Show More
This diff has been collapsed as it changes many lines, (708 lines changed) Show them Hide them | |||||
@@ -1,7 +1,7 b'' | |||||
1 | { |
|
1 | { | |
2 | "metadata": { |
|
2 | "metadata": { | |
3 | "name": "", |
|
3 | "name": "", | |
4 | "signature": "sha256:3f30c6e839ac39f890da34a2af6bf50bf0d99ea32f7aadc043f3e31f619e4bc9" |
|
4 | "signature": "sha256:6d8c7c51322c4911e478068e8fa8e897bd72c614096f5df110ed86d01d66001c" | |
5 | }, |
|
5 | }, | |
6 | "nbformat": 3, |
|
6 | "nbformat": 3, | |
7 | "nbformat_minor": 0, |
|
7 | "nbformat_minor": 0, | |
@@ -13,14 +13,14 b'' | |||||
13 | "level": 1, |
|
13 | "level": 1, | |
14 | "metadata": {}, |
|
14 | "metadata": {}, | |
15 | "source": [ |
|
15 | "source": [ | |
16 | "Interact" |
|
16 | "Using Interact" | |
17 | ] |
|
17 | ] | |
18 | }, |
|
18 | }, | |
19 | { |
|
19 | { | |
20 | "cell_type": "markdown", |
|
20 | "cell_type": "markdown", | |
21 | "metadata": {}, |
|
21 | "metadata": {}, | |
22 | "source": [ |
|
22 | "source": [ | |
23 | "The `interact` function provides a high-level interface for creating user interface controls to use in exploring code and data interactively." |
|
23 | "The `interact` function (`IPython.html.widgets.interact`) automatically creates user interface (UI) controls for exploring code and data interactively. It is the easiest way to get started using IPython's widgets." | |
24 | ] |
|
24 | ] | |
25 | }, |
|
25 | }, | |
26 | { |
|
26 | { | |
@@ -28,8 +28,7 b'' | |||||
28 | "collapsed": false, |
|
28 | "collapsed": false, | |
29 | "input": [ |
|
29 | "input": [ | |
30 | "from IPython.html.widgets import interact, interactive, fixed\n", |
|
30 | "from IPython.html.widgets import interact, interactive, fixed\n", | |
31 |
"from IPython.html import widgets |
|
31 | "from IPython.html import widgets" | |
32 | "from IPython.display import clear_output, display, HTML" |
|
|||
33 | ], |
|
32 | ], | |
34 | "language": "python", |
|
33 | "language": "python", | |
35 | "metadata": {}, |
|
34 | "metadata": {}, | |
@@ -37,30 +36,35 b'' | |||||
37 | "prompt_number": 1 |
|
36 | "prompt_number": 1 | |
38 | }, |
|
37 | }, | |
39 | { |
|
38 | { | |
|
39 | "cell_type": "markdown", | |||
|
40 | "metadata": {}, | |||
|
41 | "source": [ | |||
|
42 | "<div class=\"alert alert-success\">\n", | |||
|
43 | "As of IPython 2.0, the widgets in this notebook won't show up on http://nbviewer.ipython.org. To view the widgets and interact with them, you will need to download this notebook and run it with an IPython Notebook server.\n", | |||
|
44 | "</div>" | |||
|
45 | ] | |||
|
46 | }, | |||
|
47 | { | |||
40 | "cell_type": "heading", |
|
48 | "cell_type": "heading", | |
41 | "level": 2, |
|
49 | "level": 2, | |
42 | "metadata": {}, |
|
50 | "metadata": {}, | |
43 | "source": [ |
|
51 | "source": [ | |
44 | "Basic interact" |
|
52 | "Basic `interact`" | |
45 | ] |
|
53 | ] | |
46 | }, |
|
54 | }, | |
47 | { |
|
55 | { | |
48 | "cell_type": "markdown", |
|
56 | "cell_type": "markdown", | |
49 | "metadata": {}, |
|
57 | "metadata": {}, | |
50 | "source": [ |
|
58 | "source": [ | |
51 | "Here is a simple function that displays its arguments as an HTML table:" |
|
59 | "At the most basic level, `interact` autogenerates UI controls for function arguments, and then calls the function with those arguments when you manipulate the controls interactively. To use `interact`, you need to define a function that you want to explore. Here is a function that prints its only argument `x`." | |
52 | ] |
|
60 | ] | |
53 | }, |
|
61 | }, | |
54 | { |
|
62 | { | |
55 | "cell_type": "code", |
|
63 | "cell_type": "code", | |
56 | "collapsed": false, |
|
64 | "collapsed": false, | |
57 | "input": [ |
|
65 | "input": [ | |
58 |
"def |
|
66 | "def f(x):\n", | |
59 | " s = '<h3>Arguments:</h3><table>\\n'\n", |
|
67 | " print x" | |
60 | " for k,v in kwargs.items():\n", |
|
|||
61 | " s += '<tr><td>{0}</td><td>{1}</td></tr>\\n'.format(k,v)\n", |
|
|||
62 | " s += '</table>'\n", |
|
|||
63 | " display(HTML(s))" |
|
|||
64 | ], |
|
68 | ], | |
65 | "language": "python", |
|
69 | "language": "python", | |
66 | "metadata": {}, |
|
70 | "metadata": {}, | |
@@ -68,100 +72,696 b'' | |||||
68 | "prompt_number": 2 |
|
72 | "prompt_number": 2 | |
69 | }, |
|
73 | }, | |
70 | { |
|
74 | { | |
|
75 | "cell_type": "markdown", | |||
|
76 | "metadata": {}, | |||
|
77 | "source": [ | |||
|
78 | "When you pass this function as the first argument to `interact` along with an integer keyword argument (`x=10`), a slider is generated and bound to the function." | |||
|
79 | ] | |||
|
80 | }, | |||
|
81 | { | |||
71 | "cell_type": "code", |
|
82 | "cell_type": "code", | |
72 | "collapsed": false, |
|
83 | "collapsed": false, | |
73 | "input": [ |
|
84 | "input": [ | |
74 | "show_args(a=10, b='Hi There', c=True)" |
|
85 | "interact(f, x=10);" | |
75 | ], |
|
86 | ], | |
76 | "language": "python", |
|
87 | "language": "python", | |
77 | "metadata": {}, |
|
88 | "metadata": {}, | |
78 | "outputs": [ |
|
89 | "outputs": [ | |
79 | { |
|
90 | { | |
80 | "html": [ |
|
91 | "output_type": "stream", | |
81 | "<h3>Arguments:</h3><table>\n", |
|
92 | "stream": "stdout", | |
82 | "<tr><td>a</td><td>10</td></tr>\n", |
|
93 | "text": [ | |
83 | "<tr><td>c</td><td>True</td></tr>\n", |
|
94 | "9\n" | |
84 | "<tr><td>b</td><td>Hi There</td></tr>\n", |
|
95 | ] | |
85 | "</table>" |
|
96 | } | |
86 |
|
|
97 | ], | |
|
98 | "prompt_number": 3 | |||
|
99 | }, | |||
|
100 | { | |||
|
101 | "cell_type": "markdown", | |||
|
102 | "metadata": {}, | |||
|
103 | "source": [ | |||
|
104 | "When you move the slider, the function is called and the current value of `x` is printed.\n", | |||
|
105 | "\n", | |||
|
106 | "If you pass `True` or `False`, `interact` will generate a checkbox:" | |||
|
107 | ] | |||
|
108 | }, | |||
|
109 | { | |||
|
110 | "cell_type": "code", | |||
|
111 | "collapsed": false, | |||
|
112 | "input": [ | |||
|
113 | "interact(f, x=True);" | |||
|
114 | ], | |||
|
115 | "language": "python", | |||
87 |
|
|
116 | "metadata": {}, | |
88 | "output_type": "display_data", |
|
117 | "outputs": [ | |
|
118 | { | |||
|
119 | "output_type": "stream", | |||
|
120 | "stream": "stdout", | |||
89 | "text": [ |
|
121 | "text": [ | |
90 | "<IPython.core.display.HTML object>" |
|
122 | "True\n" | |
91 | ] |
|
123 | ] | |
92 | } |
|
124 | } | |
93 | ], |
|
125 | ], | |
94 |
"prompt_number": |
|
126 | "prompt_number": 4 | |
95 | }, |
|
127 | }, | |
96 | { |
|
128 | { | |
97 | "cell_type": "markdown", |
|
129 | "cell_type": "markdown", | |
98 | "metadata": {}, |
|
130 | "metadata": {}, | |
99 | "source": [ |
|
131 | "source": [ | |
100 | "Let's use this function to explore how `interact` works." |
|
132 | "If you pass a string, `interact` will generate a text area." | |
101 | ] |
|
133 | ] | |
102 | }, |
|
134 | }, | |
103 | { |
|
135 | { | |
104 | "cell_type": "code", |
|
136 | "cell_type": "code", | |
105 | "collapsed": false, |
|
137 | "collapsed": false, | |
106 | "input": [ |
|
138 | "input": [ | |
107 | "i = interact(show_args,\n", |
|
139 | "interact(f, x='Hi there!');" | |
108 | " Temp=(0,10),\n", |
|
|||
109 | " Current=(0.,10.,0.01),\n", |
|
|||
110 | " z=True,\n", |
|
|||
111 | " Text=u'Type here!',\n", |
|
|||
112 | " #Algorithm=['This','That','Other'],\n", |
|
|||
113 | " a=widgets.FloatSliderWidget(min=-10.0, max=10.0, step=0.1, value=5.0, description=\"Float (a)\")\n", |
|
|||
114 | " )" |
|
|||
115 | ], |
|
140 | ], | |
116 | "language": "python", |
|
141 | "language": "python", | |
117 | "metadata": {}, |
|
142 | "metadata": {}, | |
118 | "outputs": [ |
|
143 | "outputs": [ | |
119 | { |
|
144 | { | |
120 | "html": [ |
|
145 | "output_type": "stream", | |
121 | "<h3>Arguments:</h3><table>\n", |
|
146 | "stream": "stdout", | |
122 | "<tr><td>Current</td><td>4.99</td></tr>\n", |
|
147 | "text": [ | |
123 | "<tr><td>Text</td><td>Type here!</td></tr>\n", |
|
148 | "Hi there!\n" | |
124 | "<tr><td>z</td><td>True</td></tr>\n", |
|
149 | ] | |
125 | "<tr><td>Temp</td><td>5</td></tr>\n", |
|
150 | } | |
126 | "<tr><td>Float (a)</td><td>5.0</td></tr>\n", |
|
151 | ], | |
127 | "</table>" |
|
152 | "prompt_number": 5 | |
|
153 | }, | |||
|
154 | { | |||
|
155 | "cell_type": "markdown", | |||
|
156 | "metadata": {}, | |||
|
157 | "source": [ | |||
|
158 | "`interact` can also be used as a decorator. This allows you to define a function and interact with it in a single shot. As this example shows, `interact` also works with functions that have multiple arguments." | |||
|
159 | ] | |||
|
160 | }, | |||
|
161 | { | |||
|
162 | "cell_type": "code", | |||
|
163 | "collapsed": false, | |||
|
164 | "input": [ | |||
|
165 | "@interact(x=True, y=1.0)\n", | |||
|
166 | "def g(x, y):\n", | |||
|
167 | " print x, y" | |||
128 |
|
|
168 | ], | |
|
169 | "language": "python", | |||
129 |
|
|
170 | "metadata": {}, | |
130 | "output_type": "display_data", |
|
171 | "outputs": [ | |
|
172 | { | |||
|
173 | "output_type": "stream", | |||
|
174 | "stream": "stdout", | |||
131 | "text": [ |
|
175 | "text": [ | |
132 | "<IPython.core.display.HTML object>" |
|
176 | "True 1.0\n" | |
133 | ] |
|
177 | ] | |
134 | } |
|
178 | } | |
135 | ], |
|
179 | ], | |
136 |
"prompt_number": |
|
180 | "prompt_number": 6 | |
|
181 | }, | |||
|
182 | { | |||
|
183 | "cell_type": "heading", | |||
|
184 | "level": 2, | |||
|
185 | "metadata": {}, | |||
|
186 | "source": [ | |||
|
187 | "Fixing arguments using `fixed`" | |||
|
188 | ] | |||
|
189 | }, | |||
|
190 | { | |||
|
191 | "cell_type": "markdown", | |||
|
192 | "metadata": {}, | |||
|
193 | "source": [ | |||
|
194 | "There are times when you may want to explore a function using `interact`, but fix one or more of its arguments to specific values. This can be accomplished by wrapping values with the `fixed` function." | |||
|
195 | ] | |||
|
196 | }, | |||
|
197 | { | |||
|
198 | "cell_type": "code", | |||
|
199 | "collapsed": false, | |||
|
200 | "input": [ | |||
|
201 | "def h(p, q):\n", | |||
|
202 | " print p, q" | |||
|
203 | ], | |||
|
204 | "language": "python", | |||
|
205 | "metadata": {}, | |||
|
206 | "outputs": [], | |||
|
207 | "prompt_number": 7 | |||
|
208 | }, | |||
|
209 | { | |||
|
210 | "cell_type": "markdown", | |||
|
211 | "metadata": {}, | |||
|
212 | "source": [ | |||
|
213 | "When we call `interact`, we pass `fixed(20)` for q to hold it fixed at a value of `20`." | |||
|
214 | ] | |||
137 | }, |
|
215 | }, | |
138 | { |
|
216 | { | |
139 | "cell_type": "code", |
|
217 | "cell_type": "code", | |
140 | "collapsed": false, |
|
218 | "collapsed": false, | |
141 | "input": [ |
|
219 | "input": [ | |
142 | "i.widget" |
|
220 | "interact(h, p=5, q=fixed(20));" | |
143 | ], |
|
221 | ], | |
144 | "language": "python", |
|
222 | "language": "python", | |
145 | "metadata": {}, |
|
223 | "metadata": {}, | |
146 | "outputs": [ |
|
224 | "outputs": [ | |
147 | { |
|
225 | { | |
148 | "html": [ |
|
226 | "output_type": "stream", | |
149 | "<h3>Arguments:</h3><table>\n", |
|
227 | "stream": "stdout", | |
150 | "<tr><td>Current</td><td>4.99</td></tr>\n", |
|
228 | "text": [ | |
151 | "<tr><td>Text</td><td>Type here!</td></tr>\n", |
|
229 | "5 20\n" | |
152 | "<tr><td>z</td><td>True</td></tr>\n", |
|
230 | ] | |
153 | "<tr><td>Temp</td><td>5</td></tr>\n", |
|
231 | } | |
154 | "<tr><td>Float (a)</td><td>5.0</td></tr>\n", |
|
232 | ], | |
|
233 | "prompt_number": 8 | |||
|
234 | }, | |||
|
235 | { | |||
|
236 | "cell_type": "markdown", | |||
|
237 | "metadata": {}, | |||
|
238 | "source": [ | |||
|
239 | "Notice that a slider is only produced for `p` as the value of `q` is fixed." | |||
|
240 | ] | |||
|
241 | }, | |||
|
242 | { | |||
|
243 | "cell_type": "heading", | |||
|
244 | "level": 2, | |||
|
245 | "metadata": {}, | |||
|
246 | "source": [ | |||
|
247 | "Widget abbreviations" | |||
|
248 | ] | |||
|
249 | }, | |||
|
250 | { | |||
|
251 | "cell_type": "markdown", | |||
|
252 | "metadata": {}, | |||
|
253 | "source": [ | |||
|
254 | "When you pass an integer valued keyword argument (`x=10`) to `interact`, it generates an integer valued slider control with a range of $[-10,+3\\times10]$. In this case `10` is an *abbreviation* for an actual slider widget:\n", | |||
|
255 | "\n", | |||
|
256 | "```python\n", | |||
|
257 | "IntSliderWidget(min=-10,max=30,step=1,value=10)\n", | |||
|
258 | "```\n", | |||
|
259 | "\n", | |||
|
260 | "In fact, we can get the same result if we pass this `IntSliderWidget` as the keyword argument for `x`:" | |||
|
261 | ] | |||
|
262 | }, | |||
|
263 | { | |||
|
264 | "cell_type": "code", | |||
|
265 | "collapsed": false, | |||
|
266 | "input": [ | |||
|
267 | "interact(f, x=widgets.IntSliderWidget(min=-10,max=30,step=1,value=10));" | |||
|
268 | ], | |||
|
269 | "language": "python", | |||
|
270 | "metadata": {}, | |||
|
271 | "outputs": [ | |||
|
272 | { | |||
|
273 | "output_type": "stream", | |||
|
274 | "stream": "stdout", | |||
|
275 | "text": [ | |||
|
276 | "10\n" | |||
|
277 | ] | |||
|
278 | } | |||
|
279 | ], | |||
|
280 | "prompt_number": 9 | |||
|
281 | }, | |||
|
282 | { | |||
|
283 | "cell_type": "markdown", | |||
|
284 | "metadata": {}, | |||
|
285 | "source": [ | |||
|
286 | "This examples clarifies how `interact` proceses its keyword arguments:\n", | |||
|
287 | "\n", | |||
|
288 | "1. If the keyword argument is `Widget` instance with a `value` attribute, that widget is used. Any widget with a `value` attribute can be used, even custom ones.\n", | |||
|
289 | "2. Otherwise, the value is treated as a *widget abbreviation* that is converted to a widget before it is used.\n", | |||
|
290 | "\n", | |||
|
291 | "The following table gives an overview of different widget abbreviations:\n", | |||
|
292 | "\n", | |||
|
293 | "<table class=\"table table-condensed table-bordered\">\n", | |||
|
294 | " <tr><td><strong>Keyword argument</strong></td><td><strong>Widget</strong></td></tr> \n", | |||
|
295 | " <tr><td>`True` or `False`</td><td>CheckboxWiget</td></tr> \n", | |||
|
296 | " <tr><td>`'Hi there'`</td><td>TextareaWidget</td></tr>\n", | |||
|
297 | " <tr><td>`value` or `(min,max)` or `(min,max,step)` if integers are passed</td><td>IntSliderWidget</td></tr>\n", | |||
|
298 | " <tr><td>`value` or `(min,max)` or `(min,max,step)` if floats are passed</td><td>FloatSliderWidget</td></tr>\n", | |||
|
299 | " <tr><td>`('orange','apple')` or `{'one':1,'two':2}`</td><td>DropdownWidget</td></tr>\n", | |||
155 |
|
|
300 | "</table>" | |
|
301 | ] | |||
|
302 | }, | |||
|
303 | { | |||
|
304 | "cell_type": "markdown", | |||
|
305 | "metadata": {}, | |||
|
306 | "source": [ | |||
|
307 | "You have seen how the checkbox and textarea widgets work above. Here, more details about the different abbreviations for sliders and dropdowns are given.\n", | |||
|
308 | "\n", | |||
|
309 | "If a 2-tuple of integers is passed `(min,max)` a integer valued slider is produced with those minimum and maximum (inclusive) values. In this case, the default step size of `1` is used." | |||
|
310 | ] | |||
|
311 | }, | |||
|
312 | { | |||
|
313 | "cell_type": "code", | |||
|
314 | "collapsed": false, | |||
|
315 | "input": [ | |||
|
316 | "interact(f, x=(0,4));" | |||
156 |
|
|
317 | ], | |
|
318 | "language": "python", | |||
157 |
|
|
319 | "metadata": {}, | |
158 | "output_type": "display_data", |
|
320 | "outputs": [ | |
|
321 | { | |||
|
322 | "output_type": "stream", | |||
|
323 | "stream": "stdout", | |||
159 | "text": [ |
|
324 | "text": [ | |
160 | "<IPython.core.display.HTML object>" |
|
325 | "2\n" | |
161 | ] |
|
326 | ] | |
162 | } |
|
327 | } | |
163 | ], |
|
328 | ], | |
164 |
"prompt_number": |
|
329 | "prompt_number": 10 | |
|
330 | }, | |||
|
331 | { | |||
|
332 | "cell_type": "markdown", | |||
|
333 | "metadata": {}, | |||
|
334 | "source": [ | |||
|
335 | "If a 3-tuple of integers is passed `(min,max,step)` the step size can also be set." | |||
|
336 | ] | |||
|
337 | }, | |||
|
338 | { | |||
|
339 | "cell_type": "code", | |||
|
340 | "collapsed": false, | |||
|
341 | "input": [ | |||
|
342 | "interact(f, x=(0,8,2));" | |||
|
343 | ], | |||
|
344 | "language": "python", | |||
|
345 | "metadata": {}, | |||
|
346 | "outputs": [ | |||
|
347 | { | |||
|
348 | "output_type": "stream", | |||
|
349 | "stream": "stdout", | |||
|
350 | "text": [ | |||
|
351 | "4\n" | |||
|
352 | ] | |||
|
353 | } | |||
|
354 | ], | |||
|
355 | "prompt_number": 11 | |||
|
356 | }, | |||
|
357 | { | |||
|
358 | "cell_type": "markdown", | |||
|
359 | "metadata": {}, | |||
|
360 | "source": [ | |||
|
361 | "A float valued slider is produced if the elements of the tuples are floats. Here the minimum is `0.0`, the maximum is `10.0` and step size is `0.1` (the default)." | |||
|
362 | ] | |||
|
363 | }, | |||
|
364 | { | |||
|
365 | "cell_type": "code", | |||
|
366 | "collapsed": false, | |||
|
367 | "input": [ | |||
|
368 | "interact(f, x=(0.0,10.0));" | |||
|
369 | ], | |||
|
370 | "language": "python", | |||
|
371 | "metadata": {}, | |||
|
372 | "outputs": [ | |||
|
373 | { | |||
|
374 | "output_type": "stream", | |||
|
375 | "stream": "stdout", | |||
|
376 | "text": [ | |||
|
377 | "5.0\n" | |||
|
378 | ] | |||
|
379 | } | |||
|
380 | ], | |||
|
381 | "prompt_number": 12 | |||
|
382 | }, | |||
|
383 | { | |||
|
384 | "cell_type": "markdown", | |||
|
385 | "metadata": {}, | |||
|
386 | "source": [ | |||
|
387 | "The step size can be changed by passing a 3rd element in the tuple." | |||
|
388 | ] | |||
|
389 | }, | |||
|
390 | { | |||
|
391 | "cell_type": "code", | |||
|
392 | "collapsed": false, | |||
|
393 | "input": [ | |||
|
394 | "interact(f, x=(0.0,10.0,0.01));" | |||
|
395 | ], | |||
|
396 | "language": "python", | |||
|
397 | "metadata": {}, | |||
|
398 | "outputs": [ | |||
|
399 | { | |||
|
400 | "output_type": "stream", | |||
|
401 | "stream": "stdout", | |||
|
402 | "text": [ | |||
|
403 | "4.99\n" | |||
|
404 | ] | |||
|
405 | } | |||
|
406 | ], | |||
|
407 | "prompt_number": 13 | |||
|
408 | }, | |||
|
409 | { | |||
|
410 | "cell_type": "markdown", | |||
|
411 | "metadata": {}, | |||
|
412 | "source": [ | |||
|
413 | "For both integer and float valued sliders, you can pick the initial value of the widget by passing a default keyword argument to the underlying Python function. Here we set the initial value of a float slider to `5.5`." | |||
|
414 | ] | |||
|
415 | }, | |||
|
416 | { | |||
|
417 | "cell_type": "code", | |||
|
418 | "collapsed": false, | |||
|
419 | "input": [ | |||
|
420 | "@interact(x=(0.0,20.0,0.5))\n", | |||
|
421 | "def h(x=5.5):\n", | |||
|
422 | " print x" | |||
|
423 | ], | |||
|
424 | "language": "python", | |||
|
425 | "metadata": {}, | |||
|
426 | "outputs": [ | |||
|
427 | { | |||
|
428 | "output_type": "stream", | |||
|
429 | "stream": "stdout", | |||
|
430 | "text": [ | |||
|
431 | "5.5\n" | |||
|
432 | ] | |||
|
433 | } | |||
|
434 | ], | |||
|
435 | "prompt_number": 14 | |||
|
436 | }, | |||
|
437 | { | |||
|
438 | "cell_type": "markdown", | |||
|
439 | "metadata": {}, | |||
|
440 | "source": [ | |||
|
441 | "Dropdown menus can be produced by passing a tuple of strings. In this case, the strings are both used as the names in the dropdown menu UI and passed to the underlying Python function." | |||
|
442 | ] | |||
|
443 | }, | |||
|
444 | { | |||
|
445 | "cell_type": "code", | |||
|
446 | "collapsed": false, | |||
|
447 | "input": [ | |||
|
448 | "interact(f, x=('apples','oranges'));" | |||
|
449 | ], | |||
|
450 | "language": "python", | |||
|
451 | "metadata": {}, | |||
|
452 | "outputs": [ | |||
|
453 | { | |||
|
454 | "output_type": "stream", | |||
|
455 | "stream": "stdout", | |||
|
456 | "text": [ | |||
|
457 | "apples\n" | |||
|
458 | ] | |||
|
459 | } | |||
|
460 | ], | |||
|
461 | "prompt_number": 15 | |||
|
462 | }, | |||
|
463 | { | |||
|
464 | "cell_type": "markdown", | |||
|
465 | "metadata": {}, | |||
|
466 | "source": [ | |||
|
467 | "If you want a dropdown menu that passes non-string values to the Python function, you can pass a dictionary. The keys in the dictionary are used for the names in the dropdown menu UI and the values are the arguments that are passed to the underlying Python function." | |||
|
468 | ] | |||
|
469 | }, | |||
|
470 | { | |||
|
471 | "cell_type": "code", | |||
|
472 | "collapsed": false, | |||
|
473 | "input": [ | |||
|
474 | "interact(f, x={'one': 10, 'two': 20});" | |||
|
475 | ], | |||
|
476 | "language": "python", | |||
|
477 | "metadata": {}, | |||
|
478 | "outputs": [ | |||
|
479 | { | |||
|
480 | "output_type": "stream", | |||
|
481 | "stream": "stdout", | |||
|
482 | "text": [ | |||
|
483 | "20\n" | |||
|
484 | ] | |||
|
485 | } | |||
|
486 | ], | |||
|
487 | "prompt_number": 16 | |||
|
488 | }, | |||
|
489 | { | |||
|
490 | "cell_type": "heading", | |||
|
491 | "level": 2, | |||
|
492 | "metadata": {}, | |||
|
493 | "source": [ | |||
|
494 | "Using function annotations with `interact`" | |||
|
495 | ] | |||
|
496 | }, | |||
|
497 | { | |||
|
498 | "cell_type": "markdown", | |||
|
499 | "metadata": {}, | |||
|
500 | "source": [ | |||
|
501 | "If you are using Python 3, you can also specify widget abbreviations using [function annotations](https://docs.python.org/3/tutorial/controlflow.html#function-annotations). This is a convenient approach allows the widget abbreviations to be defined with a function.\n", | |||
|
502 | "\n", | |||
|
503 | "Define a function with an checkbox widget abbreviation for the argument `x`." | |||
|
504 | ] | |||
|
505 | }, | |||
|
506 | { | |||
|
507 | "cell_type": "code", | |||
|
508 | "collapsed": false, | |||
|
509 | "input": [ | |||
|
510 | "def f(x:True):\n", | |||
|
511 | " print x" | |||
|
512 | ], | |||
|
513 | "language": "python", | |||
|
514 | "metadata": {}, | |||
|
515 | "outputs": [] | |||
|
516 | }, | |||
|
517 | { | |||
|
518 | "cell_type": "markdown", | |||
|
519 | "metadata": {}, | |||
|
520 | "source": [ | |||
|
521 | "Then, because the widget abbreviation has already been defined, you can call `interact` with a single argument." | |||
|
522 | ] | |||
|
523 | }, | |||
|
524 | { | |||
|
525 | "cell_type": "code", | |||
|
526 | "collapsed": false, | |||
|
527 | "input": [ | |||
|
528 | "interact(f);" | |||
|
529 | ], | |||
|
530 | "language": "python", | |||
|
531 | "metadata": {}, | |||
|
532 | "outputs": [] | |||
|
533 | }, | |||
|
534 | { | |||
|
535 | "cell_type": "markdown", | |||
|
536 | "metadata": {}, | |||
|
537 | "source": [ | |||
|
538 | "If you are running Python 2, function annotations can be defined using the `@annotate` function." | |||
|
539 | ] | |||
|
540 | }, | |||
|
541 | { | |||
|
542 | "cell_type": "code", | |||
|
543 | "collapsed": false, | |||
|
544 | "input": [ | |||
|
545 | "from IPython.utils.py3compat import annotate" | |||
|
546 | ], | |||
|
547 | "language": "python", | |||
|
548 | "metadata": {}, | |||
|
549 | "outputs": [], | |||
|
550 | "prompt_number": 50 | |||
|
551 | }, | |||
|
552 | { | |||
|
553 | "cell_type": "code", | |||
|
554 | "collapsed": false, | |||
|
555 | "input": [ | |||
|
556 | "@annotate(x=True)\n", | |||
|
557 | "def f(x):\n", | |||
|
558 | " print x" | |||
|
559 | ], | |||
|
560 | "language": "python", | |||
|
561 | "metadata": {}, | |||
|
562 | "outputs": [], | |||
|
563 | "prompt_number": 51 | |||
|
564 | }, | |||
|
565 | { | |||
|
566 | "cell_type": "code", | |||
|
567 | "collapsed": false, | |||
|
568 | "input": [ | |||
|
569 | "interact(f);" | |||
|
570 | ], | |||
|
571 | "language": "python", | |||
|
572 | "metadata": {}, | |||
|
573 | "outputs": [ | |||
|
574 | { | |||
|
575 | "output_type": "stream", | |||
|
576 | "stream": "stdout", | |||
|
577 | "text": [ | |||
|
578 | "True\n" | |||
|
579 | ] | |||
|
580 | } | |||
|
581 | ], | |||
|
582 | "prompt_number": 52 | |||
|
583 | }, | |||
|
584 | { | |||
|
585 | "cell_type": "heading", | |||
|
586 | "level": 2, | |||
|
587 | "metadata": {}, | |||
|
588 | "source": [ | |||
|
589 | "`interactive`" | |||
|
590 | ] | |||
|
591 | }, | |||
|
592 | { | |||
|
593 | "cell_type": "markdown", | |||
|
594 | "metadata": {}, | |||
|
595 | "source": [ | |||
|
596 | "In addition to `interact` IPython provides another function, `interactive`, that is useful when you want to reuse the widget that are produced or access the data that is bound to the UI controls." | |||
|
597 | ] | |||
|
598 | }, | |||
|
599 | { | |||
|
600 | "cell_type": "markdown", | |||
|
601 | "metadata": {}, | |||
|
602 | "source": [ | |||
|
603 | "Here is a function that returns the sum of its two arguments." | |||
|
604 | ] | |||
|
605 | }, | |||
|
606 | { | |||
|
607 | "cell_type": "code", | |||
|
608 | "collapsed": false, | |||
|
609 | "input": [ | |||
|
610 | "def f(a, b):\n", | |||
|
611 | " return a+b" | |||
|
612 | ], | |||
|
613 | "language": "python", | |||
|
614 | "metadata": {}, | |||
|
615 | "outputs": [], | |||
|
616 | "prompt_number": 18 | |||
|
617 | }, | |||
|
618 | { | |||
|
619 | "cell_type": "markdown", | |||
|
620 | "metadata": {}, | |||
|
621 | "source": [ | |||
|
622 | "Unlike `interact`, `interactive` returns a `Widget` instance rather than immediately displaying the widget." | |||
|
623 | ] | |||
|
624 | }, | |||
|
625 | { | |||
|
626 | "cell_type": "code", | |||
|
627 | "collapsed": false, | |||
|
628 | "input": [ | |||
|
629 | "w = interactive(f, a=10, b=20)" | |||
|
630 | ], | |||
|
631 | "language": "python", | |||
|
632 | "metadata": {}, | |||
|
633 | "outputs": [], | |||
|
634 | "prompt_number": 19 | |||
|
635 | }, | |||
|
636 | { | |||
|
637 | "cell_type": "markdown", | |||
|
638 | "metadata": {}, | |||
|
639 | "source": [ | |||
|
640 | "The widget is a `ContainerWidget`, which is a container for other widgets." | |||
|
641 | ] | |||
|
642 | }, | |||
|
643 | { | |||
|
644 | "cell_type": "code", | |||
|
645 | "collapsed": false, | |||
|
646 | "input": [ | |||
|
647 | "type(w)" | |||
|
648 | ], | |||
|
649 | "language": "python", | |||
|
650 | "metadata": {}, | |||
|
651 | "outputs": [ | |||
|
652 | { | |||
|
653 | "metadata": {}, | |||
|
654 | "output_type": "pyout", | |||
|
655 | "prompt_number": 20, | |||
|
656 | "text": [ | |||
|
657 | "IPython.html.widgets.widget_container.ContainerWidget" | |||
|
658 | ] | |||
|
659 | } | |||
|
660 | ], | |||
|
661 | "prompt_number": 20 | |||
|
662 | }, | |||
|
663 | { | |||
|
664 | "cell_type": "markdown", | |||
|
665 | "metadata": {}, | |||
|
666 | "source": [ | |||
|
667 | "The children of the `ContainerWidget` are two integer valued sliders produced by the widget abbreviations above." | |||
|
668 | ] | |||
|
669 | }, | |||
|
670 | { | |||
|
671 | "cell_type": "code", | |||
|
672 | "collapsed": false, | |||
|
673 | "input": [ | |||
|
674 | "w.children" | |||
|
675 | ], | |||
|
676 | "language": "python", | |||
|
677 | "metadata": {}, | |||
|
678 | "outputs": [ | |||
|
679 | { | |||
|
680 | "metadata": {}, | |||
|
681 | "output_type": "pyout", | |||
|
682 | "prompt_number": 21, | |||
|
683 | "text": [ | |||
|
684 | "(<IPython.html.widgets.widget_int.IntSliderWidget at 0x10557ee90>,\n", | |||
|
685 | " <IPython.html.widgets.widget_int.IntSliderWidget at 0x10616ebd0>)" | |||
|
686 | ] | |||
|
687 | } | |||
|
688 | ], | |||
|
689 | "prompt_number": 21 | |||
|
690 | }, | |||
|
691 | { | |||
|
692 | "cell_type": "markdown", | |||
|
693 | "metadata": {}, | |||
|
694 | "source": [ | |||
|
695 | "To actually display the widgets, you can use IPython's `display` function." | |||
|
696 | ] | |||
|
697 | }, | |||
|
698 | { | |||
|
699 | "cell_type": "code", | |||
|
700 | "collapsed": false, | |||
|
701 | "input": [ | |||
|
702 | "from IPython.display import display\n", | |||
|
703 | "display(w)" | |||
|
704 | ], | |||
|
705 | "language": "python", | |||
|
706 | "metadata": {}, | |||
|
707 | "outputs": [], | |||
|
708 | "prompt_number": 22 | |||
|
709 | }, | |||
|
710 | { | |||
|
711 | "cell_type": "markdown", | |||
|
712 | "metadata": {}, | |||
|
713 | "source": [ | |||
|
714 | "At this point, the UI controls work just like they would if `interact` had been used. You can manipulate them interactively and the function will be called. However, the widget instance returned by `interactive` also give you access to the current keyword arguments and return value of the underlying Python function.\n", | |||
|
715 | "\n", | |||
|
716 | "Here are the current keyword arguments. If you rerun this cell after manipulating the sliders, the values will have changed." | |||
|
717 | ] | |||
|
718 | }, | |||
|
719 | { | |||
|
720 | "cell_type": "code", | |||
|
721 | "collapsed": false, | |||
|
722 | "input": [ | |||
|
723 | "w.kwargs" | |||
|
724 | ], | |||
|
725 | "language": "python", | |||
|
726 | "metadata": {}, | |||
|
727 | "outputs": [ | |||
|
728 | { | |||
|
729 | "metadata": {}, | |||
|
730 | "output_type": "pyout", | |||
|
731 | "prompt_number": 23, | |||
|
732 | "text": [ | |||
|
733 | "{u'a': 10, u'b': 20}" | |||
|
734 | ] | |||
|
735 | } | |||
|
736 | ], | |||
|
737 | "prompt_number": 23 | |||
|
738 | }, | |||
|
739 | { | |||
|
740 | "cell_type": "markdown", | |||
|
741 | "metadata": {}, | |||
|
742 | "source": [ | |||
|
743 | "Here is the current return value of the function." | |||
|
744 | ] | |||
|
745 | }, | |||
|
746 | { | |||
|
747 | "cell_type": "code", | |||
|
748 | "collapsed": false, | |||
|
749 | "input": [ | |||
|
750 | "w.result" | |||
|
751 | ], | |||
|
752 | "language": "python", | |||
|
753 | "metadata": {}, | |||
|
754 | "outputs": [ | |||
|
755 | { | |||
|
756 | "metadata": {}, | |||
|
757 | "output_type": "pyout", | |||
|
758 | "prompt_number": 24, | |||
|
759 | "text": [ | |||
|
760 | "30" | |||
|
761 | ] | |||
|
762 | } | |||
|
763 | ], | |||
|
764 | "prompt_number": 24 | |||
165 | } |
|
765 | } | |
166 | ], |
|
766 | ], | |
167 | "metadata": {} |
|
767 | "metadata": {} |
General Comments 0
You need to be logged in to leave comments.
Login now