overview.rst
289 lines
| 12.5 KiB
| text/x-rst
|
RstLexer
Brian E Granger
|
r1258 | .. _overview: | ||
============ | ||||
Introduction | ||||
============ | ||||
Overview | ||||
======== | ||||
One of Python's most useful features is its interactive interpreter. | ||||
Paul Ivanov
|
r11938 | It allows for very fast testing of ideas without the overhead of | ||
Brian E Granger
|
r1258 | creating test files as is typical in most programming languages. | ||
However, the interpreter supplied with the standard Python distribution | ||||
is somewhat limited for extended interactive use. | ||||
Brian E Granger
|
r1400 | The goal of IPython is to create a comprehensive environment for | ||
Brian Granger
|
r1716 | interactive and exploratory computing. To support this goal, IPython | ||
Paul Ivanov
|
r11604 | has three main components: | ||
Brian E Granger
|
r1400 | |||
Brian Granger
|
r1677 | * An enhanced interactive Python shell. | ||
Paul Ivanov
|
r12098 | * A decoupled :ref:`two-process communication model <ipythonzmq>`, which | ||
allows for multiple clients to connect to a computation kernel, most notably | ||||
the web-based :ref:`notebook <htmlnotebook>` | ||||
Brian Granger
|
r1677 | * An architecture for interactive parallel computing. | ||
Brian E Granger
|
r1400 | |||
All of IPython is open source (released under the revised BSD license). | ||||
Enhanced interactive Python shell | ||||
================================= | ||||
Brian Granger
|
r1677 | IPython's interactive shell (:command:`ipython`), has the following goals, | ||
amongst others: | ||||
1. Provide an interactive shell superior to Python's default. IPython | ||||
Paul Ivanov
|
r11938 | has many features for tab-completion, object introspection, system shell | ||
access, command history retrieval across sessions, and its own special | ||||
command system for adding functionality when working interactively. It | ||||
tries to be a very efficient environment both for Python code development | ||||
and for exploration of problems using Python objects (in situations like | ||||
data analysis). | ||||
Brian Granger
|
r1677 | |||
2. Serve as an embeddable, ready to use interpreter for your own | ||||
Paul Ivanov
|
r11938 | programs. An interactive IPython shell can be started with a single call | ||
from inside another program, providing access to the current namespace. | ||||
This can be very useful both for debugging purposes and for situations | ||||
where a blend of batch-processing and interactive exploration are needed. | ||||
Brian Granger
|
r1677 | |||
3. Offer a flexible framework which can be used as the base | ||||
Paul Ivanov
|
r11938 | environment for working with other systems, with Python as the underlying | ||
bridge language. Specifically scientific environments like Mathematica, | ||||
Brian Granger
|
r1677 | IDL and Matlab inspired its design, but similar ideas can be | ||
useful in many fields. | ||||
4. Allow interactive testing of threaded graphical toolkits. IPython | ||||
Paul Ivanov
|
r11938 | has support for interactive, non-blocking control of GTK, Qt, WX, GLUT, and | ||
OS X applications via special threading flags. The normal Python | ||||
Brian Granger
|
r1677 | shell can only do this for Tkinter applications. | ||
Brian E Granger
|
r1258 | |||
Brian E Granger
|
r1400 | Main features of the interactive shell | ||
-------------------------------------- | ||||
Brian Granger
|
r1677 | * Dynamic object introspection. One can access docstrings, function | ||
definition prototypes, source code, source files and other details | ||||
of any object accessible to the interpreter with a single | ||||
keystroke (:samp:`?`, and using :samp:`??` provides additional detail). | ||||
* Searching through modules and namespaces with :samp:`*` wildcards, both | ||||
when using the :samp:`?` system and via the :samp:`%psearch` command. | ||||
* Completion in the local namespace, by typing :kbd:`TAB` at the prompt. | ||||
This works for keywords, modules, methods, variables and files in the | ||||
current directory. This is supported via the readline library, and | ||||
full access to configuring readline's behavior is provided. | ||||
Custom completers can be implemented easily for different purposes | ||||
(system commands, magic arguments etc.) | ||||
* Numbered input/output prompts with command history (persistent | ||||
across sessions and tied to each profile), full searching in this | ||||
history and caching of all input and output. | ||||
* User-extensible 'magic' commands. A set of commands prefixed with | ||||
:samp:`%` is available for controlling IPython itself and provides | ||||
directory control, namespace information and many aliases to | ||||
common system shell commands. | ||||
* Alias facility for defining your own system aliases. | ||||
* Complete system shell access. Lines starting with :samp:`!` are passed | ||||
directly to the system shell, and using :samp:`!!` or :samp:`var = !cmd` | ||||
captures shell output into python variables for further use. | ||||
Fernando Perez
|
r1753 | * The ability to expand python variables when calling the system shell. In a | ||
shell command, any python variable prefixed with :samp:`$` is expanded. A | ||||
double :samp:`$$` allows passing a literal :samp:`$` to the shell (for access | ||||
to shell and environment variables like :envvar:`PATH`). | ||||
Brian Granger
|
r1677 | |||
* Filesystem navigation, via a magic :samp:`%cd` command, along with a | ||||
persistent bookmark system (using :samp:`%bookmark`) for fast access to | ||||
frequently visited directories. | ||||
* A lightweight persistence framework via the :samp:`%store` command, which | ||||
allows you to save arbitrary Python variables. These get restored | ||||
Paul Ivanov
|
r11939 | when you run the :samp:`%store -r` command. | ||
Brian Granger
|
r1677 | |||
* Automatic indentation (optional) of code as you type (through the | ||||
readline library). | ||||
* Macro system for quickly re-executing multiple lines of previous | ||||
Paul Ivanov
|
r11939 | input with a single name via the :samp:`%macro` command. Macros can be | ||
stored persistently via :samp:`%store` and edited via :samp:`%edit`. | ||||
Brian Granger
|
r1677 | |||
* Session logging (you can then later use these logs as code in your | ||||
programs). Logs can optionally timestamp all input, and also store | ||||
session output (marked as comments, so the log remains valid | ||||
Python source code). | ||||
* Session restoring: logs can be replayed to restore a previous | ||||
session to the state where you left it. | ||||
* Verbose and colored exception traceback printouts. Easier to parse | ||||
visually, and in verbose mode they produce a lot of useful | ||||
debugging information (basically a terminal version of the cgitb | ||||
module). | ||||
Paul Ivanov
|
r11939 | * Auto-parentheses via the :samp:`%autocall` command: callable objects can be | ||
executed without parentheses: :samp:`sin 3` is automatically converted to | ||||
:samp:`sin(3)` | ||||
Brian Granger
|
r1677 | |||
* Auto-quoting: using :samp:`,`, or :samp:`;` as the first character forces | ||||
auto-quoting of the rest of the line: :samp:`,my_function a b` becomes | ||||
automatically :samp:`my_function("a","b")`, while :samp:`;my_function a b` | ||||
becomes :samp:`my_function("a b")`. | ||||
* Extensible input syntax. You can define filters that pre-process | ||||
user input to simplify input in special situations. This allows | ||||
for example pasting multi-line code fragments which start with | ||||
:samp:`>>>` or :samp:`...` such as those from other python sessions or the | ||||
standard Python documentation. | ||||
Paul Ivanov
|
r11939 | * Flexible :ref:`configuration system <config_overview>`. It uses a | ||
configuration file which allows permanent setting of all command-line | ||||
options, module loading, code and file execution. The system allows | ||||
recursive file inclusion, so you can have a base file with defaults and | ||||
layers which load other customizations for particular projects. | ||||
Brian Granger
|
r1677 | |||
* Embeddable. You can call IPython as a python shell inside your own | ||||
python programs. This can be used both for debugging code or for | ||||
providing interactive abilities to your programs with knowledge | ||||
about the local namespaces (very useful in debugging and data | ||||
analysis situations). | ||||
Fernando Perez
|
r1753 | * Easy debugger access. You can set IPython to call up an enhanced version of | ||
the Python debugger (pdb) every time there is an uncaught exception. This | ||||
drops you inside the code which triggered the exception with all the data | ||||
live and it is possible to navigate the stack to rapidly isolate the source | ||||
of a bug. The :samp:`%run` magic command (with the :samp:`-d` option) can run | ||||
any script under pdb's control, automatically setting initial breakpoints for | ||||
you. This version of pdb has IPython-specific improvements, including | ||||
tab-completion and traceback coloring support. For even easier debugger | ||||
Paul Ivanov
|
r11939 | access, try :samp:`%debug` after seeing an exception. | ||
Brian Granger
|
r1677 | |||
* Profiler support. You can run single statements (similar to | ||||
:samp:`profile.run()`) or complete programs under the profiler's control. | ||||
While this is possible with standard cProfile or profile modules, | ||||
IPython wraps this functionality with magic commands (see :samp:`%prun` | ||||
and :samp:`%run -p`) convenient for rapid interactive work. | ||||
Paul Ivanov
|
r11939 | * Simple timing information. You can use the :samp:`%timeit` command to get | ||
the execution time of a Python statement or expression. This machinery is | ||||
intelligent enough to do more repetitions for commands that finish very | ||||
quickly in order to get a better estimate of their running time. | ||||
.. sourcecode:: ipython | ||||
Paul Ivanov
|
r11941 | In [1]: %timeit 1+1 | ||
Paul Ivanov
|
r11939 | 10000000 loops, best of 3: 25.5 ns per loop | ||
In [2]: %timeit [math.sin(x) for x in range(5000)] | ||||
1000 loops, best of 3: 719 µs per loop | ||||
.. | ||||
To get the timing information for more than one expression, use the | ||||
:samp:`%%timeit` cell magic command. | ||||
Brian Granger
|
r1677 | * Doctest support. The special :samp:`%doctest_mode` command toggles a mode | ||
Paul Ivanov
|
r11941 | to use doctest-compatible prompts, so you can use IPython sessions as | ||
doctest code. By default, IPython also allows you to paste existing | ||||
doctests, and strips out the leading :samp:`>>>` and :samp:`...` prompts in | ||||
them. | ||||
Brian E Granger
|
r1400 | |||
Paul Ivanov
|
r11610 | .. _ipythonzmq: | ||
Paul Ivanov
|
r11604 | Decoupled two-process model | ||
============================== | ||||
IPython has abstracted and extended the notion of a traditional | ||||
*Read-Evaluate-Print Loop* (REPL) environment by decoupling the *evaluation* | ||||
Paul Ivanov
|
r12098 | into its own process. We call this process a **kernel**: it receives execution | ||
Paul Ivanov
|
r11604 | instructions from clients and communicates the results back to them. | ||
This decoupling allows us to have several clients connected to the same | ||||
kernel, and even allows clients and kernels to live on different machines. | ||||
With the exclusion of the traditional single process terminal-based IPython | ||||
(what you start if you run ``ipython`` without any subcommands), all | ||||
other IPython machinery uses this two-process model. This includes ``ipython | ||||
console``, ``ipython qtconsole``, and ``ipython notebook``. | ||||
As an example, this means that when you start ``ipython qtconsole``, you're | ||||
really starting two processes, a kernel and a Qt-based client can send | ||||
commands to and receive results from that kernel. If there is already a kernel | ||||
running that you want to connect to, you can pass the ``--existing`` flag | ||||
which will skip initiating a new kernel and connect to the most recent kernel, | ||||
instead. To connect to a specific kernel once you have several kernels | ||||
running, use the ``%connect_info`` magic to get the unique connection file, | ||||
which will be something like ``--existing kernel-19732.json`` but with | ||||
different numbers which correspond to the Process ID of the kernel. | ||||
You can read more about using :ref:`ipython qtconsole <qtconsole>`, and | ||||
:ref:`ipython notebook <htmlnotebook>`. There is also a :ref:`message spec | ||||
<messaging>` which documents the protocol for communication between kernels | ||||
and clients. | ||||
Paul Ivanov
|
r12098 | .. seealso:: | ||
`Frontend/Kernel Model`_ example notebook | ||||
Paul Ivanov
|
r11604 | |||
Brian E Granger
|
r1400 | Interactive parallel computing | ||
============================== | ||||
Fernando Perez
|
r1753 | Increasingly, parallel computer hardware, such as multicore CPUs, clusters and | ||
Paul Ivanov
|
r11615 | supercomputers, is becoming ubiquitous. Over the last several years, we have | ||
Fernando Perez
|
r1753 | developed an architecture within IPython that allows such hardware to be used | ||
quickly and easily from Python. Moreover, this architecture is designed to | ||||
support interactive and collaborative parallel computing. | ||||
Brian E Granger
|
r1400 | |||
Brian Granger
|
r1677 | The main features of this system are: | ||
* Quickly parallelize Python code from an interactive Python/IPython session. | ||||
* A flexible and dynamic process model that be deployed on anything from | ||||
multicore workstations to supercomputers. | ||||
* An architecture that supports many different styles of parallelism, from | ||||
message passing to task farming. And all of these styles can be handled | ||||
interactively. | ||||
* Both blocking and fully asynchronous interfaces. | ||||
* High level APIs that enable many things to be parallelized in a few lines | ||||
of code. | ||||
* Write parallel code that will run unchanged on everything from multicore | ||||
workstations to supercomputers. | ||||
* Full integration with Message Passing libraries (MPI). | ||||
* Capabilities based security model with full encryption of network connections. | ||||
Fernando Perez
|
r1753 | * Share live parallel jobs with other users securely. We call this | ||
collaborative parallel computing. | ||||
Brian Granger
|
r1677 | |||
* Dynamically load balanced task farming system. | ||||
* Robust error handling. Python exceptions raised in parallel execution are | ||||
gathered and presented to the top-level code. | ||||
Fernando Perez
|
r1753 | For more information, see our :ref:`overview <parallel_index>` of using IPython | ||
for parallel computing. | ||||
Brian E Granger
|
r1258 | |||
Portability and Python requirements | ||||
----------------------------------- | ||||
Thomas Kluyver
|
r12147 | As of the 2.0 release, IPython works with Python 2.7 and 3.3 or above. | ||
Version 1.0 additionally worked with Python 2.6 and 3.2. | ||||
Version 0.12 was the first version to fully support Python 3. | ||||
Brian E Granger
|
r1400 | |||
IPython is known to work on the following operating systems: | ||||
* Linux | ||||
Fernando Perez
|
r1753 | * Most other Unix-like OSs (AIX, Solaris, BSD, etc.) | ||
Brian E Granger
|
r1400 | * Mac OS X | ||
* Windows (CygWin, XP, Vista, etc.) | ||||
Brian Granger
|
r2275 | See :ref:`here <install_index>` for instructions on how to install IPython. | ||
Paul Ivanov
|
r12098 | .. include:: links.txt | ||