chomakov commited on
Commit
69f964f
1 Parent(s): 524d66e

There was a space in the code :))))

Browse files
Files changed (1) hide show
  1. GPT-4_PDF_summary.ipynb +5 -509
GPT-4_PDF_summary.ipynb CHANGED
@@ -117,435 +117,16 @@
117
  "outputs": [
118
  {
119
  "data": {
120
- "application/javascript": [
121
- "(function(root) {\n",
122
- " function now() {\n",
123
- " return new Date();\n",
124
- " }\n",
125
- "\n",
126
- " var force = true;\n",
127
- "\n",
128
- " if (typeof root._bokeh_onload_callbacks === \"undefined\" || force === true) {\n",
129
- " root._bokeh_onload_callbacks = [];\n",
130
- " root._bokeh_is_loading = undefined;\n",
131
- " }\n",
132
- "\n",
133
- " if (typeof (root._bokeh_timeout) === \"undefined\" || force === true) {\n",
134
- " root._bokeh_timeout = Date.now() + 5000;\n",
135
- " root._bokeh_failed_load = false;\n",
136
- " }\n",
137
- "\n",
138
- " function run_callbacks() {\n",
139
- " try {\n",
140
- " root._bokeh_onload_callbacks.forEach(function(callback) {\n",
141
- " if (callback != null)\n",
142
- " callback();\n",
143
- " });\n",
144
- " } finally {\n",
145
- " delete root._bokeh_onload_callbacks\n",
146
- " }\n",
147
- " console.debug(\"Bokeh: all callbacks have finished\");\n",
148
- " }\n",
149
- "\n",
150
- " function load_libs(css_urls, js_urls, js_modules, callback) {\n",
151
- " if (css_urls == null) css_urls = [];\n",
152
- " if (js_urls == null) js_urls = [];\n",
153
- " if (js_modules == null) js_modules = [];\n",
154
- "\n",
155
- " root._bokeh_onload_callbacks.push(callback);\n",
156
- " if (root._bokeh_is_loading > 0) {\n",
157
- " console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n",
158
- " return null;\n",
159
- " }\n",
160
- " if (js_urls.length === 0 && js_modules.length === 0) {\n",
161
- " run_callbacks();\n",
162
- " return null;\n",
163
- " }\n",
164
- " console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n",
165
- "\n",
166
- " function on_load() {\n",
167
- " root._bokeh_is_loading--;\n",
168
- " if (root._bokeh_is_loading === 0) {\n",
169
- " console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n",
170
- " run_callbacks()\n",
171
- " }\n",
172
- " }\n",
173
- "\n",
174
- " function on_error() {\n",
175
- " console.error(\"failed to load \" + url);\n",
176
- " }\n",
177
- "\n",
178
- " for (var i = 0; i < css_urls.length; i++) {\n",
179
- " var url = css_urls[i];\n",
180
- " const element = document.createElement(\"link\");\n",
181
- " element.onload = on_load;\n",
182
- " element.onerror = on_error;\n",
183
- " element.rel = \"stylesheet\";\n",
184
- " element.type = \"text/css\";\n",
185
- " element.href = url;\n",
186
- " console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n",
187
- " document.body.appendChild(element);\n",
188
- " }\n",
189
- "\n",
190
- " var skip = [];\n",
191
- " if (window.requirejs) {\n",
192
- " window.requirejs.config({'packages': {}, 'paths': {'Quill': 'https://cdn.quilljs.com/1.3.6/quill', 'gridstack': 'https://cdn.jsdelivr.net/npm/[email protected]/dist/gridstack-h5', 'notyf': 'https://cdn.jsdelivr.net/npm/notyf@3/notyf.min'}, 'shim': {'gridstack': {'exports': 'GridStack'}}});\n",
193
- " require([\"Quill\"], function(Quill) {\n",
194
- "\twindow.Quill = Quill\n",
195
- "\ton_load()\n",
196
- " })\n",
197
- " require([\"gridstack\"], function(GridStack) {\n",
198
- "\twindow.GridStack = GridStack\n",
199
- "\ton_load()\n",
200
- " })\n",
201
- " require([\"notyf\"], function() {\n",
202
- "\ton_load()\n",
203
- " })\n",
204
- " root._bokeh_is_loading = css_urls.length + 3;\n",
205
- " } else {\n",
206
- " root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length;\n",
207
- " } if (((window['Quill'] !== undefined) && (!(window['Quill'] instanceof HTMLElement))) || window.requirejs) {\n",
208
- " var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.js'];\n",
209
- " for (var i = 0; i < urls.length; i++) {\n",
210
- " skip.push(urls[i])\n",
211
- " }\n",
212
- " } if (((window['GridStack'] !== undefined) && (!(window['GridStack'] instanceof HTMLElement))) || window.requirejs) {\n",
213
- " var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/gridstack/[email protected]/dist/gridstack-h5.js'];\n",
214
- " for (var i = 0; i < urls.length; i++) {\n",
215
- " skip.push(urls[i])\n",
216
- " }\n",
217
- " } if (((window['Notyf'] !== undefined) && (!(window['Notyf'] instanceof HTMLElement))) || window.requirejs) {\n",
218
- " var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/notificationarea/notyf@3/notyf.min.js'];\n",
219
- " for (var i = 0; i < urls.length; i++) {\n",
220
- " skip.push(urls[i])\n",
221
- " }\n",
222
- " } for (var i = 0; i < js_urls.length; i++) {\n",
223
- " var url = js_urls[i];\n",
224
- " if (skip.indexOf(url) >= 0) {\n",
225
- "\tif (!window.requirejs) {\n",
226
- "\t on_load();\n",
227
- "\t}\n",
228
- "\tcontinue;\n",
229
- " }\n",
230
- " var element = document.createElement('script');\n",
231
- " element.onload = on_load;\n",
232
- " element.onerror = on_error;\n",
233
- " element.async = false;\n",
234
- " element.src = url;\n",
235
- " console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n",
236
- " document.head.appendChild(element);\n",
237
- " }\n",
238
- " for (var i = 0; i < js_modules.length; i++) {\n",
239
- " var url = js_modules[i];\n",
240
- " if (skip.indexOf(url) >= 0) {\n",
241
- "\tif (!window.requirejs) {\n",
242
- "\t on_load();\n",
243
- "\t}\n",
244
- "\tcontinue;\n",
245
- " }\n",
246
- " var element = document.createElement('script');\n",
247
- " element.onload = on_load;\n",
248
- " element.onerror = on_error;\n",
249
- " element.async = false;\n",
250
- " element.src = url;\n",
251
- " element.type = \"module\";\n",
252
- " console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n",
253
- " document.head.appendChild(element);\n",
254
- " }\n",
255
- " if (!js_urls.length && !js_modules.length) {\n",
256
- " on_load()\n",
257
- " }\n",
258
- " };\n",
259
- "\n",
260
- " function inject_raw_css(css) {\n",
261
- " const element = document.createElement(\"style\");\n",
262
- " element.appendChild(document.createTextNode(css));\n",
263
- " document.body.appendChild(element);\n",
264
- " }\n",
265
- "\n",
266
- " var js_urls = [\"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-gl-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-widgets-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-tables-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-mathjax-2.4.3.min.js\", \"https://unpkg.com/@holoviz/[email protected]/dist/panel.min.js\"];\n",
267
- " var js_modules = [];\n",
268
- " var css_urls = [\"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.bubble.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.snow.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/debugger.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/alerts.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/card.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/widgets.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/markdown.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/json.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/loading.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/dataframe.css\"];\n",
269
- " var inline_js = [ function(Bokeh) {\n",
270
- " inject_raw_css(\"\\n .bk.pn-loading.arc:before {\\n background-image: url(\\\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHN0eWxlPSJtYXJnaW46IGF1dG87IGJhY2tncm91bmQ6IG5vbmU7IGRpc3BsYXk6IGJsb2NrOyBzaGFwZS1yZW5kZXJpbmc6IGF1dG87IiB2aWV3Qm94PSIwIDAgMTAwIDEwMCIgcHJlc2VydmVBc3BlY3RSYXRpbz0ieE1pZFlNaWQiPiAgPGNpcmNsZSBjeD0iNTAiIGN5PSI1MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjYzNjM2MzIiBzdHJva2Utd2lkdGg9IjEwIiByPSIzNSIgc3Ryb2tlLWRhc2hhcnJheT0iMTY0LjkzMzYxNDMxMzQ2NDE1IDU2Ljk3Nzg3MTQzNzgyMTM4Ij4gICAgPGFuaW1hdGVUcmFuc2Zvcm0gYXR0cmlidXRlTmFtZT0idHJhbnNmb3JtIiB0eXBlPSJyb3RhdGUiIHJlcGVhdENvdW50PSJpbmRlZmluaXRlIiBkdXI9IjFzIiB2YWx1ZXM9IjAgNTAgNTA7MzYwIDUwIDUwIiBrZXlUaW1lcz0iMDsxIj48L2FuaW1hdGVUcmFuc2Zvcm0+ICA8L2NpcmNsZT48L3N2Zz4=\\\");\\n background-size: auto calc(min(50%, 400px));\\n }\\n \");\n",
271
- " }, function(Bokeh) {\n",
272
- " Bokeh.set_log_level(\"info\");\n",
273
- " },\n",
274
- "function(Bokeh) {} // ensure no trailing comma for IE\n",
275
- " ];\n",
276
- "\n",
277
- " function run_inline_js() {\n",
278
- " if ((root.Bokeh !== undefined) || (force === true)) {\n",
279
- " for (var i = 0; i < inline_js.length; i++) {\n",
280
- " inline_js[i].call(root, root.Bokeh);\n",
281
- " }} else if (Date.now() < root._bokeh_timeout) {\n",
282
- " setTimeout(run_inline_js, 100);\n",
283
- " } else if (!root._bokeh_failed_load) {\n",
284
- " console.log(\"Bokeh: BokehJS failed to load within specified timeout.\");\n",
285
- " root._bokeh_failed_load = true;\n",
286
- " }\n",
287
- " }\n",
288
- "\n",
289
- " if (root._bokeh_is_loading === 0) {\n",
290
- " console.debug(\"Bokeh: BokehJS loaded, going straight to plotting\");\n",
291
- " run_inline_js();\n",
292
- " } else {\n",
293
- " load_libs(css_urls, js_urls, js_modules, function() {\n",
294
- " console.debug(\"Bokeh: BokehJS plotting callback run at\", now());\n",
295
- " run_inline_js();\n",
296
- " });\n",
297
- " }\n",
298
- "}(window));"
299
- ],
300
- "application/vnd.holoviews_load.v0+json": "(function(root) {\n function now() {\n return new Date();\n }\n\n var force = true;\n\n if (typeof root._bokeh_onload_callbacks === \"undefined\" || force === true) {\n root._bokeh_onload_callbacks = [];\n root._bokeh_is_loading = undefined;\n }\n\n if (typeof (root._bokeh_timeout) === \"undefined\" || force === true) {\n root._bokeh_timeout = Date.now() + 5000;\n root._bokeh_failed_load = false;\n }\n\n function run_callbacks() {\n try {\n root._bokeh_onload_callbacks.forEach(function(callback) {\n if (callback != null)\n callback();\n });\n } finally {\n delete root._bokeh_onload_callbacks\n }\n console.debug(\"Bokeh: all callbacks have finished\");\n }\n\n function load_libs(css_urls, js_urls, js_modules, callback) {\n if (css_urls == null) css_urls = [];\n if (js_urls == null) js_urls = [];\n if (js_modules == null) js_modules = [];\n\n root._bokeh_onload_callbacks.push(callback);\n if (root._bokeh_is_loading > 0) {\n console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n return null;\n }\n if (js_urls.length === 0 && js_modules.length === 0) {\n run_callbacks();\n return null;\n }\n console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n\n function on_load() {\n root._bokeh_is_loading--;\n if (root._bokeh_is_loading === 0) {\n console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n run_callbacks()\n }\n }\n\n function on_error() {\n console.error(\"failed to load \" + url);\n }\n\n for (var i = 0; i < css_urls.length; i++) {\n var url = css_urls[i];\n const element = document.createElement(\"link\");\n element.onload = on_load;\n element.onerror = on_error;\n element.rel = \"stylesheet\";\n element.type = \"text/css\";\n element.href = url;\n console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n document.body.appendChild(element);\n }\n\n var skip = [];\n if (window.requirejs) {\n window.requirejs.config({'packages': {}, 'paths': {'Quill': 'https://cdn.quilljs.com/1.3.6/quill', 'gridstack': 'https://cdn.jsdelivr.net/npm/[email protected]/dist/gridstack-h5', 'notyf': 'https://cdn.jsdelivr.net/npm/notyf@3/notyf.min'}, 'shim': {'gridstack': {'exports': 'GridStack'}}});\n require([\"Quill\"], function(Quill) {\n\twindow.Quill = Quill\n\ton_load()\n })\n require([\"gridstack\"], function(GridStack) {\n\twindow.GridStack = GridStack\n\ton_load()\n })\n require([\"notyf\"], function() {\n\ton_load()\n })\n root._bokeh_is_loading = css_urls.length + 3;\n } else {\n root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length;\n } if (((window['Quill'] !== undefined) && (!(window['Quill'] instanceof HTMLElement))) || window.requirejs) {\n var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.js'];\n for (var i = 0; i < urls.length; i++) {\n skip.push(urls[i])\n }\n } if (((window['GridStack'] !== undefined) && (!(window['GridStack'] instanceof HTMLElement))) || window.requirejs) {\n var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/gridstack/[email protected]/dist/gridstack-h5.js'];\n for (var i = 0; i < urls.length; i++) {\n skip.push(urls[i])\n }\n } if (((window['Notyf'] !== undefined) && (!(window['Notyf'] instanceof HTMLElement))) || window.requirejs) {\n var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/notificationarea/notyf@3/notyf.min.js'];\n for (var i = 0; i < urls.length; i++) {\n skip.push(urls[i])\n }\n } for (var i = 0; i < js_urls.length; i++) {\n var url = js_urls[i];\n if (skip.indexOf(url) >= 0) {\n\tif (!window.requirejs) {\n\t on_load();\n\t}\n\tcontinue;\n }\n var element = document.createElement('script');\n element.onload = on_load;\n element.onerror = on_error;\n element.async = false;\n element.src = url;\n console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n document.head.appendChild(element);\n }\n for (var i = 0; i < js_modules.length; i++) {\n var url = js_modules[i];\n if (skip.indexOf(url) >= 0) {\n\tif (!window.requirejs) {\n\t on_load();\n\t}\n\tcontinue;\n }\n var element = document.createElement('script');\n element.onload = on_load;\n element.onerror = on_error;\n element.async = false;\n element.src = url;\n element.type = \"module\";\n console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n document.head.appendChild(element);\n }\n if (!js_urls.length && !js_modules.length) {\n on_load()\n }\n };\n\n function inject_raw_css(css) {\n const element = document.createElement(\"style\");\n element.appendChild(document.createTextNode(css));\n document.body.appendChild(element);\n }\n\n var js_urls = [\"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-gl-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-widgets-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-tables-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-mathjax-2.4.3.min.js\", \"https://unpkg.com/@holoviz/[email protected]/dist/panel.min.js\"];\n var js_modules = [];\n var css_urls = [\"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.bubble.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.snow.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/debugger.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/alerts.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/card.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/widgets.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/markdown.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/json.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/loading.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/dataframe.css\"];\n var inline_js = [ function(Bokeh) {\n inject_raw_css(\"\\n .bk.pn-loading.arc:before {\\n background-image: url(\\\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHN0eWxlPSJtYXJnaW46IGF1dG87IGJhY2tncm91bmQ6IG5vbmU7IGRpc3BsYXk6IGJsb2NrOyBzaGFwZS1yZW5kZXJpbmc6IGF1dG87IiB2aWV3Qm94PSIwIDAgMTAwIDEwMCIgcHJlc2VydmVBc3BlY3RSYXRpbz0ieE1pZFlNaWQiPiAgPGNpcmNsZSBjeD0iNTAiIGN5PSI1MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjYzNjM2MzIiBzdHJva2Utd2lkdGg9IjEwIiByPSIzNSIgc3Ryb2tlLWRhc2hhcnJheT0iMTY0LjkzMzYxNDMxMzQ2NDE1IDU2Ljk3Nzg3MTQzNzgyMTM4Ij4gICAgPGFuaW1hdGVUcmFuc2Zvcm0gYXR0cmlidXRlTmFtZT0idHJhbnNmb3JtIiB0eXBlPSJyb3RhdGUiIHJlcGVhdENvdW50PSJpbmRlZmluaXRlIiBkdXI9IjFzIiB2YWx1ZXM9IjAgNTAgNTA7MzYwIDUwIDUwIiBrZXlUaW1lcz0iMDsxIj48L2FuaW1hdGVUcmFuc2Zvcm0+ICA8L2NpcmNsZT48L3N2Zz4=\\\");\\n background-size: auto calc(min(50%, 400px));\\n }\\n \");\n }, function(Bokeh) {\n Bokeh.set_log_level(\"info\");\n },\nfunction(Bokeh) {} // ensure no trailing comma for IE\n ];\n\n function run_inline_js() {\n if ((root.Bokeh !== undefined) || (force === true)) {\n for (var i = 0; i < inline_js.length; i++) {\n inline_js[i].call(root, root.Bokeh);\n }} else if (Date.now() < root._bokeh_timeout) {\n setTimeout(run_inline_js, 100);\n } else if (!root._bokeh_failed_load) {\n console.log(\"Bokeh: BokehJS failed to load within specified timeout.\");\n root._bokeh_failed_load = true;\n }\n }\n\n if (root._bokeh_is_loading === 0) {\n console.debug(\"Bokeh: BokehJS loaded, going straight to plotting\");\n run_inline_js();\n } else {\n load_libs(css_urls, js_urls, js_modules, function() {\n console.debug(\"Bokeh: BokehJS plotting callback run at\", now());\n run_inline_js();\n });\n }\n}(window));"
301
  },
302
  "metadata": {},
303
  "output_type": "display_data"
304
  },
305
  {
306
  "data": {
307
- "application/javascript": [
308
- "\n",
309
- "if ((window.PyViz === undefined) || (window.PyViz instanceof HTMLElement)) {\n",
310
- " window.PyViz = {comms: {}, comm_status:{}, kernels:{}, receivers: {}, plot_index: []}\n",
311
- "}\n",
312
- "\n",
313
- "\n",
314
- " function JupyterCommManager() {\n",
315
- " }\n",
316
- "\n",
317
- " JupyterCommManager.prototype.register_target = function(plot_id, comm_id, msg_handler) {\n",
318
- " if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n",
319
- " var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n",
320
- " comm_manager.register_target(comm_id, function(comm) {\n",
321
- " comm.on_msg(msg_handler);\n",
322
- " });\n",
323
- " } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n",
324
- " window.PyViz.kernels[plot_id].registerCommTarget(comm_id, function(comm) {\n",
325
- " comm.onMsg = msg_handler;\n",
326
- " });\n",
327
- " } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n",
328
- " google.colab.kernel.comms.registerTarget(comm_id, (comm) => {\n",
329
- " var messages = comm.messages[Symbol.asyncIterator]();\n",
330
- " function processIteratorResult(result) {\n",
331
- " var message = result.value;\n",
332
- " console.log(message)\n",
333
- " var content = {data: message.data, comm_id};\n",
334
- " var buffers = []\n",
335
- " for (var buffer of message.buffers || []) {\n",
336
- " buffers.push(new DataView(buffer))\n",
337
- " }\n",
338
- " var metadata = message.metadata || {};\n",
339
- " var msg = {content, buffers, metadata}\n",
340
- " msg_handler(msg);\n",
341
- " return messages.next().then(processIteratorResult);\n",
342
- " }\n",
343
- " return messages.next().then(processIteratorResult);\n",
344
- " })\n",
345
- " }\n",
346
- " }\n",
347
- "\n",
348
- " JupyterCommManager.prototype.get_client_comm = function(plot_id, comm_id, msg_handler) {\n",
349
- " if (comm_id in window.PyViz.comms) {\n",
350
- " return window.PyViz.comms[comm_id];\n",
351
- " } else if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n",
352
- " var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n",
353
- " var comm = comm_manager.new_comm(comm_id, {}, {}, {}, comm_id);\n",
354
- " if (msg_handler) {\n",
355
- " comm.on_msg(msg_handler);\n",
356
- " }\n",
357
- " } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n",
358
- " var comm = window.PyViz.kernels[plot_id].connectToComm(comm_id);\n",
359
- " comm.open();\n",
360
- " if (msg_handler) {\n",
361
- " comm.onMsg = msg_handler;\n",
362
- " }\n",
363
- " } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n",
364
- " var comm_promise = google.colab.kernel.comms.open(comm_id)\n",
365
- " comm_promise.then((comm) => {\n",
366
- " window.PyViz.comms[comm_id] = comm;\n",
367
- " if (msg_handler) {\n",
368
- " var messages = comm.messages[Symbol.asyncIterator]();\n",
369
- " function processIteratorResult(result) {\n",
370
- " var message = result.value;\n",
371
- " var content = {data: message.data};\n",
372
- " var metadata = message.metadata || {comm_id};\n",
373
- " var msg = {content, metadata}\n",
374
- " msg_handler(msg);\n",
375
- " return messages.next().then(processIteratorResult);\n",
376
- " }\n",
377
- " return messages.next().then(processIteratorResult);\n",
378
- " }\n",
379
- " }) \n",
380
- " var sendClosure = (data, metadata, buffers, disposeOnDone) => {\n",
381
- " return comm_promise.then((comm) => {\n",
382
- " comm.send(data, metadata, buffers, disposeOnDone);\n",
383
- " });\n",
384
- " };\n",
385
- " var comm = {\n",
386
- " send: sendClosure\n",
387
- " };\n",
388
- " }\n",
389
- " window.PyViz.comms[comm_id] = comm;\n",
390
- " return comm;\n",
391
- " }\n",
392
- " window.PyViz.comm_manager = new JupyterCommManager();\n",
393
- " \n",
394
- "\n",
395
- "\n",
396
- "var JS_MIME_TYPE = 'application/javascript';\n",
397
- "var HTML_MIME_TYPE = 'text/html';\n",
398
- "var EXEC_MIME_TYPE = 'application/vnd.holoviews_exec.v0+json';\n",
399
- "var CLASS_NAME = 'output';\n",
400
- "\n",
401
- "/**\n",
402
- " * Render data to the DOM node\n",
403
- " */\n",
404
- "function render(props, node) {\n",
405
- " var div = document.createElement(\"div\");\n",
406
- " var script = document.createElement(\"script\");\n",
407
- " node.appendChild(div);\n",
408
- " node.appendChild(script);\n",
409
- "}\n",
410
- "\n",
411
- "/**\n",
412
- " * Handle when a new output is added\n",
413
- " */\n",
414
- "function handle_add_output(event, handle) {\n",
415
- " var output_area = handle.output_area;\n",
416
- " var output = handle.output;\n",
417
- " if ((output.data == undefined) || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n",
418
- " return\n",
419
- " }\n",
420
- " var id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n",
421
- " var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n",
422
- " if (id !== undefined) {\n",
423
- " var nchildren = toinsert.length;\n",
424
- " var html_node = toinsert[nchildren-1].children[0];\n",
425
- " html_node.innerHTML = output.data[HTML_MIME_TYPE];\n",
426
- " var scripts = [];\n",
427
- " var nodelist = html_node.querySelectorAll(\"script\");\n",
428
- " for (var i in nodelist) {\n",
429
- " if (nodelist.hasOwnProperty(i)) {\n",
430
- " scripts.push(nodelist[i])\n",
431
- " }\n",
432
- " }\n",
433
- "\n",
434
- " scripts.forEach( function (oldScript) {\n",
435
- " var newScript = document.createElement(\"script\");\n",
436
- " var attrs = [];\n",
437
- " var nodemap = oldScript.attributes;\n",
438
- " for (var j in nodemap) {\n",
439
- " if (nodemap.hasOwnProperty(j)) {\n",
440
- " attrs.push(nodemap[j])\n",
441
- " }\n",
442
- " }\n",
443
- " attrs.forEach(function(attr) { newScript.setAttribute(attr.name, attr.value) });\n",
444
- " newScript.appendChild(document.createTextNode(oldScript.innerHTML));\n",
445
- " oldScript.parentNode.replaceChild(newScript, oldScript);\n",
446
- " });\n",
447
- " if (JS_MIME_TYPE in output.data) {\n",
448
- " toinsert[nchildren-1].children[1].textContent = output.data[JS_MIME_TYPE];\n",
449
- " }\n",
450
- " output_area._hv_plot_id = id;\n",
451
- " if ((window.Bokeh !== undefined) && (id in Bokeh.index)) {\n",
452
- " window.PyViz.plot_index[id] = Bokeh.index[id];\n",
453
- " } else {\n",
454
- " window.PyViz.plot_index[id] = null;\n",
455
- " }\n",
456
- " } else if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n",
457
- " var bk_div = document.createElement(\"div\");\n",
458
- " bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n",
459
- " var script_attrs = bk_div.children[0].attributes;\n",
460
- " for (var i = 0; i < script_attrs.length; i++) {\n",
461
- " toinsert[toinsert.length - 1].childNodes[1].setAttribute(script_attrs[i].name, script_attrs[i].value);\n",
462
- " }\n",
463
- " // store reference to server id on output_area\n",
464
- " output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n",
465
- " }\n",
466
- "}\n",
467
- "\n",
468
- "/**\n",
469
- " * Handle when an output is cleared or removed\n",
470
- " */\n",
471
- "function handle_clear_output(event, handle) {\n",
472
- " var id = handle.cell.output_area._hv_plot_id;\n",
473
- " var server_id = handle.cell.output_area._bokeh_server_id;\n",
474
- " if (((id === undefined) || !(id in PyViz.plot_index)) && (server_id !== undefined)) { return; }\n",
475
- " var comm = window.PyViz.comm_manager.get_client_comm(\"hv-extension-comm\", \"hv-extension-comm\", function () {});\n",
476
- " if (server_id !== null) {\n",
477
- " comm.send({event_type: 'server_delete', 'id': server_id});\n",
478
- " return;\n",
479
- " } else if (comm !== null) {\n",
480
- " comm.send({event_type: 'delete', 'id': id});\n",
481
- " }\n",
482
- " delete PyViz.plot_index[id];\n",
483
- " if ((window.Bokeh !== undefined) & (id in window.Bokeh.index)) {\n",
484
- " var doc = window.Bokeh.index[id].model.document\n",
485
- " doc.clear();\n",
486
- " const i = window.Bokeh.documents.indexOf(doc);\n",
487
- " if (i > -1) {\n",
488
- " window.Bokeh.documents.splice(i, 1);\n",
489
- " }\n",
490
- " }\n",
491
- "}\n",
492
- "\n",
493
- "/**\n",
494
- " * Handle kernel restart event\n",
495
- " */\n",
496
- "function handle_kernel_cleanup(event, handle) {\n",
497
- " delete PyViz.comms[\"hv-extension-comm\"];\n",
498
- " window.PyViz.plot_index = {}\n",
499
- "}\n",
500
- "\n",
501
- "/**\n",
502
- " * Handle update_display_data messages\n",
503
- " */\n",
504
- "function handle_update_output(event, handle) {\n",
505
- " handle_clear_output(event, {cell: {output_area: handle.output_area}})\n",
506
- " handle_add_output(event, handle)\n",
507
- "}\n",
508
- "\n",
509
- "function register_renderer(events, OutputArea) {\n",
510
- " function append_mime(data, metadata, element) {\n",
511
- " // create a DOM node to render to\n",
512
- " var toinsert = this.create_output_subarea(\n",
513
- " metadata,\n",
514
- " CLASS_NAME,\n",
515
- " EXEC_MIME_TYPE\n",
516
- " );\n",
517
- " this.keyboard_manager.register_events(toinsert);\n",
518
- " // Render to node\n",
519
- " var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n",
520
- " render(props, toinsert[0]);\n",
521
- " element.append(toinsert);\n",
522
- " return toinsert\n",
523
- " }\n",
524
- "\n",
525
- " events.on('output_added.OutputArea', handle_add_output);\n",
526
- " events.on('output_updated.OutputArea', handle_update_output);\n",
527
- " events.on('clear_output.CodeCell', handle_clear_output);\n",
528
- " events.on('delete.Cell', handle_clear_output);\n",
529
- " events.on('kernel_ready.Kernel', handle_kernel_cleanup);\n",
530
- "\n",
531
- " OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n",
532
- " safe: true,\n",
533
- " index: 0\n",
534
- " });\n",
535
- "}\n",
536
- "\n",
537
- "if (window.Jupyter !== undefined) {\n",
538
- " try {\n",
539
- " var events = require('base/js/events');\n",
540
- " var OutputArea = require('notebook/js/outputarea').OutputArea;\n",
541
- " if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n",
542
- " register_renderer(events, OutputArea);\n",
543
- " }\n",
544
- " } catch(err) {\n",
545
- " }\n",
546
- "}\n"
547
- ],
548
- "application/vnd.holoviews_load.v0+json": "\nif ((window.PyViz === undefined) || (window.PyViz instanceof HTMLElement)) {\n window.PyViz = {comms: {}, comm_status:{}, kernels:{}, receivers: {}, plot_index: []}\n}\n\n\n function JupyterCommManager() {\n }\n\n JupyterCommManager.prototype.register_target = function(plot_id, comm_id, msg_handler) {\n if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n comm_manager.register_target(comm_id, function(comm) {\n comm.on_msg(msg_handler);\n });\n } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n window.PyViz.kernels[plot_id].registerCommTarget(comm_id, function(comm) {\n comm.onMsg = msg_handler;\n });\n } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n google.colab.kernel.comms.registerTarget(comm_id, (comm) => {\n var messages = comm.messages[Symbol.asyncIterator]();\n function processIteratorResult(result) {\n var message = result.value;\n console.log(message)\n var content = {data: message.data, comm_id};\n var buffers = []\n for (var buffer of message.buffers || []) {\n buffers.push(new DataView(buffer))\n }\n var metadata = message.metadata || {};\n var msg = {content, buffers, metadata}\n msg_handler(msg);\n return messages.next().then(processIteratorResult);\n }\n return messages.next().then(processIteratorResult);\n })\n }\n }\n\n JupyterCommManager.prototype.get_client_comm = function(plot_id, comm_id, msg_handler) {\n if (comm_id in window.PyViz.comms) {\n return window.PyViz.comms[comm_id];\n } else if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n var comm = comm_manager.new_comm(comm_id, {}, {}, {}, comm_id);\n if (msg_handler) {\n comm.on_msg(msg_handler);\n }\n } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n var comm = window.PyViz.kernels[plot_id].connectToComm(comm_id);\n comm.open();\n if (msg_handler) {\n comm.onMsg = msg_handler;\n }\n } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n var comm_promise = google.colab.kernel.comms.open(comm_id)\n comm_promise.then((comm) => {\n window.PyViz.comms[comm_id] = comm;\n if (msg_handler) {\n var messages = comm.messages[Symbol.asyncIterator]();\n function processIteratorResult(result) {\n var message = result.value;\n var content = {data: message.data};\n var metadata = message.metadata || {comm_id};\n var msg = {content, metadata}\n msg_handler(msg);\n return messages.next().then(processIteratorResult);\n }\n return messages.next().then(processIteratorResult);\n }\n }) \n var sendClosure = (data, metadata, buffers, disposeOnDone) => {\n return comm_promise.then((comm) => {\n comm.send(data, metadata, buffers, disposeOnDone);\n });\n };\n var comm = {\n send: sendClosure\n };\n }\n window.PyViz.comms[comm_id] = comm;\n return comm;\n }\n window.PyViz.comm_manager = new JupyterCommManager();\n \n\n\nvar JS_MIME_TYPE = 'application/javascript';\nvar HTML_MIME_TYPE = 'text/html';\nvar EXEC_MIME_TYPE = 'application/vnd.holoviews_exec.v0+json';\nvar CLASS_NAME = 'output';\n\n/**\n * Render data to the DOM node\n */\nfunction render(props, node) {\n var div = document.createElement(\"div\");\n var script = document.createElement(\"script\");\n node.appendChild(div);\n node.appendChild(script);\n}\n\n/**\n * Handle when a new output is added\n */\nfunction handle_add_output(event, handle) {\n var output_area = handle.output_area;\n var output = handle.output;\n if ((output.data == undefined) || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n return\n }\n var id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n if (id !== undefined) {\n var nchildren = toinsert.length;\n var html_node = toinsert[nchildren-1].children[0];\n html_node.innerHTML = output.data[HTML_MIME_TYPE];\n var scripts = [];\n var nodelist = html_node.querySelectorAll(\"script\");\n for (var i in nodelist) {\n if (nodelist.hasOwnProperty(i)) {\n scripts.push(nodelist[i])\n }\n }\n\n scripts.forEach( function (oldScript) {\n var newScript = document.createElement(\"script\");\n var attrs = [];\n var nodemap = oldScript.attributes;\n for (var j in nodemap) {\n if (nodemap.hasOwnProperty(j)) {\n attrs.push(nodemap[j])\n }\n }\n attrs.forEach(function(attr) { newScript.setAttribute(attr.name, attr.value) });\n newScript.appendChild(document.createTextNode(oldScript.innerHTML));\n oldScript.parentNode.replaceChild(newScript, oldScript);\n });\n if (JS_MIME_TYPE in output.data) {\n toinsert[nchildren-1].children[1].textContent = output.data[JS_MIME_TYPE];\n }\n output_area._hv_plot_id = id;\n if ((window.Bokeh !== undefined) && (id in Bokeh.index)) {\n window.PyViz.plot_index[id] = Bokeh.index[id];\n } else {\n window.PyViz.plot_index[id] = null;\n }\n } else if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n var bk_div = document.createElement(\"div\");\n bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n var script_attrs = bk_div.children[0].attributes;\n for (var i = 0; i < script_attrs.length; i++) {\n toinsert[toinsert.length - 1].childNodes[1].setAttribute(script_attrs[i].name, script_attrs[i].value);\n }\n // store reference to server id on output_area\n output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n }\n}\n\n/**\n * Handle when an output is cleared or removed\n */\nfunction handle_clear_output(event, handle) {\n var id = handle.cell.output_area._hv_plot_id;\n var server_id = handle.cell.output_area._bokeh_server_id;\n if (((id === undefined) || !(id in PyViz.plot_index)) && (server_id !== undefined)) { return; }\n var comm = window.PyViz.comm_manager.get_client_comm(\"hv-extension-comm\", \"hv-extension-comm\", function () {});\n if (server_id !== null) {\n comm.send({event_type: 'server_delete', 'id': server_id});\n return;\n } else if (comm !== null) {\n comm.send({event_type: 'delete', 'id': id});\n }\n delete PyViz.plot_index[id];\n if ((window.Bokeh !== undefined) & (id in window.Bokeh.index)) {\n var doc = window.Bokeh.index[id].model.document\n doc.clear();\n const i = window.Bokeh.documents.indexOf(doc);\n if (i > -1) {\n window.Bokeh.documents.splice(i, 1);\n }\n }\n}\n\n/**\n * Handle kernel restart event\n */\nfunction handle_kernel_cleanup(event, handle) {\n delete PyViz.comms[\"hv-extension-comm\"];\n window.PyViz.plot_index = {}\n}\n\n/**\n * Handle update_display_data messages\n */\nfunction handle_update_output(event, handle) {\n handle_clear_output(event, {cell: {output_area: handle.output_area}})\n handle_add_output(event, handle)\n}\n\nfunction register_renderer(events, OutputArea) {\n function append_mime(data, metadata, element) {\n // create a DOM node to render to\n var toinsert = this.create_output_subarea(\n metadata,\n CLASS_NAME,\n EXEC_MIME_TYPE\n );\n this.keyboard_manager.register_events(toinsert);\n // Render to node\n var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n render(props, toinsert[0]);\n element.append(toinsert);\n return toinsert\n }\n\n events.on('output_added.OutputArea', handle_add_output);\n events.on('output_updated.OutputArea', handle_update_output);\n events.on('clear_output.CodeCell', handle_clear_output);\n events.on('delete.Cell', handle_clear_output);\n events.on('kernel_ready.Kernel', handle_kernel_cleanup);\n\n OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n safe: true,\n index: 0\n });\n}\n\nif (window.Jupyter !== undefined) {\n try {\n var events = require('base/js/events');\n var OutputArea = require('notebook/js/outputarea').OutputArea;\n if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n register_renderer(events, OutputArea);\n }\n } catch(err) {\n }\n}\n"
549
  },
550
  "metadata": {},
551
  "output_type": "display_data"
@@ -645,75 +226,6 @@
645
  " return result"
646
  ]
647
  },
648
- {
649
- "cell_type": "code",
650
- "execution_count": 5,
651
- "id": "f0d05516",
652
- "metadata": {},
653
- "outputs": [
654
- {
655
- "data": {},
656
- "metadata": {},
657
- "output_type": "display_data"
658
- },
659
- {
660
- "data": {
661
- "application/vnd.holoviews_exec.v0+json": "",
662
- "text/html": [
663
- "<div id='1002'>\n",
664
- " <div class=\"bk-root\" id=\"2c4c2cc8-1a02-45fe-8d30-e716654592a9\" data-root-id=\"1002\"></div>\n",
665
- "</div>\n",
666
- "<script type=\"application/javascript\">(function(root) {\n",
667
- " function embed_document(root) {\n",
668
- " var docs_json = {\"419de70a-56db-4acb-b656-37b21ce66579\":{\"defs\":[{\"extends\":null,\"module\":null,\"name\":\"ReactiveHTML1\",\"overrides\":[],\"properties\":[]},{\"extends\":null,\"module\":null,\"name\":\"FlexBox1\",\"overrides\":[],\"properties\":[{\"default\":\"flex-start\",\"kind\":null,\"name\":\"align_content\"},{\"default\":\"flex-start\",\"kind\":null,\"name\":\"align_items\"},{\"default\":\"row\",\"kind\":null,\"name\":\"flex_direction\"},{\"default\":\"wrap\",\"kind\":null,\"name\":\"flex_wrap\"},{\"default\":\"flex-start\",\"kind\":null,\"name\":\"justify_content\"}]},{\"extends\":null,\"module\":null,\"name\":\"GridStack1\",\"overrides\":[],\"properties\":[{\"default\":\"warn\",\"kind\":null,\"name\":\"mode\"},{\"default\":null,\"kind\":null,\"name\":\"ncols\"},{\"default\":null,\"kind\":null,\"name\":\"nrows\"},{\"default\":true,\"kind\":null,\"name\":\"allow_resize\"},{\"default\":true,\"kind\":null,\"name\":\"allow_drag\"},{\"default\":[],\"kind\":null,\"name\":\"state\"}]},{\"extends\":null,\"module\":null,\"name\":\"click1\",\"overrides\":[],\"properties\":[{\"default\":\"\",\"kind\":null,\"name\":\"terminal_output\"},{\"default\":\"\",\"kind\":null,\"name\":\"debug_name\"},{\"default\":0,\"kind\":null,\"name\":\"clears\"}]},{\"extends\":null,\"module\":null,\"name\":\"NotificationAreaBase1\",\"overrides\":[],\"properties\":[{\"default\":\"bottom-right\",\"kind\":null,\"name\":\"position\"},{\"default\":0,\"kind\":null,\"name\":\"_clear\"}]},{\"extends\":null,\"module\":null,\"name\":\"NotificationArea1\",\"overrides\":[],\"properties\":[{\"default\":[],\"kind\":null,\"name\":\"notifications\"},{\"default\":\"bottom-right\",\"kind\":null,\"name\":\"position\"},{\"default\":0,\"kind\":null,\"name\":\"_clear\"},{\"default\":[{\"background\":\"#ffc107\",\"icon\":{\"className\":\"fas fa-exclamation-triangle\",\"color\":\"white\",\"tagName\":\"i\"},\"type\":\"warning\"},{\"background\":\"#007bff\",\"icon\":{\"className\":\"fas fa-info-circle\",\"color\":\"white\",\"tagName\":\"i\"},\"type\":\"info\"}],\"kind\":null,\"name\":\"types\"}]},{\"extends\":null,\"module\":null,\"name\":\"Notification\",\"overrides\":[],\"properties\":[{\"default\":null,\"kind\":null,\"name\":\"background\"},{\"default\":3000,\"kind\":null,\"name\":\"duration\"},{\"default\":null,\"kind\":null,\"name\":\"icon\"},{\"default\":\"\",\"kind\":null,\"name\":\"message\"},{\"default\":null,\"kind\":null,\"name\":\"notification_type\"},{\"default\":false,\"kind\":null,\"name\":\"_destroyed\"}]},{\"extends\":null,\"module\":null,\"name\":\"TemplateActions1\",\"overrides\":[],\"properties\":[{\"default\":0,\"kind\":null,\"name\":\"open_modal\"},{\"default\":0,\"kind\":null,\"name\":\"close_modal\"}]},{\"extends\":null,\"module\":null,\"name\":\"MaterialTemplateActions1\",\"overrides\":[],\"properties\":[{\"default\":0,\"kind\":null,\"name\":\"open_modal\"},{\"default\":0,\"kind\":null,\"name\":\"close_modal\"}]}],\"roots\":{\"references\":[{\"attributes\":{\"client_comm_id\":\"2f1f9300e11c4ab299196b99237bc938\",\"comm_id\":\"4dd3b41cc96b40c2a579ecf230025936\",\"plot_id\":\"1002\"},\"id\":\"1003\",\"type\":\"panel.models.comm_manager.CommManager\"},{\"attributes\":{\"margin\":[5,10,5,10],\"min_width\":300,\"width\":300},\"id\":\"1002\",\"type\":\"FileInput\"},{\"attributes\":{\"reload\":false},\"id\":\"1004\",\"type\":\"panel.models.location.Location\"}],\"root_ids\":[\"1002\",\"1003\",\"1004\"]},\"title\":\"Bokeh Application\",\"version\":\"2.4.3\"}};\n",
669
- " var render_items = [{\"docid\":\"419de70a-56db-4acb-b656-37b21ce66579\",\"root_ids\":[\"1002\"],\"roots\":{\"1002\":\"2c4c2cc8-1a02-45fe-8d30-e716654592a9\"}}];\n",
670
- " root.Bokeh.embed.embed_items_notebook(docs_json, render_items);\n",
671
- " for (const render_item of render_items) {\n",
672
- " for (const root_id of render_item.root_ids) {\n",
673
- "\tconst id_el = document.getElementById(root_id)\n",
674
- "\tif (id_el.children.length && (id_el.children[0].className === 'bk-root')) {\n",
675
- "\t const root_el = id_el.children[0]\n",
676
- "\t root_el.id = root_el.id + '-rendered'\n",
677
- "\t}\n",
678
- " }\n",
679
- " }\n",
680
- " }\n",
681
- " if (root.Bokeh !== undefined && root.Bokeh.Panel !== undefined) {\n",
682
- " embed_document(root);\n",
683
- " } else {\n",
684
- " var attempts = 0;\n",
685
- " var timer = setInterval(function(root) {\n",
686
- " if (root.Bokeh !== undefined && root.Bokeh.Panel !== undefined) {\n",
687
- " clearInterval(timer);\n",
688
- " embed_document(root);\n",
689
- " } else if (document.readyState == \"complete\") {\n",
690
- " attempts++;\n",
691
- " if (attempts > 200) {\n",
692
- " clearInterval(timer);\n",
693
- " console.log(\"Bokeh: ERROR: Unable to run BokehJS code because BokehJS library is missing\");\n",
694
- " }\n",
695
- " }\n",
696
- " }, 25, root)\n",
697
- " }\n",
698
- "})(window);</script>"
699
- ],
700
- "text/plain": [
701
- "FileInput(width=300)"
702
- ]
703
- },
704
- "execution_count": 5,
705
- "metadata": {
706
- "application/vnd.holoviews_exec.v0+json": {
707
- "id": "1002"
708
- }
709
- },
710
- "output_type": "execute_result"
711
- }
712
- ],
713
- "source": [
714
- "file_input"
715
- ]
716
- },
717
  {
718
  "cell_type": "code",
719
  "execution_count": 6,
@@ -862,7 +374,7 @@
862
  "source": [
863
  "# layout\n",
864
  "pn.Column(\n",
865
- " pn.pane.Markdown (\"\"\"\n",
866
  " ## \\U0001F60A! Question Answering with your PDF file\n",
867
  " \n",
868
  " 1) Upload a PDF. 2) Enter OpenAI API key. This costs $. Set up billing at OpenAl. 3) Type a question and click \"Run\".\n",
@@ -873,22 +385,6 @@
873
  " widgets\n",
874
  ").servable()"
875
  ]
876
- },
877
- {
878
- "cell_type": "code",
879
- "execution_count": null,
880
- "id": "56cffd14",
881
- "metadata": {},
882
- "outputs": [],
883
- "source": []
884
- },
885
- {
886
- "cell_type": "code",
887
- "execution_count": null,
888
- "id": "7487267b",
889
- "metadata": {},
890
- "outputs": [],
891
- "source": []
892
  }
893
  ],
894
  "metadata": {
 
117
  "outputs": [
118
  {
119
  "data": {
120
+ "application/javascript": "(function(root) {\n function now() {\n return new Date();\n }\n\n var force = true;\n\n if (typeof root._bokeh_onload_callbacks === \"undefined\" || force === true) {\n root._bokeh_onload_callbacks = [];\n root._bokeh_is_loading = undefined;\n }\n\n if (typeof (root._bokeh_timeout) === \"undefined\" || force === true) {\n root._bokeh_timeout = Date.now() + 5000;\n root._bokeh_failed_load = false;\n }\n\n function run_callbacks() {\n try {\n root._bokeh_onload_callbacks.forEach(function(callback) {\n if (callback != null)\n callback();\n });\n } finally {\n delete root._bokeh_onload_callbacks\n }\n console.debug(\"Bokeh: all callbacks have finished\");\n }\n\n function load_libs(css_urls, js_urls, js_modules, callback) {\n if (css_urls == null) css_urls = [];\n if (js_urls == null) js_urls = [];\n if (js_modules == null) js_modules = [];\n\n root._bokeh_onload_callbacks.push(callback);\n if (root._bokeh_is_loading > 0) {\n console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n return null;\n }\n if (js_urls.length === 0 && js_modules.length === 0) {\n run_callbacks();\n return null;\n }\n console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n\n function on_load() {\n root._bokeh_is_loading--;\n if (root._bokeh_is_loading === 0) {\n console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n run_callbacks()\n }\n }\n\n function on_error() {\n console.error(\"failed to load \" + url);\n }\n\n for (var i = 0; i < css_urls.length; i++) {\n var url = css_urls[i];\n const element = document.createElement(\"link\");\n element.onload = on_load;\n element.onerror = on_error;\n element.rel = \"stylesheet\";\n element.type = \"text/css\";\n element.href = url;\n console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n document.body.appendChild(element);\n }\n\n var skip = [];\n if (window.requirejs) {\n window.requirejs.config({'packages': {}, 'paths': {'Quill': 'https://cdn.quilljs.com/1.3.6/quill', 'gridstack': 'https://cdn.jsdelivr.net/npm/[email protected]/dist/gridstack-h5', 'notyf': 'https://cdn.jsdelivr.net/npm/notyf@3/notyf.min'}, 'shim': {'gridstack': {'exports': 'GridStack'}}});\n require([\"Quill\"], function(Quill) {\n\twindow.Quill = Quill\n\ton_load()\n })\n require([\"gridstack\"], function(GridStack) {\n\twindow.GridStack = GridStack\n\ton_load()\n })\n require([\"notyf\"], function() {\n\ton_load()\n })\n root._bokeh_is_loading = css_urls.length + 3;\n } else {\n root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length;\n } if (((window['Quill'] !== undefined) && (!(window['Quill'] instanceof HTMLElement))) || window.requirejs) {\n var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.js'];\n for (var i = 0; i < urls.length; i++) {\n skip.push(urls[i])\n }\n } if (((window['GridStack'] !== undefined) && (!(window['GridStack'] instanceof HTMLElement))) || window.requirejs) {\n var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/gridstack/[email protected]/dist/gridstack-h5.js'];\n for (var i = 0; i < urls.length; i++) {\n skip.push(urls[i])\n }\n } if (((window['Notyf'] !== undefined) && (!(window['Notyf'] instanceof HTMLElement))) || window.requirejs) {\n var urls = ['https://cdn.holoviz.org/panel/0.14.4/dist/bundled/notificationarea/notyf@3/notyf.min.js'];\n for (var i = 0; i < urls.length; i++) {\n skip.push(urls[i])\n }\n } for (var i = 0; i < js_urls.length; i++) {\n var url = js_urls[i];\n if (skip.indexOf(url) >= 0) {\n\tif (!window.requirejs) {\n\t on_load();\n\t}\n\tcontinue;\n }\n var element = document.createElement('script');\n element.onload = on_load;\n element.onerror = on_error;\n element.async = false;\n element.src = url;\n console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n document.head.appendChild(element);\n }\n for (var i = 0; i < js_modules.length; i++) {\n var url = js_modules[i];\n if (skip.indexOf(url) >= 0) {\n\tif (!window.requirejs) {\n\t on_load();\n\t}\n\tcontinue;\n }\n var element = document.createElement('script');\n element.onload = on_load;\n element.onerror = on_error;\n element.async = false;\n element.src = url;\n element.type = \"module\";\n console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n document.head.appendChild(element);\n }\n if (!js_urls.length && !js_modules.length) {\n on_load()\n }\n };\n\n function inject_raw_css(css) {\n const element = document.createElement(\"style\");\n element.appendChild(document.createTextNode(css));\n document.body.appendChild(element);\n }\n\n var js_urls = [\"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-gl-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-widgets-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-tables-2.4.3.min.js\", \"https://cdn.bokeh.org/bokeh/release/bokeh-mathjax-2.4.3.min.js\", \"https://unpkg.com/@holoviz/[email protected]/dist/panel.min.js\"];\n var js_modules = [];\n var css_urls = [\"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.bubble.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/bundled/quillinput/1.3.6/quill.snow.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/debugger.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/alerts.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/card.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/widgets.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/markdown.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/json.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/loading.css\", \"https://cdn.holoviz.org/panel/0.14.4/dist/css/dataframe.css\"];\n var inline_js = [ function(Bokeh) {\n inject_raw_css(\"\\n .bk.pn-loading.arc:before {\\n background-image: url(\\\"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHN0eWxlPSJtYXJnaW46IGF1dG87IGJhY2tncm91bmQ6IG5vbmU7IGRpc3BsYXk6IGJsb2NrOyBzaGFwZS1yZW5kZXJpbmc6IGF1dG87IiB2aWV3Qm94PSIwIDAgMTAwIDEwMCIgcHJlc2VydmVBc3BlY3RSYXRpbz0ieE1pZFlNaWQiPiAgPGNpcmNsZSBjeD0iNTAiIGN5PSI1MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjYzNjM2MzIiBzdHJva2Utd2lkdGg9IjEwIiByPSIzNSIgc3Ryb2tlLWRhc2hhcnJheT0iMTY0LjkzMzYxNDMxMzQ2NDE1IDU2Ljk3Nzg3MTQzNzgyMTM4Ij4gICAgPGFuaW1hdGVUcmFuc2Zvcm0gYXR0cmlidXRlTmFtZT0idHJhbnNmb3JtIiB0eXBlPSJyb3RhdGUiIHJlcGVhdENvdW50PSJpbmRlZmluaXRlIiBkdXI9IjFzIiB2YWx1ZXM9IjAgNTAgNTA7MzYwIDUwIDUwIiBrZXlUaW1lcz0iMDsxIj48L2FuaW1hdGVUcmFuc2Zvcm0+ICA8L2NpcmNsZT48L3N2Zz4=\\\");\\n background-size: auto calc(min(50%, 400px));\\n }\\n \");\n }, function(Bokeh) {\n Bokeh.set_log_level(\"info\");\n },\nfunction(Bokeh) {} // ensure no trailing comma for IE\n ];\n\n function run_inline_js() {\n if ((root.Bokeh !== undefined) || (force === true)) {\n for (var i = 0; i < inline_js.length; i++) {\n inline_js[i].call(root, root.Bokeh);\n }} else if (Date.now() < root._bokeh_timeout) {\n setTimeout(run_inline_js, 100);\n } else if (!root._bokeh_failed_load) {\n console.log(\"Bokeh: BokehJS failed to load within specified timeout.\");\n root._bokeh_failed_load = true;\n }\n }\n\n if (root._bokeh_is_loading === 0) {\n console.debug(\"Bokeh: BokehJS loaded, going straight to plotting\");\n run_inline_js();\n } else {\n load_libs(css_urls, js_urls, js_modules, function() {\n console.debug(\"Bokeh: BokehJS plotting callback run at\", now());\n run_inline_js();\n });\n }\n}(window));",
121
+ "application/vnd.holoviews_load.v0+json": ""
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
122
  },
123
  "metadata": {},
124
  "output_type": "display_data"
125
  },
126
  {
127
  "data": {
128
+ "application/javascript": "\nif ((window.PyViz === undefined) || (window.PyViz instanceof HTMLElement)) {\n window.PyViz = {comms: {}, comm_status:{}, kernels:{}, receivers: {}, plot_index: []}\n}\n\n\n function JupyterCommManager() {\n }\n\n JupyterCommManager.prototype.register_target = function(plot_id, comm_id, msg_handler) {\n if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n comm_manager.register_target(comm_id, function(comm) {\n comm.on_msg(msg_handler);\n });\n } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n window.PyViz.kernels[plot_id].registerCommTarget(comm_id, function(comm) {\n comm.onMsg = msg_handler;\n });\n } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n google.colab.kernel.comms.registerTarget(comm_id, (comm) => {\n var messages = comm.messages[Symbol.asyncIterator]();\n function processIteratorResult(result) {\n var message = result.value;\n console.log(message)\n var content = {data: message.data, comm_id};\n var buffers = []\n for (var buffer of message.buffers || []) {\n buffers.push(new DataView(buffer))\n }\n var metadata = message.metadata || {};\n var msg = {content, buffers, metadata}\n msg_handler(msg);\n return messages.next().then(processIteratorResult);\n }\n return messages.next().then(processIteratorResult);\n })\n }\n }\n\n JupyterCommManager.prototype.get_client_comm = function(plot_id, comm_id, msg_handler) {\n if (comm_id in window.PyViz.comms) {\n return window.PyViz.comms[comm_id];\n } else if (window.comm_manager || ((window.Jupyter !== undefined) && (Jupyter.notebook.kernel != null))) {\n var comm_manager = window.comm_manager || Jupyter.notebook.kernel.comm_manager;\n var comm = comm_manager.new_comm(comm_id, {}, {}, {}, comm_id);\n if (msg_handler) {\n comm.on_msg(msg_handler);\n }\n } else if ((plot_id in window.PyViz.kernels) && (window.PyViz.kernels[plot_id])) {\n var comm = window.PyViz.kernels[plot_id].connectToComm(comm_id);\n comm.open();\n if (msg_handler) {\n comm.onMsg = msg_handler;\n }\n } else if (typeof google != 'undefined' && google.colab.kernel != null) {\n var comm_promise = google.colab.kernel.comms.open(comm_id)\n comm_promise.then((comm) => {\n window.PyViz.comms[comm_id] = comm;\n if (msg_handler) {\n var messages = comm.messages[Symbol.asyncIterator]();\n function processIteratorResult(result) {\n var message = result.value;\n var content = {data: message.data};\n var metadata = message.metadata || {comm_id};\n var msg = {content, metadata}\n msg_handler(msg);\n return messages.next().then(processIteratorResult);\n }\n return messages.next().then(processIteratorResult);\n }\n }) \n var sendClosure = (data, metadata, buffers, disposeOnDone) => {\n return comm_promise.then((comm) => {\n comm.send(data, metadata, buffers, disposeOnDone);\n });\n };\n var comm = {\n send: sendClosure\n };\n }\n window.PyViz.comms[comm_id] = comm;\n return comm;\n }\n window.PyViz.comm_manager = new JupyterCommManager();\n \n\n\nvar JS_MIME_TYPE = 'application/javascript';\nvar HTML_MIME_TYPE = 'text/html';\nvar EXEC_MIME_TYPE = 'application/vnd.holoviews_exec.v0+json';\nvar CLASS_NAME = 'output';\n\n/**\n * Render data to the DOM node\n */\nfunction render(props, node) {\n var div = document.createElement(\"div\");\n var script = document.createElement(\"script\");\n node.appendChild(div);\n node.appendChild(script);\n}\n\n/**\n * Handle when a new output is added\n */\nfunction handle_add_output(event, handle) {\n var output_area = handle.output_area;\n var output = handle.output;\n if ((output.data == undefined) || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n return\n }\n var id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n if (id !== undefined) {\n var nchildren = toinsert.length;\n var html_node = toinsert[nchildren-1].children[0];\n html_node.innerHTML = output.data[HTML_MIME_TYPE];\n var scripts = [];\n var nodelist = html_node.querySelectorAll(\"script\");\n for (var i in nodelist) {\n if (nodelist.hasOwnProperty(i)) {\n scripts.push(nodelist[i])\n }\n }\n\n scripts.forEach( function (oldScript) {\n var newScript = document.createElement(\"script\");\n var attrs = [];\n var nodemap = oldScript.attributes;\n for (var j in nodemap) {\n if (nodemap.hasOwnProperty(j)) {\n attrs.push(nodemap[j])\n }\n }\n attrs.forEach(function(attr) { newScript.setAttribute(attr.name, attr.value) });\n newScript.appendChild(document.createTextNode(oldScript.innerHTML));\n oldScript.parentNode.replaceChild(newScript, oldScript);\n });\n if (JS_MIME_TYPE in output.data) {\n toinsert[nchildren-1].children[1].textContent = output.data[JS_MIME_TYPE];\n }\n output_area._hv_plot_id = id;\n if ((window.Bokeh !== undefined) && (id in Bokeh.index)) {\n window.PyViz.plot_index[id] = Bokeh.index[id];\n } else {\n window.PyViz.plot_index[id] = null;\n }\n } else if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n var bk_div = document.createElement(\"div\");\n bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n var script_attrs = bk_div.children[0].attributes;\n for (var i = 0; i < script_attrs.length; i++) {\n toinsert[toinsert.length - 1].childNodes[1].setAttribute(script_attrs[i].name, script_attrs[i].value);\n }\n // store reference to server id on output_area\n output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n }\n}\n\n/**\n * Handle when an output is cleared or removed\n */\nfunction handle_clear_output(event, handle) {\n var id = handle.cell.output_area._hv_plot_id;\n var server_id = handle.cell.output_area._bokeh_server_id;\n if (((id === undefined) || !(id in PyViz.plot_index)) && (server_id !== undefined)) { return; }\n var comm = window.PyViz.comm_manager.get_client_comm(\"hv-extension-comm\", \"hv-extension-comm\", function () {});\n if (server_id !== null) {\n comm.send({event_type: 'server_delete', 'id': server_id});\n return;\n } else if (comm !== null) {\n comm.send({event_type: 'delete', 'id': id});\n }\n delete PyViz.plot_index[id];\n if ((window.Bokeh !== undefined) & (id in window.Bokeh.index)) {\n var doc = window.Bokeh.index[id].model.document\n doc.clear();\n const i = window.Bokeh.documents.indexOf(doc);\n if (i > -1) {\n window.Bokeh.documents.splice(i, 1);\n }\n }\n}\n\n/**\n * Handle kernel restart event\n */\nfunction handle_kernel_cleanup(event, handle) {\n delete PyViz.comms[\"hv-extension-comm\"];\n window.PyViz.plot_index = {}\n}\n\n/**\n * Handle update_display_data messages\n */\nfunction handle_update_output(event, handle) {\n handle_clear_output(event, {cell: {output_area: handle.output_area}})\n handle_add_output(event, handle)\n}\n\nfunction register_renderer(events, OutputArea) {\n function append_mime(data, metadata, element) {\n // create a DOM node to render to\n var toinsert = this.create_output_subarea(\n metadata,\n CLASS_NAME,\n EXEC_MIME_TYPE\n );\n this.keyboard_manager.register_events(toinsert);\n // Render to node\n var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n render(props, toinsert[0]);\n element.append(toinsert);\n return toinsert\n }\n\n events.on('output_added.OutputArea', handle_add_output);\n events.on('output_updated.OutputArea', handle_update_output);\n events.on('clear_output.CodeCell', handle_clear_output);\n events.on('delete.Cell', handle_clear_output);\n events.on('kernel_ready.Kernel', handle_kernel_cleanup);\n\n OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n safe: true,\n index: 0\n });\n}\n\nif (window.Jupyter !== undefined) {\n try {\n var events = require('base/js/events');\n var OutputArea = require('notebook/js/outputarea').OutputArea;\n if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n register_renderer(events, OutputArea);\n }\n } catch(err) {\n }\n}\n",
129
+ "application/vnd.holoviews_load.v0+json": ""
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
130
  },
131
  "metadata": {},
132
  "output_type": "display_data"
 
226
  " return result"
227
  ]
228
  },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
229
  {
230
  "cell_type": "code",
231
  "execution_count": 6,
 
374
  "source": [
375
  "# layout\n",
376
  "pn.Column(\n",
377
+ " pn.pane.Markdown(\"\"\"\n",
378
  " ## \\U0001F60A! Question Answering with your PDF file\n",
379
  " \n",
380
  " 1) Upload a PDF. 2) Enter OpenAI API key. This costs $. Set up billing at OpenAl. 3) Type a question and click \"Run\".\n",
 
385
  " widgets\n",
386
  ").servable()"
387
  ]
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
388
  }
389
  ],
390
  "metadata": {