QuTiP: An opensource Python framework for the dynamics of open quantum systems
Abstract
We present an objectoriented opensource framework for solving the dynamics of open quantum systems written in Python. Arbitrary Hamiltonians, including timedependent systems, may be built up from operators and states defined by a quantum object class, and then passed on to a choice of master equation or MonteCarlo solvers. We give an overview of the basic structure for the framework before detailing the numerical simulation of open system dynamics. Several examples are given to illustrate the build up to a complete calculation. Finally, we measure the performance of our library against that of current implementations. The framework described here is particularly wellsuited to the fields of quantum optics, superconducting circuit devices, nanomechanics, and trapped ions, while also being ideal for use in classroom instruction.
keywords:
Open quantum systems, Lindblad master equation, Quantum MonteCarlo, PythonPacs:
03.65.Yz, 07.05.Tp, 01.50.hvPROGRAM SUMMARY
Manuscript Title: QuTiP: An opensource Python framework for the dynamics of open quantum systems
Authors: J. R. Johansson, P. D. Nation
Program Title: QuTiP: The Quantum Toolbox in Python
Journal Reference:
Catalogue identifier:
Licensing provisions: GPLv3
Programming language: Python
Computer: i386, x8664
Operating system: Linux, Mac OSX, Windows
RAM: 2+ Gigabytes
Number of processors used: 1+
Keywords: Open quantum systems, Lindblad master equation, Quantum MonteCarlo, Python
Classification: 7 Condensed Matter and Surface Science
External routines/libraries: NumPy, SciPy, Matplotlib
Nature of problem: Dynamics of open quantum systems
Solution method: Numerical solutions to Lindblad master equation or MonteCarlo wave function method.
Restrictions: Problems must meet the criteria for using the master equation in Lindblad form.
Running time: A few seconds up to several tens of minutes, depending on size of underlying Hilbert space.
1 Introduction
Every quantum system encountered in the real world is an open quantum system Breuer and Petruccione (2002). For although much care is taken experimentally to eliminate the unwanted influence of external interactions, there remains, if ever so slight, a coupling between the system of interest and the external world. In addition, any measurement performed on the system necessarily involves coupling to the measuring device, therefore introducing an additional source of external influence. Consequently, developing the necessary tools, both theoretical and numerical, to account for the interactions between a system and its environment is an essential step in understanding the dynamics of quantum systems.
By definition, an open quantum system is coupled to an environment, also called a reservoir or bath, where the complexity of the environmental dynamics renders the combined evolution of system plus reservoir intractable. However, for a system weakly coupled to its surroundings, there is a clear distinction between the system and its environment, allowing for the dynamics of the environment to be traced over, resulting in a reduced density matrix describing the system alone. The most general dynamical equation governing this reduced system density matrix is given by the Lindblad master equation Lindblad (1976) describing the evolution of an ensemble average of a large (formally infinite) number of identical system realizations. Although the density operator formalism sufficed for the first halfcentury of quantum mechanics, the advent of singleion traps in the 1980’s Horvath et al. (1997) motivated the study of the quantum trajectories, or MonteCarlo, description for the evolution of a single realization of a dissipative quantum system Plenio and Knight (1998).
In general, for all but the most basic of Hamiltonians, an analytical description of the system dynamics is not possible, and one must resort to numerical simulations of the equations of motion. In absence of a quantum computer Buluta et al. (2011), these simulations must be carried out using classical computing techniques, where the exponentially increasing dimensionality of the underlying Hilbert space severely limits the size of system that can be efficiently simulated Feynman (1982); Buluta and Nori (2009). However, in many fields such as quantum optics Haroche and Raimond (2006); O’Brien et al. (2009), trapped ions Horvath et al. (1997); Blatt and Wineland (2008), superconducting circuit devices You and Nori (2005); Schoelkopf and Girvin (2008); You and Nori (2011), and most recently nanomechanical systems Armour and Blencowe (2008); Blencowe and Armour (2008); O’Connell et al. (2010); Teufel et al. (2011), it is possible to design systems using a small number of effective oscillator and spin components, excited by a small number of quanta, that are amenable to classical simulation in a truncated Hilbert space.
Of the freely available quantum evolution software packages Schack and Brun (1997); Tan (1999); Vukics and Ritsch (2007), the Quantum Optics Toolbox (qotoolbox) Tan (1999) has by far been the most successful. Although originally geared toward quantum optics, the qotoolbox has gained popularity in a variety of disciplines, driven in part by its rapid modeling capabilities and easy to read code syntax. Yet, at the same time, the qotoolbox has not been updated in nearly a decade, leaving researchers to rely on an outdated numerical platform. Moreover, while the code underlying the qotoolbox is opensourced, it does rely on the proprietary Matlab The Mathworks Inc. (2011) computing environment making it an impractical solution for many research groups, as well as for use as an educational tool inside the classroom.
In this paper, we describe a fully opensource implementation of a framework designed for simulating open quantum dynamics written in the Python programming language van Rossum et al. (2011) called the Quantum Toolbox in Python or QuTiP Nation and Johansson (2011). This framework distinguishes itself from the other available software solutions by providing the following advantages:

Based entirely on opensource software.

Easy to read, rapid code development using the Python programming language.

Support for arbitrary, time dependent Hamiltonians.

Makes use of the multiple processing cores found in modern computers.

Community based infrastructure, allowing for user contributions to the code base.
Although Python is an interpreted programming language, it is well suited for scientific computations as a result of its large collection of highperformance lowlevel numerical libraries Oliphant (2007), mathematical functions Jones et al. (2011), and data visualization capabilities Hunter (2007), that largely are implemented in efficient compiled code. In particular, QuTiP relies heavily on the sparse matrix and dense array functionality provided by the SciPy Jones et al. (2011) and NumPy Oliphant (2007) packages, respectively. Since the bulk of a typical calculation is spent in these libraries, a QuTiP simulation can achieve nearly the same performance as compiled code. The advantage of using the Python programming language over a compiled programming language is a greatly simplified development process, and more transparent, less bugprone code. For data visualization QuTiP uses the matplotlib package Hunter (2007), which is capable of producing publicationquality 2D and 3D figures in a wide range of styles and formats.
Given the success of the qotoolbox, the development of QuTiP has in part been directed toward providing a replacement for this excellent, yet aging software. In the spirit of opensource development, we have strived to use the best parts of the qotoolbox in QuTiP, while improving, replacing, or complementing the parts that were in need of modernization. The result is a framework for simulating quantum system dynamics that is in many ways more efficient and better suited for modern computers, as well as better positioned for further development and adoption to new computer architecture advances. Given the size of the QuTiP framework, we do not hope to cover all of its functionality here. Instead, we will focus on the key data structures, and numerical routines underlying the majority of calculations. In addition, we will highlight a variety of example calculations that we hope will give the reader a flavor of the capabilities of QuTiP, and highlight what is possible using this framework. A complete overview of QuTiP is given on its website Nation and Johansson (2011).
This paper is organized as follows. In Sec. 2 we introduce the main QuTiP class, representing a quantum operator or state vector, and its associated data structures and methods. In Sec. 3 we give a brief overview of the density matrix formalism before discussing the master equation and MonteCarlo methods used in QuTiP. Section 4 presents a selection of examples meant to illustrate how calculations are performed using the QuTiP framework. Section 5 compares the performance of the QuTiP master equation and MonteCarlo solvers to those in the qotoolbox. Finally, Sec. 6 briefly concludes, while a list of user accessible functions built into QuTiP, as well as example codes, are relegated to the appendix.
2 The QuTiP framework
QuTiP provides an objectoriented framework for representing generic quantum systems, and for performing calculations and simulations on such systems. In order to simulate a quantum system, one must first construct an object that encapsulates the properties of an arbitrary state vector or operator.
A unified representation of quantum operators and state vectors is implemented in QuTiP by means of the quantum object class (Qobj), that uses a sparse matrix representation of a quantum object in a finite dimensional Hilbert space. The Qobj class internally maintains a record of the principal attributes of the quantum object it represents. These include, the objects type (i.e ket, bra, operator, or superoperator), whether the underlying object is Hermitian, the dimensionality of a composite object formed via the tensorproduct, and the size of the sparse data matrix. A schematic illustration of the key components underlying the Qobj class is shown in Fig. 1.
In addition to serving as a bookkeeper for the properties of a quantum object, the Qobj class is also a computational object, implementing the usual binary arithmetic operations, and a variety of class methods for performing common object manipulations as presented in Table 1.
Method  Description 

dag()  Adjoint of the quantum object. 
diag()  Diagonal elements of object. 
eigenstates()  Eigenstates and eigenvectors. 
expm()  Exponentiated quantum object. 
full()  Dense array representation. 
norm()  L2 norm (states), trace norm (oper). 
sqrtm()  Matrix square root. 
tr()  Trace of quantum object. 
unit()  Normalizes the quantum object. 
Therefore, with just a few lines of QuTiP code, it is straightforward to construct Hamiltonians from arbitrary combinations of operators, and to construct density matrices and state vectors that represent complicated superpositions of basis states. To further simplify this important step, QuTiP provides a library of commonly occurring operators and states which are given in A.
For example, to create an instance of the Qobj class that represents the ubiquitous twolevel Hamiltonian
(1) 
with energy splitting and transition energy , one can use the following QuTiP code:
H = 0.5 * epsilon * sigmaz() + 0.5 * delta * sigmax()
where epsilon and delta represent user defined constants. The result is a single Qobj instance H that represents the Hamiltonian operator Eq. (1).
Composite quantum systems are nearly as easy to create. Consider the JaynesCumming Hamiltonian
(2) 
with cavity frequency and coupling strength , describing a cavity field coupled to a twolevel atom (qubit). A Qobj instance representing this composite Hamiltonian can be created with the following code:
a = tensor(destroy(N), qeye(2)) sm = tensor(qeye(N), destroy(2)) sz = tensor(qeye(N), sigmaz()) H = omega0 * a.dag() * a + 0.5 * epsilon * sz + g * (a.dag() * sm + a * sm.dag())
where the tensor function is used to construct composite operators for the combined Hilbert space of the cavity (truncated to the lowest Fock states) and the atom.
Since the Qobj class provides a unified representation for operators and states, we can use exactly the same technique to generate quantum states (either as state vectors or density matrices). A possible initial state for the system described by Eq. (2), is generated with the QuTiP code:
psi0 = tensor(fock(N,0),(fock(2,0)+fock(2,1)).unit())
creating the Qobj representation of a cavity in its ground state, coupled to a qubit in a balanced superposition of its ground and excited state . Here, the subscripts and denote the cavity and qubit states, respectively. The normalization factor () is applied automatically using the unit() method.
In the previous example, we have used builtin QuTiP library functions to generate Qobj instances of commonly occurring operators and states, and the associated arithmetic operations in the Qobj class^{3}^{3}3The binary arithmetic operators +, , and * are defined for two Qobj objects, and +, , * as well as / are defined between a Qobj object and a real or complex number. to combine these quantum operators into more complicated systems. The close correspondence between the mathematical formulation and the programming code makes it easy and transparent to define quantum objects. This is especially important when working with quantum systems of more complex structure. Note that the Qobj instances in the previous examples are all selfcontained descriptions of the quantum object they represent. From the Qobj instance alone, a number of properties pertaining to the quantum object may be calculated, and various operations be applied (see Table 1). This includes, for example, operations such as the Hermitian adjoint, normalization, and trace, as well as computation of the eigenstates and eigenenergies and operator exponentiation.
In addition, QuTiP includes several important functions operating on multiple states and/or operators (see Table 2). We have already seen one such example in the tensor function used to generate tensor product states. These states may also be decomposed into their constituent parts by performing a partial trace over selected degrees of freedom using the function ptrace. For example, from the composite wave function psi0 for the oscillatorqubit system, the state of the qubit can be extracted by tracing out the oscillator degrees of freedom using the QuTiP code:
rho0_qubit = ptrace(psi0, 1)
where the second argument is the index of the system that we wish to keep. In general, it can be a list of indices. The properties of the resulting Qobj instance (shown in Fig. 1) may be inspected by displaying the string representation of the object returned by its str method. This method is implicitly invoked when the object is printed to the standard output
print rho0_qubit Quantum object: dims = [[2], [2]], shape = [2, 2], type = oper, isHerm = True Qobj data = [[ 0.5 0.5] [ 0.5 0.5]]
which, in this case, shows that the Qobj instance rho0_qubit is a , Hermitian quantum operator representing a balanced coherent superposition of its two basis states. From a Qobj instance one may also calculate items such as the expectation value (expect) for an arbitrary operator with the QuTiP function, find the fidelity (fidelity) between two density matrices Nielsen and Chuang (2000), or calculate the Wigner function (wigner) of a quantum state. Using these, and other functions (Table. 2), in the exploration of open quantum dynamics will be the focus of Sec. 4.
Even though the emphasis of QuTiP is on dynamical modeling, it is possible to obtain nontrivial results directly from a quantum object. As an example, let us consider the JaynesCummings model in the ultrastrong coupling regime where the rotating wave approximation (RWA) is no longer valid
(3) 
Recently, this regime has become of interest Casanova et al. (2010); Ashhab and Nori (2010); Cao et al. (2011) due to the experimental realization of the required large coupling strengths in superconducting circuit devices FornDíaz et al. (2010). When the coupling strength is a significant fraction of the cavity and qubit frequencies, the ground state of the cavity mode, after tracing out the qubit, is no longer the vacuum state. Instead, the antiresonant terms proportional to and give rise to an anomalous ground state which, in the large coupling limit , may be approximated as Nataf and Ciuti (2010); Ashhab and Nori (2010)
(4) 
where the cavity mode is in a Schrödinger catstate with . This ground state can be evaluated by finding the eigenstates and eigenvalues of the Hamiltonian, and can therefore be extracted directly from the Qobj representation of Eq. (3). In Fig. (2) we plot the cavity and qubit occupation numbers for the groundstate of Eq. (3) as a function of the coupling strength. Here, the cavity is on resonance with the qubit transition frequency, . In addition, Fig. 2 shows the Wigner function for the cavity mode at the largest coupling strength , which is well approximated by Eq. (4). The 20 lines of QuTiP code used in calculating Fig. 2 are given in B.1.
3 Evolution of open quantum systems
The main focus of QuTiP is the timeevolution of open quantum systems. Before we describe how this problem is approached in QuTiP, we give a brief review of the theory of quantum evolution, and the available methods for numerically integrating the equations of motion.
The dynamics of a closed (pure) quantum system is governed by the Schrödinger equation
(5) 
where is the wave function, the Hamiltonian, and is Planck’s constant. In general, the Schrödinger equation is a partial differential equation (PDE) where both and are functions of space and time. For computational purposes it is useful to expand the PDE in a set of basis functions that span the Hilbert space of the Hamiltonian, and to write the equation in matrix and vector form
(6) 
where is the state vector and is the matrix representation of the Hamiltonian. This matrix equation can, in principle, be solved by diagonalizing the Hamiltonian matrix . In practice, however, it is difficult to perform this diagonalization unless the size of the Hilbert space (dimension of the matrix ) is small. Analytically, it is a formidable task to calculate the dynamics for systems with more than two states. If, in addition, we consider dissipation due to the inevitable interaction with a surrounding environment, the computational complexity grows even larger, and we have to resort to numerical calculations in all realistic situations. This illustrates the importance of numerical calculations in describing the dynamics of open quantum systems, and the need for efficient and accessible tools for this task.
While the evolution of the state vector in a closed quantum system is deterministic, open quantum systems are stochastic in nature. The effect of an environment on the system of interest is to induce stochastic transitions between energy levels, and to introduce uncertainty in the phase difference between states of the system. The state of an open quantum system is therefore described in terms of ensemble averaged states using the density matrix formalism. A density matrix describes a probability distribution of quantum states , in a matrix representation , where is the classical probability that the system is in the quantum state . The time evolution of a density matrix is the topic of the remaining portions of this section.
3.1 Master equation
The standard approach for deriving the equations of motion for a system interacting with its environment is to expand the scope of the system to include the environment. The combined quantum system is then closed, and its evolution is governed by the von Neumann equation
(7) 
the equivalent of the Schrödinger equation (5) in the density matrix formalism. Here, the total Hamiltonian
(8) 
includes the original system Hamiltonian , the Hamiltonian for the environment , and a term representing the interaction between the system and its environment . Since we are only interested in the dynamics of the system, we can at this point perform a partial trace over the environmental degrees of freedom in Eq. (7), and thereby obtain a master equation for the motion of the original system density matrix. The most general tracepreserving and completely positive form of this evolution is the Lindblad master equation for the reduced density matrix
(9)  
where the are collapse operators, and are the operators through which the environment couples to the system in , and are the corresponding rates. The derivation of Eq. (9) may be found in several sources Lindblad (1976); Gardiner and Zoller (2004); Walls and Milburn (2008), and will not be reproduced here. Instead, we emphasize the approximations that are required to arrive at the master equation in the form of Eq. (9), and hence perform a calculation in QuTiP:

Separability: At there are no correlations between the system and its environment such that the total density matrix can be written as a tensor product .

Born approximation: Requires: (1) that the state of the environment does not significantly change as a result of the interaction with the system; (2) The system and the environment remain separable throughout the evolution. These assumptions are justified if the interaction is weak, and if the environment is much larger than the system. In summary, .

Markov approximation: The timescale of decay for the environment is much shorter than the smallest timescale of the system dynamics . This approximation is often deemed a “shortmemory environment” as it requires that environmental correlation functions decay on a timescale fast compared to those of the system.

Secular approximation: Stipulates that elements in the master equation corresponding to transition frequencies satisfy , i.e., all fast rotating terms in the interaction picture can be neglected. It also ignores terms that lead to a small renormalization of the system energy levels. This approximation is not strictly necessary for all masterequation formalisms (e.g., the BlockRedfield master equation), but it is required for arriving at the Lindblad form (9) which is used in QuTiP.
For systems with environments satisfying the conditions outlined above, the Lindblad master equation (9) governs the timeevolution of the system density matrix, giving an ensemble average of the system dynamics. In order to ensure that these approximations are not violated, it is important that the decay rates be smaller than the minimum energy splitting in the system Hamiltonian. Situations that demand special attention therefore include, for example, systems strongly coupled to their environment, and systems with degenerate or nearly degenerate energy levels.
In QuTiP there are two solvers that calculate the time evolution according to Eq. (9): odesolve numerically integrates the set of coupled ordinary differential equations (ODEs), and essolve which employs full diagonalization. The odesolve and essolve solvers both take the same set of input parameters (as exemplified in Sec. 4) and can easily be substituted for each other in a QuTiP program. For a quantum system with states, the number of elements in the density matrix is , and solving the master equation by numerical integration or diagonalization involves of use of superoperators of size . In the sparse matrix format, not all of the elements need to be stored in the memory. However, the time required to evolve a quantum system according to the master equation still increases rapidly as a function of the system size. Consequently, the master equation solvers are practical only for relatively small systems: , depending on the details of the problem. In Fig. 3 we show the scaling of the elapsed time for a typical simulation, here chosen to be the Heisenberg spinchain
(10)  
as a function of the size of the Hilbert space, for the two master equation solvers, as well as for two realizations of the MonteCarlo solver mcsolve described the following section. In general, the exact time required to evolve a system depends on the details of the problem, but the scaling with system size is rather generic. The MonteCarlo solver has superior scaling properties compared to the masterequation solvers, but due to the overhead from stochastic averaging, it is only for systems with a Hilbert space dimension around that the MonteCarlo solvers outperform the master equation.
3.2 MonteCarlo trajectories
Where as the density matrix formalism describes the ensemble average over many identical realizations of a quantum system, the MonteCarlo (MC), or quantumjump approach Plenio and Knight (1998) to wave function evolution, allows for simulating an individual realization of the system dynamics. Here, the environment is continuously monitored, resulting in a series of quantum jumps in the system wave function, conditioned on the increase in information gained about the state of the system via the environmental measurements Haroche and Raimond (2006). In general, this evolution is governed by the Schrödinger equation (5) with a nonHermitian effective Hamiltonian
(11) 
where again, the are collapse operators, each corresponding to a separate irreversible process with rate . Here, the strictly negative nonHermitian portion of Eq. (11) gives rise to a reduction in the norm of the wave function, that to firstorder in a small time , is given by where
(12) 
and is such that . With a probability of remaining in the state given by , the corresponding quantum jump probability is thus Eq. (12). If the environmental measurements register a quantum jump, say via the emission of a photon into the environment Guerlin et al. (2007), or a change in the spin of a quantum dot Vamivakas et al. (2010), the wave function undergoes a jump into a state defined by projecting using the collapse operator corresponding to the measurement
(13) 
If more than a single collapse operator is present in Eq (11), the probability of collapse due to the operator is given by
(14) 
Evaluating the MC evolution to firstorder in time is quite tedious. Instead, QuTiP uses the following algorithm to simulate a single realization of a quantum system Dalibard et al. (1992); Dum et al. (1992); Mølmer et al. (1993). Starting from a pure state :

I: Choose a random number between zero and one, representing the probability that a quantum jump occurs.

III: The resultant jump projects the system at time into one of the renormalized states given by Eq. (13). The corresponding collapse operator is chosen such that is the smallest integer satisfying
(15) where the individual are given by Eq. (14). Note that the left hand side of Eq. (15) is, by definition, normalized to unity.

IV: Using the renormalized state from step III as the new initial condition at time , draw a new random number, and repeat the above procedure until the final simulation time is reached.
3.2.1 Example: Singlephoton cavity decay
As an illustrative example, let us consider the evolution of a singlephoton cavity Fock state in a nonzero thermal environment Gleyzes et al. (2007). The evolution of the wave function is governed by the effective Hamiltonian ()
(16) 
with cavity frequency , cavity decay rate , and where is the steady state thermal occupation number. While the first term in Eq. (11) is responsible for the standard unitary evolution of the cavity mode, the second and third terms give rise to random quantum jumps to lower and higher cavity photon numbers, respectively. When a jump occurs, the wave function of the system is projected into a state corresponding to the collapse operator , yielding a decrease in the cavity occupation number, or , which results in an increase. Here, the relative ratio of jumps corresponding to an increase in the cavity occupation number to those for decay is determined by the magnitude of . A single realization of this evolution, showing a lone quantum jump, is presented in Fig. 4a.
In addition to single quantum systems, when averaged over a sufficiently large number of identical system realizations, the MC method leads to the same evolution equation as the Lindblad master equation (9) for a pure state density matrix Plenio and Knight (1998); Haroche and Raimond (2006). Therefore, the MC method may be used in any situation where the Lindblad master equation is valid, as discussed in Sec. 3.1. However, for large quantum systems with Hilbert space dimension , the MC method is vastly more efficient than simulating the full density matrix given that only elements are required to simulate a wave function, as opposed to the elements necessary in the ME approach. Although multiple trajectories are required, convergence to the ME result scales as Walls and Milburn (2008), where is the number of trajectories simulated. In typical situations, between 250 and 500 trajectories are sufficient for errors smaller than a few percent, see Fig. 5. In Fig. 4 we show the convergence of the MC simulation to the ME solution for the singlephoton cavity example as the number of trajectories averaged over is increased.
4 Numerical calculations
In this section we illustrate, via a number of examples, how quantum dynamical calculations are carried out using the QuTiP framework. The typical workflow for performing a simulation with qutip is:

I: Define the parameters that characterize the system and environment (if applicable).

II: Create Qobj class instances representing the Hamiltonian and initial state of the system.

III: For dissipative systems, define the collapse operators as Qobj objects.

IV: Evolve the system with a choice of evolution algorithm and output (e.g., operator expectation values).

V: Postprocess and visualize the data.
Using the quantum object described in Sec. 2, and the solvers for the timeevolution of quantum systems described in Sec. 3, we can explore a diverse set of problems. The examples presented here are selected because they illustrate different features of QuTiP with a minimum of complexity.
4.1 Fidelity of a twoqubit gate subject to noise
To introduce how the evolution of a dynamical quantum system is calculated using QuTiP, let us consider a simple system comprised of two qubits that, during a time , are subject to the coupling Hamiltonian
(17) 
where is the coupling strength. Under ideal conditions this coupling realizes the SWAP gate between the two qubit states Schuch and Siewert (2003); Steffen et al. (2006). This can readily be seen by evolving any initial state for the time , and comparing the final state with the corresponding SWAP transformed initial state. We shall assume that the qubits are coupled with their surrounding environments, resulting in qubit energy relaxation and dephasing.
Following the workflow outlined in the previous section, the QuTiP code for this problem can be organized in the following manner. First, define the numerical constants in the problem. For brevity, the code for this step has been omitted. Next, the Qobj instances for the Hamiltonian and the initial state may be defined as
H = g * (tensor(sigmax(), sigmax()) + tensor(sigmay(), sigmay())) psi0 = tensor(basis(2,1), basis(2,0))
To model qubit relaxation and dephasing, we define a list of collapse operators that later will be passed on to the ODE solver. For each qubit we append its associated collapse operator to this list (here called c_op_list)
sm1 = tensor(sigmam(), qeye(2)) sz1 = tensor(sigmaz(), qeye(2)) c_op_list.append(sqrt(g1 * (1+nth)) * sm1) c_op_list.append(sqrt(g1 * nth) * sm1.dag()) c_op_list.append(sqrt(g2) * sz1)
where the parameter nth is the number of environmentallyinduced thermal excitations in the steady state. The collapse operators containing and describe the qubit relaxation and excitation with the rates g1 * (1+nth) and g1 * nth, respectively, and the collapse operator models qubit dephasing. These lines of codes are repeated for the second qubit, with the appropriate change in the definition of the operators (i.e., the arguments in the tensor function are switched).
At this point we are ready to let QuTiP calculate the timeevolution of the system. In the following example we use the master equation ODE solver odesolve. In addition to the Hamiltonian, initial state, and the list of collapse operator, we pass a list tlist to the solver that contains the times at which we wish to evaluate the density matrix.
tlist = linspace(0, T, 100) rho_list = odesolve(H, psi0, tlist, c_op_list, []) rho_final = rho_list[1]
If the last parameter is empty, as in this example, all QuTiP timeevolution solvers return the full density matrix (or state vector) corresponding to the times in tlist. Alternatively, a list of operators may be passed as last argument to the solver, in which case it will return the corresponding expectation values.
Given the output of density matrices, we may now calculate the corresponding expectation values for selected quantum operators. For example, to calculate the excitation probability of the two qubits as a function of time, we may use the QuTiP function expect
n1 = expect(sm1.dag() * sm1, rho_list) n2 = expect(sm2.dag() * sm2, rho_list)
Here, n1 and n2 are now real NumPy arrays of expectation values, suitable for plotting or saving to file.
Finally, to quantify the difference between the lossy SWAP gate and its ideal counterpart, we calculate the fidelity fidelity
U = (1j * H * pi / (4*g)).expm() psi_ideal = U * psi0 rho_ideal = psi_ideal * psi_ideal.dag() f = fidelity(rho_ideal, rho_final).
4.2 JaynesCumming model
The same method used in the previous section can calculate the dynamics of the JaynesCumming model Eq. (2). Only the definitions of the Hamiltonian, initial state, and collapse operators need to be changed to solve this problem. For the JaynesCumming model, the Hamiltonian and a possible initial state were given in Sec. 2, and we need only to define collapse operators before the system can be evolved using one of the QuTiP solvers. The cavity and the atom relaxation rates are and , respectively. In this example, only the cavity is coupled to an environment with Boltzmann occupation number . We can write the collapse operators for the cavity
a = tensor(destroy(N), qeye(2)) c_ops.append(sqrt(kappa * (1+n_th)) * a) c_ops.append(sqrt(kappa * n_th) * a.dag())
and for the atom
sm = tensor(qeye(N), destroy(2)) c_ops.append(sqrt(gamma)* sm)
Instead of having the solver return the state, as in Sec. 4.1, we can request that the expectation values for a list of operators be directly calculated at each time step. In this JaynesCumming problem we are interested in the excitation number of the cavity and the atom, and as such can then define a list of expectation value operators
expt_ops = [a.dag() * a, sm.dag() * sm]
which may be passed as last argument to, for example, the odesolve solver.
tlist = linspace(0, 10, 100) expt_list = odesolve(H, psi0, tlist, c_ops, expt_ops)
The solver then returns a NumPy array expt_list of expectation values. The result of this calculation is shown in Fig. 7, and the complete code is listed in B.4.
4.3 Trilinear Hamiltonian
To demonstrate the QuTiP MonteCarlo (MC) solver, we consider the trilinear Hamiltonian that, in the interaction frame, may be written as
(18) 
consisting of three harmonic oscillator modes conventionally labeled pump , signal and idler respectively, with the frequency relation, and coupling constant . This Hamiltonian is the full quantum generalization of the parametric amplifier Mollow and Glauber (1967) describing several quantum optics processes, including frequency conversion Walls and Barakat (1970), the interaction of twolevel atoms with a single mode resonant EM field Tavis and Cummings (1968), and the modeling of Hawking radiation from a quantized black hole Nation and Blencowe (2010). Here we suppose the pump mode is initially in a coherent state, while the signal and idler modes are in the ground state
(19) 
As a system comprised of three harmonic modes, this model readily lends itself to MC simulation since the Hilbert space dimensionality increases exponentially with the number of initial excitations in the system . For example, to accurately model an initial pump mode coherent state with requires states, suggesting a minimum Hilbert space dimensionality of for simulating Eq. (18); a value five times larger than what can typically be efficiently calculated using the odesolve or eseries solvers (see Fig. 3).
In QuTiP, the Hamiltonian (18) may be expressed as (=1)
H=1j*(a*b.dag()*c.dag()a.dag()*b*c),
with the destruction operators for the pump, signal, and idler modes, , and respectively, created via the tensor product
a=tensor(destroy(N),qeye(N),qeye(N)) b=tensor(qeye(N),destroy(N),qeye(N)) c=tensor(qeye(N),qeye(N),destroy(N)).
In addition, we may define number operator expectation values and collapse operators in the same manner as previous examples
num0,num1,num2=[a0.dag()*a0,a1.dag()*a1,a2.dag()*a2] C0,C1,C2=[sqrt(2.0*g0)*a0,sqrt(2.0*g1)*a1,sqrt(2.0*g2)*a2]
mcsolve takes the same input arguments as odesolve, save for an additional argument necessary to specify the number of MC trajectories to simulate
ntraj=500
In Fig. 8 we plot the expectation values for the three modes of the trilinear Hamiltonian (18), with corresponding damping rates, , , , for the initial state given by Eq. (19) with
psi0=tensor(coherent(N,sqrt(10)),basis(N,0),basis(N,0)) avgs=mcsolve(H,psi0,tlist,ntraj,[C0,C1,C2],[num0,num1,num2])
4.4 LandauZener transitions
LandauZener transitions Shevchenko et al. (2010) are an interesting problem that involves a quantum twolevel system with a timedependent energy splitting. The Hamiltonian is
(20) 
where is the tunneling rate, and is the rate of change in the bare qubit energy splitting. The LandauZener transition theory analytically describes how the final state at is related to the initial state at . In particular, the probability of an adiabatic transition from to is given by the LandauZener formula
(21) 
Using QuTiP, we can easily integrate the system dynamics numerically, and obtain the state of the system for any intermediate value of .
The LandauZener problem differs from the previous examples in that the Hamiltonian is explicitly timedependent. The QuTiP solvers odesolve and mcsolve both support timedependent Hamiltonians. In order to specify an arbitrary timedependent Hamiltonian, a callback function may be passed as the first argument to the timeevolution solvers (in place of the Qobj instance that normally represents the Hamiltonian). The callback function is expected to return the value of the Hamiltonian at the given point in time t, which is the first argument to the callback function.
def hamiltonian_t(t, args): H0 = args[0] H1 = args[1] return H0 + t * H1
In addition, a second argument passed to the callback function is a userdefined list of parameters. For performance reasons, it is appropriate to let this list contain precalculated Qobj instances for the constant parts of the Hamiltonian. For the LandauZener problem this corresponds to
H0 = delta/2.0 * sigmax() H1 = v/2.0 * sigmaz() H_args = (H0, H1)
The list of arguments for the Hamiltonian callback function is then passed on to the timeevolution solver (as the very last argument), along with the callback function itself (as first argument).
expt_list = odesolve(hamiltonian_t, psi0, tlist, c_op_list, expt_list, H_args)
The result of this calculation is shown in Fig. (9), which shows the intermediate dynamics of the system in terms of the occupation probabilities of the and states. The full code is shown in B.6. Adding the operators sigmax, sigmay and sigmaz to expt_list, this evolution can also be visualized on the Bloch sphere using QuTiP’s built in Bloch class, as demonstrated in Fig. 10. The QuTiP code for this figure is given in B.7.
Although simple, this example illustrates the support for timedependent Hamiltonians in QuTiP. It is a straightforward exercise to implement an arbitrary timedependence by changing the definition of the Hamiltonian callback function, or by modifying the timeindependent part of the Hamiltonian to correspond to a more complicated quantum system.
5 Performance
As with any scientific simulation, the performance of the underlying numerical routines in QuTiP is an important factor to consider when choosing which software to implement in the analysis of the problem at hand. In simulating quantum dynamics on a classical computer, this is especially important given that creating composite systems using the tensor product leads to an exponential increase in the total Hilbert space dimensionality. Thus, it is beneficial to compare the performance of QuTiP to the other currently available quantum simulation packages. In this section we compare the simulation times of the master equation and MonteCarlo solvers in QuTiP, to the those of the qotoolbox, as a function of Hilbert space size.
To compare the QuTiP master equation solver, odesolve, to the qotoolbox equivalent (also called odesolve), we evaluate the coupled oscillator equation ()
(22) 
with and . In addition, we consider the situation in which one resonator is damped with a corresponding dissipation rate . Here, the initial state of the system is the tensor product of Fock states , where is the number of states in the truncated Hilbert space for each oscillator. The total time needed to simulate the dynamics over the time range is shown in Fig. (11). We see that the QuTiP solver easily outperforms the qotoolbox as the Hilbert space dimensionality increases. For the largest dimensionality considered in Fig. (11) , QuTiP is times faster than the qotoolbox singleprecision Ccode implementation, even though QuTiP is performing doubleprecision calculations with a small Python overhead.
The trilinear Hamiltonian model from Sec. 4.3 provides a useful demonstration of the multiprocessing routines used by the QuTiP mcsolve function. Here, the independent MC trajectories are run in parallel, with the number of simultaneous trajectories determined by the number of processing cores. For the large Hilbert spaces associated with the trilinear Hamiltonian, the increased overhead generated from multiprocessing is overcome by the gains in running MonteCarlo trajectories in parallel. In Fig. (12), we highlight these performance gains in simulating Eq. (8) by plotting the computation time over a range of Hilbert space dimensions. For comparison, we also plot the times required for identical simulations using the qotoolbox, which is limited to a single processor.
For this simulation, the qotoolbox outperforms our QuTiP implementation for system sizes , even when multiple processors are utilized. This is due to the Python overhead needed to implement the MonteCarlo algorithm discussed in Sec. 3.2. However, as shown in Fig. (3), using the master equation is more appropriate for systems of this size. As with the master equation solver, Fig. (11), the benefits of using the QuTiP MonteCarlo solver become appreciable as the system size increases. Even for a singleprocessor, the QuTiP mcsolve routine outperforms the qotoolbox after , where the Python overhead is no longer a limiting factor. When using multiple processing cores, the MonteCarlo solver performance gain nearly equals the number of processors available, the ideal situation.
6 Conclusion
We have presented a new, opensource framework for the numerical simulation of open quantum systems implemented in the Python programming language. This framework is suitable for a wide range of computational problems in quantum systems, including unitary and dissipative timeevolution, spectral and steadystate properties, as well as advanced visualization techniques. In this work we have described the basic structure of the framework, the Qobj class, and the primary evolution solvers, odesolve and mcsolve. In addition, we have highlighted a number of examples intended to give the reader a flavor of the types of problems for which QuTiP is suitable. For more indepth documentation, and more elaborate examples using the functions listed in Table 2, we refer the reader to the QuTiP website Nation and Johansson (2011). There, one may download the latest version of this framework, as well as find installation instructions for the most common computer platforms. The version of the framework described in this paper is QuTiP 1.1.3.
Acknowledgements
JRJ and PDN were supported by Japanese Society for the Promotion of Science (JSPS) Foreign Postdoctoral Fellowship No. P11501 and P11202, respectively. FN acknowledges partial support from the LPS, NSA, ARO, DARPA, AFOSR, National Science Foundation (NSF) grant No. 0726909, GrantinAid for Scientific Research (S), MEXT Kakenhi on Quantum Cybernetics, and the JSPSFIRST program.
Appendix A QuTiP function list
States  

basis / fock  Creates single basis (Fock) state in Hilbert space. 
coherent  Singlemode coherent state with complex amplitude . 
coherent_dm  Coherent state density matrix with complex amplitude . 
fock_dm  Density matrix representation of a single basis (Fock) state. 
qstate  Tensor product state for any number of qubits in either the ground or excited states. 
thermal_dm  Thermal state density matrix. 
Operators  
qeye  Identity operator. 
create  Bosonic creation operator. 
destroy  Bosonic annihilation operator. 
displace  Singlemode displacement operator. 
squeez  Singlemode squeezing operator. 
num  Number operator. 
sigmax  Pauli spin1/2 operator. 
sigmay  Pauli spin1/2 operator. 
sigmaz  Pauli spin1/2 operator. 
sigmap  operator. 
sigmam  operator. 
jmat  Spin operator. 
Functions on states  
entropy_vn  VonNeumann entropy of a density matrix. 
expect  Calculates the expectation value of an operator. 
fidelity  Calculates the fidelity between two density matrices. 
ket2dm  Converts a ket vector to a density matrix. 
liouvillian  Assembles the Liouvillian superoperator from a Hamiltonian and a list of collapse operators. 
orbital  Calculates an angular wave function on a sphere. 
ptrace  Partial trace of composite quantum object. 
qfunc  HusimiQ function of a given state vector or density matrix. 
simdiag  Simultaneous diagonalization of commuting Hermitian operators. 
tensor  Calculates tensor product from list of input operators or states. 
tidyup  Removes small elements from a quantum object. 
tracedist  Trace distance between two density matrices. 
wigner  Wigner function of a given state vector or density matrix. 
Evolution  
correlation_es  Twotime correlation function using exponential series. 
correlation_mc  Twotime correlation function using MonteCarlo method. 
correlation_ode  Twotime correlation function using ODE solver. 
correlation_ss_es  Twotime correlation function using quantum regression theorem. 
essolve  State or density matrix evolution using exponential series expansion of ODE. 
mcsolve  Stochastic MonteCarlo wave function solver. 
Odeoptions  Options class for ODE integrators used by mcsolve and odesolve. 
odesolve  ODE solver for density matrix evolution. 
propagator  Calculates the propagator for a density matrix or wave function. 
propagator_steadystate  Steady state for successive applications of the propagator . 
steadystate  Calculates the steady state for the supplied Hamiltonian. 
Utilities  
about  Information on installed version of QuTiP and its dependencies. 
Bloch  Class for plotting vectors and data points on the Bloch sphere. 
clebsch  Calculates a ClebschGordon coefficient. 
demos  Runs builtin demos scripts. 
eseries  Exponential series representation of a timedependent quantum object. 
ode2es  Exponential series describing the time evolution of an initial state. 
parfor  Parallel execution of a forloop over a singlevariable. 
Qobj  Class for creating userdefined quantum objects. 
sphereplot  Plots an array of values on a sphere. 

Appendix B QuTiP codes
In this section we display the QuTiP codes underlying the calculations performed in generating Figures 2, 4, 6, 7, 8, 9, and 10. For brevity, the code segments associated with plotting have been omitted. The codes, in their entirety, may be viewed at the QuTiP website Nation and Johansson (2011).
b.1 Figure 2: NonRWA JaynesCummings Model
from qutip import * ## set up the calculation ## wc = 1.0 * 2 * pi # cavity frequency wa = 1.0 * 2 * pi # atom frequency N = 20 # number of cavity states g = linspace(0, 2.5, 50)*2*pi # coupling strength vector ## create operators ## a = tensor(destroy(N), qeye(2)) sm = tensor(qeye(N), destroy(2)) nc = a.dag() * a na = sm.dag() * sm ## initialize output arrays ## na_expt = zeros(len(g)) nc_expt = zeros(len(g)) ## run calculation ## for k in range(len(g)): ## recalculate the hamiltonian for each value of g ## H = wc*nc+wa*na+g[k]*(a.dag()+a)*(sm+sm.dag()) ## find the groundstate ## ekets, evals = H.eigenstates() psi_gnd = ekets[0] ## expectation values ## na_expt[k] = expect(na, psi_gnd) # qubit occupation nc_expt[k] = expect(nc, psi_gnd) # cavity occupation ## Calculate Wigner function for coupling g=2.5 ## rho_cavity = ptrace(psi_gnd,0) # trace out qubit xvec = linspace(7.5,7.5,200) ## Wigner function ## W = wigner(rho_cavity, xvec, xvec)
b.2 Figure 4: MonteCarlo relaxation in a thermal environment
from qutip import * N=5 # number of basis states to consider a=destroy(N) # cavity destruction operator H=a.dag()*a # harmonic oscillator Hamiltonian psi0=basis(N,1) # initial Fock state with one photon kappa=1.0/0.129 # coupling to heat bath nth= 0.063 # temperature with <n>=0.063 ## collapse operators ## c_op_list = [] ## decay operator ## c_op_list.append(sqrt(kappa * (1 + nth)) * a) ## excitation operator ## c_op_list.append(sqrt(kappa * nth) * a.dag()) ## run simulation ## ntraj=904 # number of MC trajectories tlist=linspace(0,0.6,100) mc = mcsolve(H,psi0,tlist,ntraj,c_op_list, []) me = odesolve(H,psi0,tlist,c_op_list, [a.dag()*a]) ## expectation values ## ex1=expect(num(N),mc[0]) ex5=sum([expect(num(N),mc[k]) for k in range(5)],0)/5 ex15=sum([expect(num(N),mc[k]) for k in range(15)],0)/15 ex904=sum([expect(num(N),mc[k]) for k in range(904)],0)/904
b.3 Figure 6: Dissipative SWAP gate
from qutip import * g = 1.0 * 2 * pi # coupling strength g1 = 0.75 # relaxation rate g2 = 0.05 # dephasing rate n_th = 0.75 # bath temperature T = pi/(4*g) H = g * (tensor(sigmax(), sigmax()) + tensor(sigmay(), sigmay())) psi0 = tensor(basis(2,1), basis(2,0)) c_op_list = [] ## qubit 1 collapse operators ## sm1 = tensor(sigmam(), qeye(2)) sz1 = tensor(sigmaz(), qeye(2)) c_op_list.append(sqrt(g1 * (1+n_th)) * sm1) c_op_list.append(sqrt(g1 * n_th) * sm1.dag()) c_op_list.append(sqrt(g2) * sz1) ## qubit 2 collapse operators ## sm2 = tensor(qeye(2), sigmam()) sz2 = tensor(qeye(2), sigmaz()) c_op_list.append(sqrt(g1 * (1+n_th)) * sm2) c_op_list.append(sqrt(g1 * n_th) * sm2.dag()) c_op_list.append(sqrt(g2) * sz2) ## evolve the system ## tlist = linspace(0, T, 100) rho_list = odesolve(H, psi0, tlist, c_op_list, []) rho_final = rho_list[1] ## calculate expectation values ## n1 = expect(sm1.dag() * sm1, rho_list) n2 = expect(sm2.dag() * sm2, rho_list) ## calculate the fidelity ## U = (1j * H * pi / (4*g)).expm() psi_ideal = U * psi0 rho_ideal = psi_ideal * psi_ideal.dag() f = fidelity(rho_ideal, rho_final)
b.4 Figure 7: Dissipative JaynesCumming model
from qutip import * N = 5 # number of cavity states omega0 = epsilon = 2 * pi # frequencies g = 0.05 * 2 * pi # coupling strength kappa = 0.005 # cavity relaxation rate gamma = 0.05 # atom relaxation rate n_th = 0.75 # bath temperature ## Hamiltonian and initial state ## a = tensor(destroy(N), qeye(2)) sm = tensor(qeye(N), destroy(2)) sz = tensor(qeye(N), sigmaz()) H = omega0 * a.dag() * a + 0.5 * epsilon * sz + g * (a.dag() * sm + a * sm.dag()) psi0 = tensor(fock(N,0), fock(2,1)) # excited atom ## Collapse operators ## c_ops = [] c_ops.append(sqrt(kappa * (1+n_th)) * a) c_ops.append(sqrt(kappa * n_th) * a.dag()) c_ops.append(sqrt(gamma) * sm) ## Operator list for expectation values ## expt_ops = [a.dag() * a, sm.dag() * sm] ## Evolution of the system ## tlist = linspace(0, 10, 100) expt_data = odesolve(H, psi0, tlist, c_ops, expt_ops)
b.5 Figure 8: Trilinear Hamiltonian
from qutip import * N=17 # number of states for each mode ## damping rates ## g0=g2=0.1 g1=0.4 alpha=sqrt(10) # initial coherent state alpha tlist=linspace(0,4,201) # list of times ntraj=1000#number of trajectories ## lowering operators ## a0=tensor(destroy(N),qeye(N),qeye(N)) a1=tensor(qeye(N),destroy(N),qeye(N)) a2=tensor(qeye(N),qeye(N),destroy(N)) ## number operators ## n0,n1,n2=[a0.dag()*a0,a1.dag()*a1,a2.dag()*a2] ## dissipative operators ## C0,C1,C2=[sqrt(2.0*g0)*a0,sqrt(2.0*g1)*a1,sqrt(2.0*g2)*a2] ## initial state ## psi0=tensor(coherent(N,alpha),basis(N,0),basis(N,0)) ## trilinear Hamiltonian ## H=1j*(a0*a1.dag()*a2.dag()a0.dag()*a1*a2) ## run MonteCarlo ## avgs=mcsolve(H,psi0,tlist,ntraj,[C0,C1,C2],[n0,n1,n2]) ## run Schrodinger ## reals=mcsolve(H,psi0,tlist,1,[],[n0,n1,n2])
b.6 Figure 9: LandauZener transitions
from qutip import * ## callback function for timedependence ## def hamiltonian_t(t, args): H0 = args[0] H1 = args[1] return H0 + t * H1 delta = 0.5 * 2 * pi v = 2.0 * 2 * pi # sweep rate ## arguments for Hamiltonian ## H0 = delta/2.0 * sigmax() H1 = v/2.0 * sigmaz() H_args = (H0, H1) psi0 = basis(2,0) ## expectation operators ## sm = destroy(2) sx=sigmax();sy=sigmay();sz=sigmaz() expt_op_list = [sm.dag() * sm,sx,sy,sz] ## evolve the system ## tlist = linspace(10.0, 10.0, 1500) expt_list = odesolve(hamiltonian_t, psi0, tlist, [], expt_op_list, H_args)
b.7 Figure 10: Bloch sphere representation of LandauZener transition
Following the code from B.6:
import matplotlib as mpl from matplotlib import cm ## create Bloch sphere instance ## b=Bloch() ## normalize colors to times in tlist ## nrm=mpl.colors.Normalize(2,10) colors=cm.jet(nrm(tlist)) ## add data points from expectation values ## b.add_points([p_ex[1],p_ex[2],p_ex[3]],’m’) ## customize sphere properties ## b.point_color=list(colors) b.point_marker=[’o’] b.point_size=[8] b.view=[9,11] b.zlpos=[1.1,1.2] b.zlabel=[’$\left0\\right>_{f}$’,’$\left1\\right>_{f}$’] ## plot sphere ## b.show()
References
 Breuer and Petruccione (2002) H.P. Breuer, F. Petruccione, The Theory of Open Quantum Systems, Oxford University, 2002.
 Lindblad (1976) G. Lindblad, Commun. Math. Phys. 48 (1976) 119.
 Horvath et al. (1997) G. Z. K. Horvath, P. L. Knight, R. C. Thompson, Contemp. Phys. 38 (1997) 25.
 Plenio and Knight (1998) M. B. Plenio, P. L. Knight, Rev. Mod. Phys. 70 (1998) 101.
 Buluta et al. (2011) I. Buluta, S. Ashhab, F. Nori, Reports on Progress in Physics 74 (2011) 104401.
 Feynman (1982) R. P. Feynman, Int. J. Theor. Phys. 21 (1982) 467.
 Buluta and Nori (2009) I. Buluta, F. Nori, Science 326 (2009) 108.
 Haroche and Raimond (2006) S. Haroche, J.M. Raimond, Exploring the Quantum: Atoms, Cavities, and Photons, Oxford University, 2006.
 O’Brien et al. (2009) J. L. O’Brien, A. Furusawa, J. Vuc̆kovic, Nat. Photonics 3 (2009) 687.
 Blatt and Wineland (2008) R. Blatt, D. Wineland, Nature 453 (2008) 1008.
 You and Nori (2005) J. Q. You, F. Nori, Phys. Today 58 (2005) 42.
 Schoelkopf and Girvin (2008) R. J. Schoelkopf, S. M. Girvin, Nature 451 (2008) 664.
 You and Nori (2011) J. Q. You, F. Nori, Nature 474 (2011) 589.
 Armour and Blencowe (2008) A. D. Armour, M. P. Blencowe, New J. Phys. 10 (2008) 095004.
 Blencowe and Armour (2008) M. P. Blencowe, A. D. Armour, New J. Phys. 10 (2008) 095005.
 O’Connell et al. (2010) A. D. O’Connell, M. Hofheinz, M. Ansmann, R. C. Bialczak, M. Lenander, E. Lucero, M. Neeley, D. Sank, H. Wang, M. Weides, J. Wenner, J. M. Martinis, A. N. Cleland, Nature 464 (2010) 697.
 Teufel et al. (2011) J. D. Teufel, T. Donner, L. Dale, J. W. Harlow, M. S. Allman, K. Cicak, A. J. Sirois, J. D. Whittaker, K. W. Lehnert, R. W. Simmonds, Nature 475 (2011) 359.
 Schack and Brun (1997) R. Schack, T. A. Brun, Comput. Phys. Commun. 102 (1997) 210.
 Tan (1999) S. M. Tan, J. Opt. B: Quantum Semiclass. Opt. 1 (1999) 424.
 Vukics and Ritsch (2007) A. Vukics, H. Ritsch, Eur. Phys. J. D 44 (2007) 585.
 The Mathworks Inc. (2011) The Mathworks Inc., Matlab, http://www.mathworks.com/, 2011.
 van Rossum et al. (2011) G. van Rossum, et al., The Python progamming language, http://www.python.org/, 2011.
 Nation and Johansson (2011) P. D. Nation, J. R. Johansson, QuTiP: Quantum Toolbox in Python, http://code.google.com/p/qutip/, 2011.
 Oliphant (2007) T. E. Oliphant, Computing in Science & Engineering 9 (2007) 10.
 Jones et al. (2011) E. Jones, T. Oliphant, P. Peterson, et al., SciPy: Open source scientific tools for Python, http://www.scipy.org/, 2011.
 Hunter (2007) J. D. Hunter, Computing in Science & Engineering 9 (2007) 90.
 Nielsen and Chuang (2000) M. A. Nielsen, I. L. Chuang, Quantum Computation and Quantum Information, Cambridge, 2000.
 Casanova et al. (2010) J. Casanova, G. Romero, I. Lizuain, J. J. GarcíaRipoll, E. Solano, Phys. Rev. Lett. 105 (2010) 263603.
 Ashhab and Nori (2010) S. Ashhab, F. Nori, Phys. Rev. A 81 (2010) 042311.
 Cao et al. (2011) X. Cao, J. Q. You, H. Zheng, F. Nori, New J. Phys. 13 (2011) 073002.
 FornDíaz et al. (2010) P. FornDíaz, J. Lisenfield, D. Marcos, GarcíaRipoll, E. Solano, C. J. P. M. Harmans, J. E. Mooij, Phys. Rev. Lett. 105 (2010) 237001.
 Nataf and Ciuti (2010) P. Nataf, C. Ciuti, Phys. Rev. Lett. 104 (2010) 023601.
 Gardiner and Zoller (2004) C. W. Gardiner, P. Zoller, Quantum Noise, Springer, 3rd edition, 2004.
 Walls and Milburn (2008) D. F. Walls, G. J. Milburn, Quantum Optics, Springer, 2nd edition, 2008.
 Guerlin et al. (2007) C. Guerlin, J. Bernu, S. Deléglise, C. Sayrin, S. Gleyzes, S. Kuhr, M. Brune, J.M. Raimond, S. Haroche, Nature 448 (2007) 889.
 Vamivakas et al. (2010) A. N. Vamivakas, C.Y. Lu, C. Matthisen, Y. Zhao, S. Fält, A. Badolato, M. Atatüre, Nature 467 (2010) 297.
 Dalibard et al. (1992) J. Dalibard, Y. Castin, K. Mølmer, Phys. Rev. Lett. 68 (1992) 580.
 Dum et al. (1992) R. Dum, P. Zoller, H. Ritsch, Phys. Rev. A 45 (1992) 4879.
 Mølmer et al. (1993) K. Mølmer, Y. Castin, J. Dalibard, J. Opt. Soc. Am. B 10 (1993) 524.
 Gleyzes et al. (2007) S. Gleyzes, S. Kuhr, C. Guerlin, J. Bernu, S. Deléglise, U. Busk Hoff, M. Brune, J.M. Raimond, S. Haroche, Nature 446 (2007) 297.
 Schuch and Siewert (2003) N. Schuch, J. Siewert, Phys. Rev. A 67 (2003) 032301.
 Steffen et al. (2006) M. Steffen, M. Ansmann, R. C. Bialczak, N. Katz, E. Lucero, R. McDermott, M. Neeley, E. M. Weig, A. N. Cleland, J. M. Martinis, Science 313 (2006) 1423–1425.
 Mollow and Glauber (1967) B. R. Mollow, R. J. Glauber, Phys. Rev. 160 (1967) 1076.
 Walls and Barakat (1970) D. F. Walls, R. Barakat, Phys. Rev. A 1 (1970) 446.
 Tavis and Cummings (1968) M. Tavis, F. W. Cummings, Phys. Rev. 170 (1968) 379.
 Nation and Blencowe (2010) P. D. Nation, M. P. Blencowe, New J. Phys. 12 (2010) 095013.
 Shevchenko et al. (2010) S. N. Shevchenko, S. Ashhab, F. Nori, Phy. Rep. 492 (2010) 1.
 Behnel et al. (2011) S. Behnel, R. Bradshaw, C. Citro, L. Dalcin, D. Seljebotn, K. Smith, Computing in Science & Engineering 13 (2011) 31.
 Klöckner (2011) A. Klöckner, PyOpenCL, http://mathema.tician.de/software/pyopencl, 2011.