{ "cells": [ { "cell_type": "code", "execution_count": 1, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/html": [ "\n", "<script src=\"https://code.jquery.com/ui/1.10.4/jquery-ui.min.js\" type=\"text/javascript\"></script>\n", "<script type=\"text/javascript\">function HoloViewsWidget(){\n", "}\n", "\n", "HoloViewsWidget.prototype.init_slider = function(init_val){\n", "\tif(this.load_json) {\n", "\t\tthis.from_json()\n", "\t} else {\n", "\t\tthis.update_cache();\n", "\t}\n", "}\n", "\n", "HoloViewsWidget.prototype.populate_cache = function(idx){\n", " this.cache[idx].html(this.frames[idx]);\n", " if (this.embed) {\n", " delete this.frames[idx];\n", " }\n", "}\n", "\n", "HoloViewsWidget.prototype.process_error = function(msg){\n", "\n", "}\n", "\n", "HoloViewsWidget.prototype.from_json = function() {\n", "\tvar data_url = this.json_path + this.id + '.json';\n", "\t$.getJSON(data_url, $.proxy(function(json_data) {\n", "\t\tthis.frames = json_data;\n", "\t\tthis.update_cache();\n", "\t\tthis.update(0);\n", "\t}, this));\n", "}\n", "\n", "HoloViewsWidget.prototype.dynamic_update = function(current){\n", " function callback(msg){\n", " /* This callback receives data from Python as a string\n", " in order to parse it correctly quotes are sliced off*/\n", " var data = msg.content.data['text/plain'].slice(1, -1);\n", " this.frames[current] = data;\n", " this.update_cache();\n", " this.update(current);\n", " }\n", " if(!(current in this.cache)) {\n", " var kernel = IPython.notebook.kernel;\n", " callbacks = {iopub: {output: $.proxy(callback, this)}};\n", " var cmd = \"holoviews.plotting.widgets.NdWidget.widgets['\" + this.id + \"'].update(\" + current + \")\";\n", " kernel.execute(\"import holoviews;\" + cmd, callbacks, {silent : false});\n", " } else {\n", " this.update(current);\n", " }\n", "}\n", "\n", "HoloViewsWidget.prototype.update_cache = function(){\n", " var frame_len = Object.keys(this.frames).length;\n", " for (var i=0; i<frame_len; i++) {\n", " if(!this.load_json || this.dynamic) {\n", " frame = Object.keys(this.frames)[i];\n", " } else {\n", " frame = i;\n", " }\n", " if(!(frame in this.cache)) {\n", " this.cache[frame] = $('<div />').appendTo(\"#\" + this.img_id).hide();\n", " var cache_id = this.img_id+\"_\"+frame;\n", " this.cache[frame].attr(\"id\", cache_id);\n", " this.populate_cache(frame);\n", " }\n", " }\n", "}\n", "\n", "HoloViewsWidget.prototype.update = function(current){\n", " if(current in this.cache) {\n", " $.each(this.cache, function(index, value) {\n", " value.hide();\n", " });\n", " this.cache[current].show();\n", "\t\tthis.wait = false;\n", " }\n", "}\n", "\n", "\n", "function SelectionWidget(frames, id, slider_ids, keyMap, dim_vals, notFound, load_json, mode, cached, json_path, dynamic){\n", " this.frames = frames;\n", " this.fig_id = \"fig_\" + id;\n", " this.img_id = \"_anim_img\" + id;\n", " this.id = id;\n", " this.slider_ids = slider_ids;\n", " this.keyMap = keyMap\n", " this.current_frame = 0;\n", " this.current_vals = dim_vals;\n", " this.load_json = load_json;\n", " this.mode = mode;\n", " this.notFound = notFound;\n", " this.cached = cached;\n", " this.dynamic = dynamic;\n", " this.cache = {};\n", "\tthis.json_path = json_path;\n", " this.init_slider(this.current_vals[0]);\n", "\tthis.queue = [];\n", "\tthis.wait = false;\n", "}\n", "\n", "SelectionWidget.prototype = new HoloViewsWidget;\n", "\n", "\n", "SelectionWidget.prototype.get_key = function(current_vals) {\n", "\tvar key = \"(\";\n", " for (var i=0; i<this.slider_ids.length; i++)\n", " {\n", " val = this.current_vals[i];\n", " if (!(typeof val === 'string')) {\n", " if (val % 1 === 0) { var fixed = 1;}\n", " else { var fixed = 10;}\n", " val = val.toFixed(fixed)\n", " }\n", " key += \"'\" + val + \"'\";\n", " if(i != this.slider_ids.length-1) { key += ', ';}\n", " else if(this.slider_ids.length == 1) { key += ',';}\n", " }\n", " key += \")\";\n", "\treturn this.keyMap[key];\n", "}\n", "\n", "SelectionWidget.prototype.set_frame = function(dim_val, dim_idx){\n", "\tthis.current_vals[dim_idx] = dim_val;\n", " var current = this.get_key(this.current_vals);\n", " if(current === undefined && !this.dynamic) {\n", " return\n", " }\n", "\tif (this.dynamic || !this.cached) {\n", "\t\tif (this.time === undefined) {\n", "\t\t\t// Do nothing the first time\n", "\t\t} else if ((this.timed === undefined) || ((this.time + this.timed) > Date.now())) {\n", "\t\t\tvar key = this.current_vals;\n", "\t\t\tif (!this.dynamic) {\n", "\t\t\t\tkey = this.get_key(key);\n", "\t\t\t}\n", "\t\t\tthis.queue.push(key);\n", "\t\t\treturn\n", "\t\t}\n", "\t}\n", "\tthis.queue = [];\n", "\tthis.time = Date.now();\n", " if(this.dynamic) {\n", " this.dynamic_update(this.current_vals)\n", " return;\n", " }\n", " this.current_frame = current;\n", " if(this.cached) {\n", " this.update(current)\n", " } else {\n", " this.dynamic_update(current)\n", " }\n", "}\n", "\n", "\n", "/* Define the ScrubberWidget class */\n", "function ScrubberWidget(frames, num_frames, id, interval, load_json, mode, cached, json_path, dynamic){\n", " this.img_id = \"_anim_img\" + id;\n", " this.slider_id = \"_anim_slider\" + id;\n", " this.loop_select_id = \"_anim_loop_select\" + id;\n", " this.id = id;\n", " this.fig_id = \"fig_\" + id;\n", " this.interval = interval;\n", " this.current_frame = 0;\n", " this.direction = 0;\n", " this.dynamic = dynamic;\n", " this.timer = null;\n", " this.load_json = load_json;\n", " this.mode = mode;\n", " this.cached = cached;\n", " this.frames = frames;\n", " this.cache = {};\n", " this.length = num_frames;\n", "\tthis.json_path = json_path;\n", " document.getElementById(this.slider_id).max = this.length - 1;\n", " this.init_slider(0);\n", "\tthis.wait = false;\n", "\tthis.queue = [];\n", "}\n", "\n", "ScrubberWidget.prototype = new HoloViewsWidget;\n", "\n", "ScrubberWidget.prototype.set_frame = function(frame){\n", "\tthis.current_frame = frame;\n", "\twidget = document.getElementById(this.slider_id);\n", " if (widget === null) {\n", " this.pause_animation();\n", " return\n", " }\n", " widget.value = this.current_frame;\n", " if(this.cached) {\n", " this.update(frame)\n", " } else {\n", " this.dynamic_update(frame)\n", " }\n", "}\n", "\n", "\n", "ScrubberWidget.prototype.process_error = function(msg){\n", "\tif (msg.content.ename === 'StopIteration') {\n", "\t\tthis.pause_animation();\n", "\t\tthis.stopped = true;\n", "\t\tvar keys = Object.keys(this.frames)\n", "\t\tthis.length = keys.length;\n", "\t\tdocument.getElementById(this.slider_id).max = this.length-1;\n", "\t\tdocument.getElementById(this.slider_id).value = this.length-1;\n", "\t\tthis.current_frame = this.length-1;\n", "\t}\n", "}\n", "\n", "\n", "ScrubberWidget.prototype.get_loop_state = function(){\n", " var button_group = document[this.loop_select_id].state;\n", " for (var i = 0; i < button_group.length; i++) {\n", " var button = button_group[i];\n", " if (button.checked) {\n", " return button.value;\n", " }\n", " }\n", " return undefined;\n", "}\n", "\n", "\n", "ScrubberWidget.prototype.next_frame = function() {\n", "\tif (this.dynamic || !this.cached) {\n", "\t\tif (this.wait) {\n", "\t\t\treturn\n", "\t\t}\n", "\t\tthis.wait = true;\n", "\t}\n", "\tif (this.dynamic && this.current_frame + 1 >= this.length) {\n", "\t\tthis.length += 1;\n", " document.getElementById(this.slider_id).max = this.length-1;\n", "\t}\n", " this.set_frame(Math.min(this.length - 1, this.current_frame + 1));\n", "}\n", "\n", "ScrubberWidget.prototype.previous_frame = function() {\n", " this.set_frame(Math.max(0, this.current_frame - 1));\n", "}\n", "\n", "ScrubberWidget.prototype.first_frame = function() {\n", " this.set_frame(0);\n", "}\n", "\n", "ScrubberWidget.prototype.last_frame = function() {\n", " this.set_frame(this.length - 1);\n", "}\n", "\n", "ScrubberWidget.prototype.slower = function() {\n", " this.interval /= 0.7;\n", " if(this.direction > 0){this.play_animation();}\n", " else if(this.direction < 0){this.reverse_animation();}\n", "}\n", "\n", "ScrubberWidget.prototype.faster = function() {\n", " this.interval *= 0.7;\n", " if(this.direction > 0){this.play_animation();}\n", " else if(this.direction < 0){this.reverse_animation();}\n", "}\n", "\n", "ScrubberWidget.prototype.anim_step_forward = function() {\n", " if(this.current_frame < this.length || (this.dynamic && !this.stopped)){\n", " this.next_frame();\n", " }else{\n", " var loop_state = this.get_loop_state();\n", " if(loop_state == \"loop\"){\n", " this.first_frame();\n", " }else if(loop_state == \"reflect\"){\n", " this.last_frame();\n", " this.reverse_animation();\n", " }else{\n", " this.pause_animation();\n", " this.last_frame();\n", " }\n", " }\n", "}\n", "\n", "ScrubberWidget.prototype.anim_step_reverse = function() {\n", " this.current_frame -= 1;\n", " if(this.current_frame >= 0){\n", " this.set_frame(this.current_frame);\n", " } else {\n", " var loop_state = this.get_loop_state();\n", " if(loop_state == \"loop\"){\n", " this.last_frame();\n", " }else if(loop_state == \"reflect\"){\n", " this.first_frame();\n", " this.play_animation();\n", " }else{\n", " this.pause_animation();\n", " this.first_frame();\n", " }\n", " }\n", "}\n", "\n", "ScrubberWidget.prototype.pause_animation = function() {\n", " this.direction = 0;\n", " if (this.timer){\n", " clearInterval(this.timer);\n", " this.timer = null;\n", " }\n", "}\n", "\n", "ScrubberWidget.prototype.play_animation = function() {\n", " this.pause_animation();\n", " this.direction = 1;\n", " var t = this;\n", " if (!this.timer) this.timer = setInterval(function(){t.anim_step_forward();}, this.interval);\n", "}\n", "\n", "ScrubberWidget.prototype.reverse_animation = function() {\n", " this.pause_animation();\n", " this.direction = -1;\n", " var t = this;\n", " if (!this.timer) this.timer = setInterval(function(){t.anim_step_reverse();}, this.interval);\n", "}\n", "\n", "function extend(destination, source) {\n", " for (var k in source) {\n", " if (source.hasOwnProperty(k)) {\n", " destination[k] = source[k];\n", " }\n", " }\n", " return destination;\n", "}\n", "\n", "function update_widget(widget, values) {\n", "\tif (widget.hasClass(\"ui-slider\")) {\n", "\t\twidget.slider('option',\n", "\t\t\t\t\t {'min': 0, 'max': values.length-1,\n", "\t\t\t\t\t 'dim_vals': values, 'value': 0,\n", "\t\t\t\t\t 'dim_labels': values})\n", "\t\twidget.slider('option', 'slide').call(widget, event, {'value': 0})\n", "\t} else {\n", "\t\twidget.empty();\n", "\t\tfor (var i=0; i<values.length; i++){\n", "\t\t\twidget.append($(\"<option>\", {\n", "\t\t\t\tvalue: i,\n", "\t\t\t\ttext: values[i]\n", "\t\t\t}))};\n", "\t\twidget.data('values', values);\n", "\t\twidget.data('value', 0);\n", "\t\twidget.trigger(\"change\");\n", "\t};\n", "}\n", "\n", "// Define MPL specific subclasses\n", "function MPLSelectionWidget() {\n", "\tSelectionWidget.apply(this, arguments);\n", "}\n", "\n", "function MPLScrubberWidget() {\n", "\tScrubberWidget.apply(this, arguments);\n", "}\n", "\n", "// Let them inherit from the baseclasses\n", "MPLSelectionWidget.prototype = Object.create(SelectionWidget.prototype);\n", "MPLScrubberWidget.prototype = Object.create(ScrubberWidget.prototype);\n", "\n", "// Define methods to override on widgets\n", "var MPLMethods = {\n", "\tinit_slider : function(init_val){\n", "\t\tif(this.load_json) {\n", "\t\t\tthis.from_json()\n", "\t\t} else {\n", "\t\t\tthis.update_cache();\n", "\t\t}\n", "\t\tthis.update(0);\n", "\t\tif(this.mode == 'nbagg') {\n", "\t\t\tthis.set_frame(init_val, 0);\n", "\t\t}\n", "\t},\n", "\tpopulate_cache : function(idx){\n", "\t\tvar cache_id = this.img_id+\"_\"+idx;\n", "\t\tif(this.mode == 'mpld3') {\n", "\t\t\tmpld3.draw_figure(cache_id, this.frames[idx]);\n", "\t\t} else {\n", "\t\t\tthis.cache[idx].html(this.frames[idx]);\n", "\t\t}\n", "\t\tif (this.embed) {\n", "\t\t\tdelete this.frames[idx];\n", "\t\t}\n", "\t},\n", "\tdynamic_update : function(current){\n", "\t\tif (this.dynamic) {\n", "\t\t\tcurrent = JSON.stringify(current);\n", "\t\t}\n", "\t\tfunction callback(msg){\n", "\t\t\t/* This callback receives data from Python as a string\n", "\t\t\t in order to parse it correctly quotes are sliced off*/\n", "\t\t\tif (msg.content.ename != undefined) {\n", "\t\t\t\tthis.process_error(msg);\n", "\t\t\t}\n", "\t\t\tif (msg.msg_type != \"execute_result\") {\n", "\t\t\t\tconsole.log(\"Warning: HoloViews callback returned unexpected data for key: (\", current, \") with the following content:\", msg.content)\n", "\t\t\t\tthis.time = undefined;\n", "\t\t\t\treturn\n", "\t\t\t}\n", "\t\t\tif (!(this.mode == 'nbagg')) {\n", "\t\t\t\tif(!(current in this.cache)) {\n", "\t\t\t\t\tvar data = msg.content.data['text/plain'].slice(1, -1);\n", "\t\t\t\t\tif(this.mode == 'mpld3'){\n", "\t\t\t\t\t\tdata = JSON.parse(data)[0];\n", "\t\t\t\t\t}\n", "\t\t\t\t\tthis.frames[current] = data;\n", "\t\t\t\t\tthis.update_cache();\n", "\t\t\t\t}\n", "\t\t\t\tthis.update(current);\n", "\t\t\t}\n", "\t\t\tthis.timed = (Date.now() - this.time) * 1.5;\n", "\t\t\tthis.wait = false;\n", "\t\t\tif (this.queue.length > 0) {\n", "\t\t\t\tvar current_vals = this.queue[this.queue.length-1];\n", "\t\t\t\tthis.time = Date.now();\n", "\t\t\t\tthis.dynamic_update(current_vals);\n", "\t\t\t\tthis.queue = [];\n", "\t\t\t}\n", "\t\t}\n", "\t\tvar kernel = IPython.notebook.kernel;\n", "\t\tcallbacks = {iopub: {output: $.proxy(callback, this)}};\n", "\t\tvar cmd = \"holoviews.plotting.widgets.NdWidget.widgets['\" + this.id + \"'].update(\" + current + \")\";\n", "\t\tkernel.execute(\"import holoviews;\" + cmd, callbacks, {silent : false});\n", "\t}\n", "}\n", "\n", "// Extend MPL widgets with backend specific methods\n", "extend(MPLSelectionWidget.prototype, MPLMethods);\n", "extend(MPLScrubberWidget.prototype, MPLMethods);\n", "</script>\n", "\n", "\n", "<link rel=\"stylesheet\" href=\"https://code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css\">\n", "<style>div.hololayout {\n", " display: flex;\n", " align-items: center;\n", " margin: 0;\n", "}\n", "\n", "div.holoframe {\n", "\twidth: 75%;\n", "}\n", "\n", "div.holowell {\n", " display: flex;\n", " align-items: center;\n", " margin: 0;\n", "}\n", "\n", "form.holoform {\n", " background-color: #fafafa;\n", " border-radius: 5px;\n", " overflow: hidden;\n", "\tpadding-left: 0.8em;\n", " padding-right: 0.8em;\n", " padding-top: 0.4em;\n", " padding-bottom: 0.4em;\n", "}\n", "\n", "div.holowidgets {\n", " padding-right: 0;\n", "\twidth: 25%;\n", "}\n", "\n", "div.holoslider {\n", " min-height: 0 !important;\n", " height: 0.8em;\n", " width: 60%;\n", "}\n", "\n", "div.holoformgroup {\n", " padding-top: 0.5em;\n", " margin-bottom: 0.5em;\n", "}\n", "\n", "div.hologroup {\n", " padding-left: 0;\n", " padding-right: 0.8em;\n", " width: 50%;\n", "}\n", "\n", ".holoselect {\n", " width: 92%;\n", " margin-left: 0;\n", " margin-right: 0;\n", "}\n", "\n", ".holotext {\n", " width: 100%;\n", " padding-left: 0.5em;\n", " padding-right: 0;\n", "}\n", "\n", ".holowidgets .ui-resizable-se {\n", "\tvisibility: hidden\n", "}\n", "\n", ".holoframe > .ui-resizable-se {\n", "\tvisibility: hidden\n", "}\n", "\n", ".holowidgets .ui-resizable-s {\n", "\tvisibility: hidden\n", "}\n", "</style>\n", "\n", "\n", "<div>\n", "<img src=''\n", " style='width:25px;height:25px; border-radius:12px;'/>\n", "\n", "HoloViewsJS successfully loaded in this cell.\n", "</div>\n" ], "text/plain": [ "<IPython.core.display.HTML object>" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "import numpy as np\n", "from types import SimpleNamespace\n", "import scipy.linalg as la\n", "import holoviews as hv\n", "\n", "hv.notebook_extension()" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# mgrid" ] }, { "cell_type": "code", "execution_count": 2, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/html": [ "<img src='' style='max-width:100%; margin: auto; display: block; '/>" ], "text/plain": [ ":Layout\n", " .Raster.I :Raster [x,y] (z)\n", " .Raster.II :Raster [x,y] (z)" ] }, "execution_count": 2, "metadata": {}, "output_type": "execute_result" } ], "source": [ "%%opts Raster (cmap='viridis' interpolation='sinc') [colorbar=True]\n", "N = 4\n", "\n", "x, y = np.mgrid[-N:N+1, -N:N+1]\n", "hv.Raster(np.rot90(x)) + hv.Raster(np.rot90(y))" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "# wave function from kwant" ] }, { "cell_type": "code", "execution_count": 4, "metadata": { "collapsed": true }, "outputs": [], "source": [ "import kwant\n", "from kwant.continuum import discretize" ] }, { "cell_type": "code", "execution_count": 5, "metadata": { "collapsed": false }, "outputs": [], "source": [ "tb = discretize('k_x**2 + k_y**2 + Vx * x + Vy * y')" ] }, { "cell_type": "code", "execution_count": 6, "metadata": { "collapsed": false }, "outputs": [], "source": [ "syst = kwant.Builder()\n", "shape = lambda s: -20 < s.pos[0] < 20 and -10 < s.pos[1] < 10\n", "syst.fill(tb, shape, (0, 0));\n", "\n", "syst = syst.finalized()\n", "\n", "pars = SimpleNamespace(Vx=.03, Vy=0.05)\n", "ev, evec = la.eigh(syst.hamiltonian_submatrix(args=[pars]))" ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "collapsed": false }, "outputs": [ { "data": { "image/png": "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\n", "text/plain": [ "<matplotlib.figure.Figure at 0x7fa7b75a1cf8>" ] }, "execution_count": 7, "metadata": {}, "output_type": "execute_result" } ], "source": [ "wf = np.abs(evec[:, 0])**2\n", "kwant.plotter.map(syst, wf)" ] }, { "cell_type": "code", "execution_count": 8, "metadata": { "collapsed": false }, "outputs": [], "source": [ "coords = np.array([s.pos for s in syst.sites])\n", "wf = kwant.plotter.mask_interpolate(coords, wf)[0]" ] }, { "cell_type": "code", "execution_count": 9, "metadata": { "collapsed": false }, "outputs": [ { "data": { "text/html": [ "<img src='' style='max-width:100%; margin: auto; display: block; '/>" ], "text/plain": [ "b':Raster [x,y] (z)'" ] }, "execution_count": 9, "metadata": {}, "output_type": "execute_result" } ], "source": [ "%%opts Raster (cmap='viridis' interpolation='sinc') [colorbar=True]\n", "\n", "hv.Raster(np.rot90(wf))" ] } ], "metadata": { "anaconda-cloud": {}, "kernelspec": { "display_name": "Python [conda env:kwant]", "language": "python", "name": "conda-env-kwant-py" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.5.3" } }, "nbformat": 4, "nbformat_minor": 1 }