Gpelab A Matlab Toolbox For Computing Stationary Solutions and Dynamics of Gross-Pitaevskii Equations (Gpe)
Gpelab A Matlab Toolbox For Computing Stationary Solutions and Dynamics of Gross-Pitaevskii Equations (Gpe)
Gpelab A Matlab Toolbox For Computing Stationary Solutions and Dynamics of Gross-Pitaevskii Equations (Gpe)
Université de Lorraine
Institut Elie Cartan de Lorraine, UMR CNRS 7502
F-54506 Vandoeuvre-lès-Nancy Cedex
FRANCE
Permission is granted to make and distribute verbatim copies of this manual provided
the copyright notice and this permission notice are preserved on all copies.
Contents
3
4 CONTENTS
B License 109
6 CONTENTS
List of Figures
2.1 Two possible gaussian initial data for initializing the iterative scheme (with γx =
γy = 1) and x0 = (0, 0). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
2.2 Thomas-Fermi initial data for initializing the iterative scheme for potential (2.11)
(with γx = γy = 1). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
2.3 Examples Thomas-Fermi approximation for potentials (2.13) (left) and (2.19) (right). 23
2.4 Examples Thomas-Fermi approximation for potentials (2.20) (left) and (2.21) (right). 23
3.1 Ground state computed with GPELab using the parameters from Section 3.2. . . . . 38
3.2 The FFTNonlinearity_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . 48
7
8 LIST OF FIGURES
List of Tables
3.1 An example of Method and Geometry2D in GPELab for computing a ground state. . 36
3.2 An example of how to define the Physics in GPELab through the Physics2D struc-
ture. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
3.3 Initialization by the Thomas-Fermi approximation. . . . . . . . . . . . . . . . . . . . 37
3.4 Printing/drawing informations during the computations. . . . . . . . . . . . . . . . . 37
3.5 Launching the computation of the solution. . . . . . . . . . . . . . . . . . . . . . . . 37
3.6 An example of 2 × 2 real-valued matrix. . . . . . . . . . . . . . . . . . . . . . . . . . 38
3.7 An example of element wise multiplication for matrices. . . . . . . . . . . . . . . . . 39
3.8 An example of cell. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
3.9 Accessing to an element of a cell. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
3.10 An example of simple function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
3.11 An example of structure. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
3.12 The Method_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
3.13 An example of initialization and use of the Method_Var2d function. . . . . . . . . . . 42
3.14 The Geometry2D_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
3.15 An example of how to use the Geometry2D_Var2d function. . . . . . . . . . . . . . . 43
3.16 The Physics2D_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
3.17 An example to use the Physics2D_Var2d function. . . . . . . . . . . . . . . . . . . . 45
3.18 The Potential_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
3.19 An example to use the Potential_Var2d function. . . . . . . . . . . . . . . . . . . . 46
3.20 The Nonlinearity_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
3.21 An example to use the Nonlinearity_Var2d function. . . . . . . . . . . . . . . . . . 48
3.22 An example of application of the FFTNonlinearity_Var2d function with the dipolar
operator. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
3.23 The Gradientx_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
3.24 An example to use the Gradientx_Var2d.m and Gradienty_Var2d functions. . . . . 52
3.25 The InitialData_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
3.26 An example to use the InitialData_Var2d function. . . . . . . . . . . . . . . . . . . 53
3.27 The OutputsINI_Var2d function . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
3.28 An example to use the OutputsINI_Var2d function for a user-defined function with
a single-component. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
3.29 An example to use the OutputsINI_Var2d function for a user-defined function with
multi-components. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
3.30 The Continuation_Var2d function. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
3.31 An example for using the Continuation_Var2d function when the parameter is a
scalar. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
3.32 An example for using the Continuation_Var2d function when the parameter is a
matrix. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58
3.33 An example to use the Continuation_Var2d function for 2 parameters. . . . . . . . . 58
9
10 LIST OF TABLES
1.1 Overview
GPELab (Gross-Pitaevskii Equation LABoratory) is a Matlab toolbox devoted to the numerical
computation of stationary and dynamical solutions of the 1d-2d-3d GPE, for general nonlinearities,
including rotation terms and possibly multi-components problems. This user guide explains which
problems GPELab can solve and which algorithms are used to effectively solve them. In addition,
we discuss and detail all the functions available in the code. Finally, complete examples are given in
such a way that any user can see how easy it is to manipulate it. GPELab is developed to be installed
on any computer that has a basic version of Matlab. The methods are based on pseudospectral
approximation techniques and therefore provide highly accurate solutions. The structure of the
document is the following.
Section 1.2 of Chapter 1 shows which kinds of equations are solved and which dimensionless
form of the GPE is used. We then discuss rapidly the classes of problems that GPELab can solve.
A few remarks end Chapter 1.
Chapter 2 explains the numerical techniques that are coded in GPELab for stationary solutions.
Mainly, the method is based on an imaginary time formulation of the problem. The discretization
of the resulting equation uses a semi-implicit Backward Euler (BE) time approximation and a
SPectral scheme in space based on Fast Fourier Transforms (FFTs). The method, called BESP,
is extended to the case of multi-components systems and high rotations values can be considered.
The nonlinearities can be classical like for the cubic case but can also be more complicate when
considering dipole-dipole problems that handle a convolution kernel. Other methods included in
GPELab are based on the Crank-Nicolson approximation scheme in time and the standard (3-points
and 5-points) second-order finite differences scheme in space (for the 1d and 2d cases but not for
the 3d case). We also discuss the possible classical choices of potentials that are met in the physics
of Bose-Einstein condensates (but any other potential can be defined by the user itself) and how to
choose the initial data for evolving the imaginary time method.
In Chapter 3, a simple example of code is given for one complete problem. It explains the general
philosophy of GPELab and shows step-by-step the model code that a user has to define. Next, we
give the full definition of all existing functions inside GPELab, and describe them in details. In
particular, the way the arguments must be defined is carefully explained.
In Chapter 4, we describe how different 1d, 2d, 3d stationary problems can be solved by GPELab.
This provides some generic codes for considering other problems that any user can meet. In par-
ticular, we give a few 1d, 2d and 3d examples including different potentials, nonlinearities, coupled
systems. This offers the possibility of slightly modifying the code if your problem is not far from
one of these examples. In the case of a different problem, we also explain what must be done, in
conjunction with Chapter 3 that gives more insight into the function use.
13
14 CHAPTER 1. INTRODUCTION & INFORMATIONS
The aim of GPELab is to compute both stationary solutions and the dynamics of Bose-Einstein
Condensates (BECs) based on the Gross-Pitaevskii Equation (GPE). We do not want here to
describe the complex physics behind the BECs and GPE but only to state a few well-known facts
about GPE and explain how to rewrite the physical GPE into a dimensionless GPE which is the
model used in GPELab. It is also developed in such a way that the user can define its own equations
and compute its proper physical outputs of interest.
Let us assume that the temperature T is much smaller than the critical temperature T critical .
Then, we can describe a BEC under a rotation effect through a macroscopic wave function ψ
which depends on the spatial variable x := (x, y, z) ∈ R3 , and the time t > 0. This function
has a dynamic which is governed by a specific nonlinear Schrödinger equation, the so-called Gross-
Pitaevskii Equation, given by
∂ψ δE ~2
i~ = (ψ) = Hψ = (− ∆ + V (t, x) + (N − 1)U0 |ψ|2 − ΩLz )ψ. (1.1)
∂t δψ ∗ 2m
The atomic mass is m, ~ is the Planck constant and H is the hamiltonian operator of the system.
δE ∗ being
The notation δψ ∗ designates the functional derivatives of the energy E of the system, ψ
the complex conjugate of ψ. The number of atoms in the condensate is N and Ω is the angular
velocity. The potential function V is an external trap which depends on x but may also depend on
t according to the physical situation. The typical example of potential V is the confining harmonic
(or quadratic potential) trap
m 2 2
V (x) = (ω x + ωy2 y 2 + ωz2 z 2 ), (1.2)
2 x
where ωx , ωy and ωz are the trap frequencies in the directions x, y and z, respectively. The quantity
U0 , defined by
4π~2 as
U0 = , (1.3)
m
describes the interaction between atoms of the condensate, as being the scattering length which is
positive for a repulsive interaction and negative for an attractive interaction. The operator Lz is
such that
Lz = xpy − ypx = −i~(x∂y − y∂x ). (1.4)
This is the z-component of the angular momentum L = x × P, where the momentum operator
P = −i~∇ = (px , py , pz )T . The energy of the functional is defined by
~2
Z
N U0 4
E(ψ) = [ |∇ψ|2 + V |ψ|2 + |ψ| − Ωψ ∗ Lz ψ]dx. (1.5)
R3 2m 2
1
V (x) = (γx2 x2 + γy2 y 2 + γz2 z 2 ), (1.10)
2
setting γx,y,z = ωx,y,z /ωm . The dimensionless energy functional Eβ,Ω is defined by
Z
1 2 2 β 4 ∗
Eβ,Ω (ψ) = |∇ψ| + V |ψ| + |ψ| − Ωψ Lz ψ dx. (1.11)
R3 2 2
In the special case of a disk-shaped condensation, ωx ≈ ωy and ωz ωx . This means that we have:
γx = 1, γy ≈ 1, and γz 1, with ω = ωx .
Then, the 3d GPE reduces to a 2d GPE given by
∂ψ 1
i = (− ∆ + V2 + β2 (x, y)|ψ|2 − ΩLz )ψ, (1.12)
∂t 2
r
γz
where β2 ≈ β2a = and
2π
1
V2 (x, y) = (γx2 x2 + γy2 y 2 ). (1.13)
2
As a conclusion, one may write the GPE in d-dimensions through
∂ψ 1
i = (− ∆ + Vd + βd (x, y)|ψ|2 − ΩLz )ψ, (1.14)
∂t 2
for x ∈ Rd , t > 0, β3 = β and V3 (x, y, z) = V (x, y, z).
• multi-components GPE,
Furthermore, Matlab offers different visualization tools to observe and to represent the solutions of
your calculations. GPELab also provides physical quantities of interest for the user. For beginners,
GPELab is easy to use in many standard situations. For more advanced users, the flexibility of the
code allows you to have your own defined output quantities that are not already contained in the
code.
In terms of performance, GPELab is developed by using an optimized implementation in Matlab.
Furthermore, the algorithms use recent developments in numerical methods. GPELab can also be
used on parallel platforms so that it uses the power of parallel architecture. The time of computation
of one given problem depends strongly of your physical configuration (for example strong nonlinear
interactions or fast rotating gazes) and the computer resources that you can access.
Specifically, we want to make sure that you have the right to give away copies of GPELab, that
you receive source code or else can get it if you want it, that you can change GPELab or use pieces
of GPELab in new free programs, and that you know you can do these things.
To make sure that everyone has such rights, we have to forbid you to deprive anyone else of
these rights. For example, if you distribute copies of GPELab, you must give the recipients all the
rights that you have. You must make sure that they, too, receive or can get the source code. And
you must tell them their rights.
Also, for our own protection, we must make certain that everyone finds out that there is no
warranty for GPELab. If GPELab is modified by someone else and passed on, we want their
recipients to know that what they have is not what we distributed, so that any problems introduced
by others will not reflect on our reputation.
The precise conditions of the license for GPELab are found in the General Public License that
accompanies the source code (see Appendix B [License], page 109). Further information about this
license is available from the GNU Project webpage 1 . Detailed copyright information can be found
in Appendix A [Copyright & credits], page 107.
If you want to integrate parts of GPELab into a closed-source software, or want to sell a modified
closed-source version of GPELab, you will need to obtain a different license. Please contact us
directly for more information.
1
GNU License
18 CHAPTER 1. INTRODUCTION & INFORMATIONS
Chapter 2
1
i∂t ψ(t, x) = − ∆ψ(t, x)+V (t, x)ψ(t, x)+βf (|ψ(t, x)|)ψ(t, x)−ΩLz ψ(t, x), (t, x) ∈ R∗+ ×R2 , (2.1)
2
where ψ is the condensate wave function and R∗+ :=]0; +∞[. The Laplace operator is defined as:
∆ = ∇2 . Function V is the external (usually trapping) potential (for example harmonic). Parameter
β is the nonlinearity strenght which describes the interaction between atoms in the condensate. It
is related to the s-scattering length (as ). It is positive for a repulsive interaction and negative
for attractive interactions. Function f describes the nonlinearity arising in the problem, which
is usually cubic: f (|ψ|) = |ψ|2 but other cases will be considered later. For vortices creation, a
rotating term is added. The operator Lz is defined as the z-component of the angular momentum
L = (px , py , pz )t = x ∧ P, with the momentum operator P = −i∇. In the two-dimensional case and
after some manipulations, its expression is
Two invariants must be satisfied by ψ, after normalization. The mass must be conserved
Z Z
2
N (ψ) = |ψ(t, x)| dx = |ψ(0, x)|2 dx = ||ψ||20 = 1, t > 0, (2.3)
R2 R2
19
20 CHAPTER 2. COMPUTATION OF STATIONARY STATES FOR THE GPE
where ||ψ||0 is the L2 (R2 )-norm of ψ. Another quantity which must be conserved is the energy Eβ,0
that is given by (for a cubic nonlinearity here and a time-independent potential)
Z
1 2 2 β 4 ∗
Eβ,Ω (ψ) = |∇ψ| + V (x)|ψ| + |ψ| − Ωψ Lz ψ dx. (2.4)
R2 2 2
where µ is called the chemical potential of the condensate and φ is a time independent function.
This solution is given as the solution to the nonlinear elliptic equation
1
µφ(x) = − ∆φ(x) + V (x)φ(x) + β|φ(x)|2 φ(x) − ΩLz φ(x), (2.6)
2
under the normalization constraint
Z
||φ||20 = |φ(x)|2 dx = 1. (2.7)
R2
This nonlinear eigenvalue problem can be solved by computing the chemical potential
Z
β
µβ,Ω (φ) = Eβ,Ω (φ) + |φ(x)|4 dx, (2.8)
4 R2
with Z
1
Eβ,Ω (φ) = (|∇φ|2 + V |φ|2 + β|φ|4 − Ωφ∗ Lz φ)dx. (2.9)
R2 2
This also means that the eigenfunctions are the critical points of the energy functional Eβ,Ω over
the unit sphere: S := {||φ||0 = 1}. Furthermore, (2.6) can be seen as the Euler-Lagrange equations
associated with the constraint minimization problem (2.7). Computing the global minimal solutions
φg to the energy functional (2.9) under the normalization constraint
corresponds to obtain a ground state solution while local minima are excited (metastable) states.
This choice can also be considered for the (non-rotating) harmonic potential and a potential of a
stirrer corresponding to a far-blue detuned Gaussian laser beam (toroidal trap) [16, 20, 22]
1 2 2
V (x) = (γx2 x2 + γy2 y 2 ) + w0 e−||x−x0 || /d . (2.13)
2
When a rotation is taken into account, the choice of the initial data is less clear. In [15], Bao et al.
propose to choose, for γx = γy = 1,
with
1 2 2 (γx x + iγy y) −(γx x2 +γy y2 )/2
φho (x) = √ e−(γx x +γy y )/2 , φvho (x) = √ e (2.15)
π π
With the above initial data, ground states for rotating gazes can be obtained for Ω < γxy (while
this is not e.g. the case with (2.12) when the rotating term is too large). In GPELab, all these
possibilities can be found in the GaussianInitialData2d function where the following extended
version is coded:
p
X (1 − Ω)φho (x − x` ) + Ωφvho (x − x` )
φ(x) = , (2.16)
||(1 − Ω)φho (x − x` ) + Ωφvho (x − x` )||0
`=1
with
Two examples of initial data using (2.16)-(2.17) are presented on Figure 2.1 (for the discrete L2 -norm
defined by (2.58) and function L2_norm2d).
Figure 2.1: Two possible gaussian initial data for initializing the iterative scheme (with γx = γy = 1)
and x0 = (0, 0).
22 CHAPTER 2. COMPUTATION OF STATIONARY STATES FOR THE GPE
In the case of a strong linearity, one may also consider the Thomas-Fermi (TF) approximation
of the ground state as initial data. For the 2d case and a quadratic potential, the TF approximate
function is such that
( q
TF (µTβ F − V (x)/βd , if β T F > V (x),
φβ (x) = (2.18)
0, otherwise.
The eigenvalue approximation µTβ F is given by: µTβ F = (4βγx γy /π)1/2 /2. The corresponding func-
tion is Thomas_Fermi2d. An example is given on figure 2.2 More details about these functions as
well as InitialData_Var2d can be found in Section 3.6.6, page 53.
(a) β = 1000
Figure 2.2: Thomas-Fermi initial data for initializing the iterative scheme for potential (2.11) (with
γx = γy = 1).
As already said, many kinds of potentials may be used. This is for example the case of a
harmonic trap (2.11) (quadratic_potential2d function) with a possible added exponential term
like in (2.13) (quadratic_plus_exp_potential2d). Examples of these two potentials are given
below on Figure 2.4. Other possibilities include
1 κ
V (x) = (1 − α) (γx2 x2 + γy2 y 2 ) + (γx2 x2 + γy2 y 2 )2 . (2.19)
2 4
1 2 2 2 2
γx x + γy2 y 2 + V0 e−x /2d .
V (x) = (2.21)
2
Examples of these potentials are given on Figures 2.4-2.3. Clearly, any new initial data or potential
can be added by just following the way the functions are written. More details about the potential
functions in GPELab are given in Subsection 3.6.2, page 45.
2.3. GRADIENT FLOW FORMULATION AND DISCRETIZATION 23
Figure 2.3: Examples Thomas-Fermi approximation for potentials (2.13) (left) and (2.19) (right).
Figure 2.4: Examples Thomas-Fermi approximation for potentials (2.20) (left) and (2.21) (right).
CNGF is a first-order time splitting scheme with discontinuous coefficients. When t tends towards
infinity, φ gives an approximation of the steady state solution which is a critical point of the energy
when the assumption on V is fulfilled (V ≥ 0). The initial guess φ0 is chosen according to the
possible choices provided in section 2.2. Finally, let us remark that, in our notations, we write
φ(x, t) and not φ(t, x) like for the dynamical case to insist on the fact that t is not a real time but
rather a continuation parameter.
setting M ∆t = Tmax , where Tmax is the maximal time of computation and N is the number of time
steps. Let us remark here that Tmax is not known a priori but rather fixed by a stopping criterion
to check the convergence of the iterative scheme towards the ground state solution (see Eq. (2.31)
for example). Until now, GPELab only includes uniform time stepping in time, for a fixed time
step ∆t.
For the numerical purpose, the scheme (2.23) still requires to be space discretized. To this
end, we use a finite difference discretization here. Since the domain is R2 , we have to set suitable
boundary conditions. Here, we impose the homogeneous boundary condition φ̃(x) = 0 for x on
the boundary of a large enough computational box: O :=] − Lx ; Lx [×] − Ly ; Ly [ assuming that the
physics takes place inside this box. Moreover, we introduce the indices of the spatial grid points
(xj , yk ), for (j, k) ∈ DJ,K , setting
with J, K ≥ 3 and uniform discretization steps hx and hy in the x- and y-directions, respectively.
Therefore, for 1 < j ≤ J − 1,
hx = (xj − xj−1 ) = 2Lx /J,
2.3. GRADIENT FLOW FORMULATION AND DISCRETIZATION 25
We associate a matrix [Lz ] to this discrete operator and denote by φn := (φnI(j,k) )(j,k)∈DJ,K the
unknown vector where we assume that the global numbering is made by a local-to-global reordering
procedure based on I(j, k) = j + (J − 1)(k − 1) (which corresponds to using the reshape Matlab
function when coding). Each discrete x- and y-derivative uses the two-points scheme adapted to
the homogeneous Dirichlet boundary condition
φnj+1,k − φnj−1,k φnj,k+1 − φnj,k−1
δx φnj,k = , δy φnj,k = . (2.25)
2hx 2hy
Concerning the GPELab toolbox, the discrete rotational operator (2.24) can be found in the
Two_Points_Rotation2d function. The derivative operators (2.25) are the Two_Points_Gradientx2d
and Two_Points_Gradienty2d functions. These three operators provide square matrices in MMD (C)
with respect to the discretization, with MD := (J − 1)(K − 1).
The Laplacian is discretized thanks to the five-points scheme with homogeneous Dirichlet bound-
ary conditions. The interior scheme is based on
φnj+1,k − 2φnj,k + φnj−1,k φnj,k+1 − 2φnj,k + φnj,k−1
δx2 φnj,k = , δy2 φnj,k = ,
h2x h2y (2.26)
[∆]φnj,k = δx φj,k + δy2 φnj,k , (j, k) ∈ DJ,K .
2 n
The corresponding function for [∆] is named FivePoints_Laplacian2d. It provides the matrix
[∆] ∈ MMP (C) which must be applied to a (global) vector φn := (φnI(j,k) )(j,k)∈DJ,K of size MD .
Finally, the potential is only considered at the discretization points and leads to a diagonal matrix
[V ] ∈ MMP (C), with diagonal elements [V ]I(j,k) .
As a consequence, the spatial discretization of (2.23) leads to the MD × MD linear system with
normalization step
n
[A]φ̃ = b ,
φ̃ (2.27)
φn+1 = ,
||φ̃||0
with
1 1
[A] := [I] − [∆] + [V ] + β[|φn |2 ] − Ω[Lz ],
∆t 2
n
(2.28)
φ
bn := .
∆t
Hereabove, we set: [I] ∈ MMP (C) as the identity matrix and [|φn |2 ] ∈ MMP (C) as the diagonal
(potential) matrix with diagonal terms [|φn |2 ]I(j,k) := |φn |2I(j,k) . For the sake of conciseness, we
denote by || · ||0 the discrete 2-norm of a vector. In the finite difference context, the norm of a vector
φ is simply defined by X
||φ||0 := h1/2 1/2
x hy ( |φj,k |2 )1/2 . (2.29)
(j,k)∈DJ,K
solver choice. This last parameter proposes to solve the linear system by a direct gaussian solver or
by a preconditioned restarted GMRES Krylov subspace solver. The preconditioner is based on the
TF approximation related to the diagonal matrix
1
[M T F ] := [I] + [V ] + β[|φn |2 ]. (2.30)
∆t
• φg the ground state solution at the final time according to the stopping criterion
wthere the tolerance is ε (= 10−8 for example) and where ||φ||∞ is the infinity norm of the
function defined at the discrete level by: ||φ||∞ := sup(j,k)∈DJ,K |φj,k |.
• φ2g (0): the value of the square of the ground state at the origin (used in physics papers)
• xrms and yrms : the radius mean square in the x- and y-directions according to
• Eβ,Ω (φg ): The energy Eβ,Ω (φg ) defined at the continuous level by
Z
1 2 2 β 4 ∗
Eβ,Ω (φ) := |∇φ(x)| + V (x)|φ(x)| + |φ(x)| − <(Ωφ Lz φ) dx (2.33)
R2 2 2
All the discretizations use the previous schemes at the interior nodes based on the trapezoidal
rule. Our function is called: energy_beta_psi_Diff2d.
The GPELab function is chemical_potential and the output is the chemical potential for
the converged function φ. This function is coded in such a way that we do not have to precise
the discretization scheme.
The GPELab function is Angularl_momentum_Diff2d and the output is the angular momen-
tum for the function φ at the converged state.
• The total cputime until convergence for computing the ground state solution by the scheme.
2.3. GRADIENT FLOW FORMULATION AND DISCRETIZATION 27
with J, K ≥ 2 and uniform discretization steps hx and hy in the x- and y-directions, respectively.
Therefore, for 0 < j ≤ J − 1,
hx = (xj − xj−1 ) = 2Lx /J,
and, for 0 < k ≤ K − 1,
hy = (yk − yk−1 ) = 2Ly /K.
The partial Fourier pseudospectral discretizations in the x- and y-directions are respectively given
by
J/2−1
1 X c̃
φ̃(xj , yk , t) = φp (yk , t)eiµp (xj +Lx ) ,
J
p=−J/2
K/2−1
(2.36)
1 X c̃ iλq (yk +Ly )
φ̃(xj , yk , t) = φq (xj , t)e ,
K
q=−K/2
where φp and φq are respectively the Fourier coefficients in the x- and y-directions
c̃ c̃
X J−1
φp (yk , t) = φ̃(xj , yk , t)e−iµp (xj +Lx ) ,
c̃
j=0
K−1
(2.37)
X
φq (xj , t) = φ̃(xj , yk , t)e−iλq (yk +Ly ) ,
c̃
k=0
πp πq
with µp = Lx and λq = Ly . For the backward Euler scheme, this implies that we have the following
spatial approximation BE,n
A φ̃ = bBE,n ,
φ̃ (2.38)
φn+1 (x) = ,
||φ̃||0
where φ̃ = (φ̃(xj,k ))(j,k)∈PJ,K is the discrete unknown array in MMP (C) and the right hand side is
bBE,n := φn /∆t,
with φn = (φn (xj,k ))(j,k)∈PJ,K ∈ MM (C). Here, MMP (C) designates the set of 2D (respectively 1D
and 3D) arrays with complex coefficients, with MP = JK (respectively MP = J and MP = JKL)
in 2D (respectively 1D and 3D). For conciseness, let us remark that we do not make any distinction
between an array φ in MMP (C) and the corresponding reshaped vector in CMP .
The operator ABE,n is given by the map which for any vector ψ ∈ CMP , that is assumed to
approximate (ψ(xj,k )) ∈ CMP for a function ψ, computes a vector Ψ ∈ CMP such that
Ψ := ABE,nψ = ABE,n BE
TF ψ + A∆,Ω ψ,
[[I]]
ABE,n
TF ψ := + [[V ]] + β[[|φn |2 ]] ψ,
∆t (2.39)
1
ABE
∆,Ω ψ := − [[∆]] − Ω[[L z ]] ψ.
2
28 CHAPTER 2. COMPUTATION OF STATIONARY STATES FOR THE GPE
The evaluation of the two above operators is made as follows. For ABE,n
TF , the application is direct
since it is realized pointwize in the physical space by setting
for (j, k) ∈ PJ,K . The symbol δj,k denotes the Dirac delta symbol which is equal to 1 if and
only if j = k and 0 otherwise. Let us note that the discrete operator ABE,nTF is represented by a
diagonal matrix after reshaping. The label TF refers to the fact that this operator is related to the
discretization of the Thomas-Fermi approximation.
On another hand, using (2.36) and (2.37), the differential operators in the x or y direction are
discretized as, ∀(j, k) ∈ PJ,K ,
J/2−1
1 X
([[∂x ]]φ̃)j,k = iµp φp (yk , t)eiµp (xj +ax ) ,
c̃
J
p=−J/2
K/2−1
1 X
([[∂y ]]φ̃)j,k = iλq φq (xk , t)eiλq (yk +ay ) .
c̃
K
q=−K/2
Therefore, we obtain the following pseudo-spectral approximation of the operator Lz on the spatial
grid, ∀(j, k) ∈ PJ,K
([[Lz ]]φ̃)j,k = −i xj ([[∂y ]]φ̃)j,k − yk ([[∂x ]]φ̃)j,k . (2.41)
Another differentiation leads to the second order differential operators in the x or y direction,
∀(j, k) ∈ PJ,K ,
J/2−1
1 X
([[∂x2 ]]φ̃)j,k = −µ2p φp (yk , t)eiµp (xj +ax ) ,
c̃
J
p=−J/2
K/2−1
1 X
([[∂y2 ]]φ̃)j,k = −λ2q φq (xk , t)eiλq (yk +ay ) ,
c̃
K
q=−K/2
The discrete Laplace operator [[∆]] is diagonal in the Fourier space but not [[Lz ]]. Finally, the
discrete || · ||0 norm is given by
X
∀φ ∈ CMP , ||φ||0 := hx1/2 hy1/2 ( |φj,k |2 )1/2 (2.43)
(j,k)∈PJ,K
In practice, the linear system (2.47) is efficiently solved by a Krylov solver (BiCGStab) precon-
ditioned by the TF operator ABE,nTF (see [23]).
In GPELab, the function for computing the ground state by BESP is BESP_CNGF2d for the two-
dimensional case. The operator [[∆]] applied to a vector is given in Delta_Fourier2d, the gradient
operator is Grad_Fourier2d. Other Matlab files can be found in the directory Code2D/FFT but are
nevertheless not useful when you use GPELab. They are transparent for the user and do not really
need to be explained. They generally contain helpful functions for optimizing the BESP method
(for instance preconditioners,...). BESP is the default method used to solve the CNGF in GPELab
(see Section 3.5.1, page 41). The output physical quantities are the same as these provided by the
BEFD scheme (see subsection 2.3.2, page 24).
2.4. CRANK-NICOLSON SCHEMES 29
d
1 X
i∂t Ψ(t, x) = − ∆Ψ(t, x) + V (x)Ψ(t, x) + Gj (x)∂xj Ψ(t, x)
2 (2.49)
j=1
+ d
+βF (Ψ(t, x), x)Ψ(t, x), (t, x) ∈ R × R ,
with initial condition: Ψ(t = 0, x) := Ψ0 (x), and where the operators are defined by
For dipolar gazes, when a nonlocal integral form of the nonlinearity must be considered, then the
user must define himself the corresponding function Fenergy in GPELab.
under the total mass constraint N (Φ) = 1 and where µ(Φ) is the chemical potential given by the
formula
l d
Z Z " # !
X 1 2 ∗
X
k
µ(Φ) = |∇φj (x)| dx + < Φ(x) V (x) + G (x)∂xk + βF (Φ(x), x) Φ(x) dx.
2 Rd Rd
j=1 k=1
Like in the one-component case, we propose to use the CNGF for the multi-components problem
which is a direct extension. Let us denote by t0 < ... < tn < ... the discrete times and by
∆tn = tn+1 − tn the local time step. The Continuous Normalized Gradient Flow is given by
d
1 X
∂ Φ = −∇ E(Φ) = ∆Φ − V (x)Φ − Gj (x)∂xj Φ − βF (Φ, x)Φ, tn < t < tn+1 ,
t Φ∗
2
j=1
Φ(x, t+
) (2.52)
n+1
Φ(x, tn+1 ) = ,
kΦ(x, t+
n+1 )k0
Φ(x, 0) = Φ0 (x).
32 CHAPTER 2. COMPUTATION OF STATIONARY STATES FOR THE GPE
setting M ∆t = Tmax , where Tmax is the time of computation to get the solution satisfying the con-
vergence criterion. Integer M is the number of related time steps. For the spatial discretization,
we extend what is done in the one-component case to the multi-component case by considering the
discrete Laplacian and gradients. The functions are evaluated pointwise on a rectangular uniform
discretization grid, according to the space dimension. For the Finite Difference (respectively SPec-
tral scheme), the resulting method is again called BEFD (respectively BESP). The semi-implicit
Crank-Nicolson scheme is also implemented resulting in the CNFD and CNSP computational meth-
ods.
Let us consider for example the two-dimensional problem and let us denote x by: x = (x, y).
We assume that the support of the evolving field of each component is inside a box
O :=] − Lx ; Lx [×] − Ly ; Ly [.
We consider the uniform grid
OJ,K = {xj,k := (xj , yk ); 0 ≤ j ≤ J − 1, 0 ≤ k ≤ K − 1} ,
J and K being two even positive integers. Furthermore, we introduce the indices of the spatial grid
points (xj , yk ), for (j, k) ∈ DJ,K , setting
DJ,K = (j, k) ∈ N2 ; 1 ≤ j ≤ J − 1 and 1 ≤ k ≤ K − 1 ,
with J, K ≥ 3 and uniform discretization steps hx and hy in the x- and y-directions, respectively,
given by
∆xj = xj+1 − xj = hx = 2Lx /J,
(2.54)
∆yk = yk+1 − yk = hy = 2Ly /K.
Since we assume that all the components are compactly supported in O, then each φl , l = 1, ..., Nc ,
satisfies a periodic boundary condition (which can in fact be put to zero) on ∂O and we can use
discrete Fourier transforms. For BESP, the following approximation holds
ABE,n Φ̃ = bBE,n ,
Φ̃ (2.55)
Φn+1 (x) = ,
||Φ̃||0
2.6. EXTENSION TO THE MULTI-COMPONENTS CASE 33
where Φ̃ = ((φ̃1 (xj,k ))(j,k)∈DJ,K , ..., (φ̃Nc (xj,k ))(j,k)∈DJ,K ) is the discrete unknown array in CM Nc
and the right hand side is
bBE,n := Φn /∆t,
with Φn = ((Φn1 (xj,k ))(j,k)∈DJ,K , ..., (ΦnNc (xj,k ))(j,k)∈DJ,K ) ∈ CM Nc .
The operator ABE,n : CM Nc → Ψ ∈ CM Nc is defined by
ABE,n Φ = ABE,n BE
TF Φ + A∆,Ω Φ,
BE,n [[INc ]] n
ATF Φ := + [[V ]] + β[[F (Φ )]] Φ, (2.56)
∆t
BE 1 1 2
A∆,∇ Φ := − [[∆]] + [[G ]][[∂x ]] + [[G ]][[∂y ]] Φ.
2
and
[[F11 (Φn )]] [[F12 (Φn )]] [[F1Nc (Φn )]]
···
[[F21 (Φn )]] [[F22 (Φn )]] ··· [[F2Nc (Φn )]]
[[F (Φn )]] := .
.. .. .. ..
. . . .
[[FNc 1 (Φn )]] [[F2Nc (Φn )]] · · · [[FNc Nc (Φn )]]
where Φnj,k = (φl (xj,k ))l=1,...,Nc , and [[Vlm ]] = (Vlm (xj,k ))(j,k)∈DJ,K . The matrix ABE
∆,∇ is implicitly
given by the discrete differentiation operators via the FFT
and
[[∂x ]]Φ := ([[∂x φl ]])l=1,...,Nc , [[∂y ]]Φ := ([[∂y φl ]])l=1,...,Nc . (2.57)
We also define
[[Gk11 ]] [[Gk12 ]] [[Gk1Nc ]]
···
[[Gk ]] [[Gk22 ]] ··· [[Gk2Nc ]]
21
[[Gk ]] := , ∀k = 1, 2,
.. .. .. ..
. . . .
[[GkNc 1 ]] [[Gk2Nc ]] · · · [[GkNc Nc ]]
setting [[Gklm ]] = (Gklm (xj,k ))(j,k)∈DJ,K .
Finally, the norm || · ||0 of a discrete vector Φ of Nc components is defined by
XNc
∀Φ ∈ CM Nc , ||Φ||0 := ( ||φl ||20 )1/2 , (2.58)
l=1
For solving (5.28), we again use the preconditioned BiCGStab. Concerning the TF precondi-
tioner, since we have coupling between gazes through [[V ]] and [[F (Φn )]], ABE,n
TF is a nondiagonal
BE,n
matrix. We propose here to extract the diagonal part of ATF to build the preconditioner, which
means that we only consider potential and nonlinear effects in each single-component. Concretely,
we build the following diagonal TF preconditioner PBE,n
TF,diag given by
[[INc ]]
PBE,n
TF,diag := + [[Vdiag ]] + β[[Fdiag (Φn )]]
∆t
where [[Vdiag ]] := ([[Vll ]])l=1,...,Nc and [[Fdiag ]] := ([[Fll (Φn )]])l=1,...,Nc .
We can also directly inverse the matrix ABE,n TF . First, we remark that this matrix is composed
of diagonal block matrices. The following formula can be used to directly compute the inverse of a
block matrix −1 −1
A + A−1 BS −1 CA−1 −A−1 BS −1
A B
=
C D −S −1 CA−1 S −1
where A, B, C, D are diagonal matrices and S = (D − CA−1 B) is the Schur complement of A,
assuming that A can be inverted. We note that the result of this computation is still a matrix
composed of diagonal block matrices. By using recursively this formula for the smaller blocks of
the matrix −1 −1
Ap + A−1 −1 −1 −A−1 B S −1
−1 Ap B p p Bp Sp Cp Ap p p p
Ap+1 = =
Cp D p −Sp−1 Cp A−1
p Sp−1
where Sp = (Dp − Cp A−1p Bp ) and p is the level of recursity, we are able to compute the inverse of
BE,n
the block matrix ATF . Therefore, we can build the full TF preconditioner
−1
[[INc ]]
PBE,n
TF,full := n
+ [[V ]] + β[[F (Φ )]]
∆t
Chapter 3
GPELab is a flexible Matlab toolbox which is able to compute the stationary solution and dynamics
of Gross-Pitaevskii equations. The physical description of the equations that are defined and the
mathematical algorithms are those described in the previous Chapters for the stationary situation.
The code offers the possibility to compute solutions to multi-components BECs and to get physical
important quantities. GPELab works through a main program that calls solvers corresponding to
efficient and robust accurate numerical methods developed in the present document. From the point
of view of the standard user, only this main program has to be modified. Furthermore, for more
complex problems, the advanced user can defined his own physical inputs (potential, nonlinearity,
number of components...) and outputs (new physical interesting quantities...). The user can also
manipulate the computed quantities and draw figures or create movies in relations to its calculations,
thanks to Matlab functions and already defined and well adapted GPELab visualization functions.
Finally, GPELab also provides the possibility to include stochastic effects into the computations for
example in the potential.
The aim of this chapter is to introduce the way GPELab works when you want to compute
stationary solutions and to detail some functions related to this class of problems.
35
36 CHAPTER 3. HOW TO USE GPELAB: STATIONARY SOLUTIONS
ε := 10−6 . Concerning the geometry, the computational domain is O :=] − 10, 10[×] − 10, 10[ and
the number of grid points (including the boundary points) is set to Nx = 28 + 1 and Ny = 28 + 1.
We can see on Figure 3.1 how it is coded in GPELab.
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 1e-2;
Stop_time = [];
Stop_crit = 1e-6;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -10;
xmax = 10;
ymin = -10;
ymax = 10;
Nx = 2^8+1;
Ny = 2^8+1;
Geometry2D = Geometry2D_Var2d(xmin,xmax, ymin,ymax, Nx, Ny);
Table 3.1: An example of Method and Geometry2D in GPELab for computing a ground state.
The next step is to define the physical problem. In our case, we want to compute the ground
state of the Gross-Pitaevskii equation
1
|x|2 + |y|2 Ψ(x, y, t) + β|Ψ(x, y, t)|2 Ψ(x, y, t)
i∂t Ψ(x, y, t) = δ∆Ψ(x, y, t) +
2
+iΩ (y∂x − x∂y ) Ψ(x, y, t),
with δ = 0.5, β = 300 and Ω = 0.7. GPELab is designed in such a way that the user may define
and add operators of the following types: a potential operator, a nonlinear operator and gradient
operators. The potential operator and the nonlinear operator are functions of the space variables
(and the wave function for the nonlinear operator) that are multiplied by the wave function. The
gradient operators are defined by functions that are multiplied by the partial derivative of the wave
function in the space directions. In our case, we identify
• the potential function: V (x, y) = 12 |x|2 + |y|2 ,
Delta = 0.5;
Beta = 300;
Omega = 0.7;
Physics2D = Physics2D_Var2d(Method,Delta,Beta);
Physics2D = Potential_Var2d(Method, Physics2D, @(x,y) (1/2)*(x.^2+y.^2));
Physics2D = Nonlinearity_Var2d(Method, Physics2D, @(phi,x,y) abs(phi).^2 );
Physics2D = Gradientx_Var2d(Method, Physics2D,@(x,y) 1i*Omega*y);
Physics2D = Gradienty_Var2d(Method, Physics2D,@(x,y) -1i*Omega*x);
Table 3.2: An example of how to define the Physics in GPELab through the Physics2D structure.
set the initial data themselves. However, the function InitialData_Var2d is helpful if one wants to
use standard initial data like the centered gaussian or the Thomas-Fermi approximation (see Section
2.2, page 20). We would like in our case to use the Thomas-Fermi approximation as an initial wave
function for the computation. This is done by setting the InitialData_choice variable to 2 as we
can see this in Table 3.3.
InitialData_choice = 2 ;
Phi_0 = InitialData_Var2d(Method, Geometry2D, Physics2D,InitialData_choice);
Finally, we want to launch the simulation. We would like to get informations about the wave
function during the computations, for example to be sure that the energy is diminishing. Thus, we
need to build the Outputs structure, that contains all the outputs computed during the simulation.
Some outputs like the energy or the mean square radius are already defined and stored when
computing. Moreover, to print these informations during the calculations, we have to build the
Print structure that ”explains” how to print the outputs. For example, in Table 3.4, we ask to print
the informations every 15 iterations and to draw the solution.
Outputs = OutputsINI_Var2d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var2d(Printing,Evo,Draw);
We are now ready to launch the simulation. This is done by using the GPELab2d function, which
gather all the previous structure (and thus the informations about the simulation). The command
is given in Table 3.5.
[Phi,Outputs]= GPELab2d(Phi_0,Method,Geometry2D,Physics2D,Outputs,[],Print);
(a) Modulus of the ground state. (b) Phase of the ground state.
Figure 3.1: Ground state computed with GPELab using the parameters from Section 3.2.
As we have seen with this example, using GPELab is quite easy and direct. We report more
complex examples in Chapter 4 for different physical situations involving: ground states, dynamics,
1d-2d-3d problems, multi-components gazes...
• Matrix type: Matrices are the basic variables of Matlab. A matrix is a multi-dimensional
array of integers, real or complex numbers... To access a certain element of a matrix, the
indexation must be done using parentheses
A = [1.3,-2;3.6,4.3];
A =
1.3 -2.
3.6 4.3
»
Basic operations such as additions or multiplications for matrices are implemented in Matlab.
Moreover, the element wise operations are done by adding a dot before the symbol of the
operation. To initialize a matrix, one can choose the zeros function that will initialize a
matrix of zeros.
• Cell type: Cells are variables that gather elements of Matlab such as matrices, functions or
strings.
1
http://www.mathworks.fr/fr/help/matlab/
3.4. NOTATIONS AND PRELIMINARY REMARKS 39
A = [1,2;3,4];
B = [1,2;2,1];
A.*B
ans =
1 4
6 4
»
A = {1,’string’;3,[1,1;2,1]};
A =
[1] ’string’
[3] [2x2 double]
»
They use the same indexation as matrices and to access a certain element of a matrix, the
indexation must be done using curly brackets. However, due to the fact that cells gather
elements such as strings, basic operations are of course not implemented in Matlab.
A = {1,’string’;3,[1,1;2,1]};
A{1,2}
ans =
string
»
• Function: Functions are scripts written in a simple way. They are defined as variables,
making them more direct to create, to use and to manipulate than a script written in a *.m
function file. To define a function, one has first to give the input arguments then write the
script.
f = @(x,y,a,b) x*strcmp(a,b)+y;
f(2,3,’world’,’phone’)
ans =
3
»
• Structure type: Structures are variables that simply gather variables. Contrary to cells,
there is no indexation and the access is done by directly naming the variables.
S.temperature = 32;
S.computer = ’office’
S =
temperature: 32
computer: ’office’
S.computer
ans =
’office’
»
• Nx , Ny , Nz : these parameters are equal to the number of degrees of freedom (dof) of the
numerical method that is considered, in the x-, y- and z-directions, respectively. We emphasize
here on the fact that these are not equal to N x , N y and N z which designate the total number
of grid points, including the boundary points. For the FD scheme, the number of dof is
Nx = N x − 2 in the x-direction and Nx = N x − 1 for the SP scheme. In example 3.1, page
36, N x = 28 + 1 but the number of dof is Nx = 28 which optimizes FFTs computations.
Furthermore, let us consider the different sets of variables below that must be used when con-
sidering the corresponding Matlab variables in GPELab
We also need the set of strings of characters that we designate by S and the set of Matlab structures
denoted by S.
We now introduce K = ×N M
j=1 Kj and L = ×`=1 L` , where Kj and L` are two sets of variables
like the ones defined above. In the sequel, we use the following notations
where (x1, x2, ..., xN ) ∈ K1 × K2 × ... × KN . More generally, we also sometimes use the
notation F(K p ; L) = F(K, ..., K; L), if K is repeated p times.
Let us consider any input variable xj in a set Kj of a function f. In GPELab, all inputs of f
have already default values xjdefault that can be modified. For clarity, in the sequel, we designate
this by the notation: xj (Kj , xjdefault ).
We essentially detail the Matlab functions for the two-dimensional case. Unless precise, the
extension from the 2d to the 1d and 3d cases is done by changing the functions’ names. For
example, the Method_Var2d function corresponds to the Method_Var1d function in 1d and to the
Method_Var3d function in 3d. If changing the dimension implies any modification of the number or
3.5. SETTING THE NUMERICAL SCHEME AND THE GEOMETRY 41
the nature of the input or output arguments of the function, then we will precise it. Concerning the
form of the variables x, y and z, we use the standard meshgrid ordering of variables. More precisely,
this means that x ∈ M1,Nx (K) in the 1d case, x, y ∈ MNy ,Nx (K) in the 2d case and x, y, z are in
MNy ,Nx ,Nz (K) for the 3d case. Here, K = R. The same situation occurs when computing the set
of frequencies (for example to compute nonlocal nonlinear interactions like for dipolar gazes) but
K = C.
The Method_Var2d function creates the Method structure that contains all the parameters rel-
ative to the method. By method, we mean the solver which is used to compute a solution. This
includes the kind of computation (dynamics or ground state), the number of components, the type
of scheme (BESP, BEFD, CNSP, CNFD for the ground state and Relaxation, Splitting for the
dynamics), the semi discretization parameters and other inputs that we explain below. The only
output is the structure Method. As seen above, the input variable of Method_Var2d have already
default values that may be modified. The optional arguments are the following
• Type (S, ’BESP’) is a variable corresponding to the scheme used in the computation. In
the case of a ground state computation, it must be either ’BEFD’ to use the Backward Euler
Finite Difference scheme (see section 2.3.2), ’CNFD’ to use the Crank-Nicolson Finite Difference
scheme (see section 2.4), ’BESP’ to use the Backward Euler SPectral discretization scheme
(see section 2.3.3) or ’CNSP’ to use the Crank-Nicolson SPectral discretization scheme (see
section 2.4).
• Deltat (R+ ,1e-3) is a variable corresponding to the time step of the method. The time
discretization is always uniform.
• Stop_time (R+ ,1) is a variable corresponding to the final time of computation in the case of
a dynamic problem (see section 5.5.1).
• Max_iter (N, 1e6) is a variable corresponding to the maximum number of iterations for a
stationary state computation.
42 CHAPTER 3. HOW TO USE GPELAB: STATIONARY SOLUTIONS
• Output (N,1) is a variable that must either be 1 if one computes outputs during the compu-
tations or 0 if not.
• BESP (N,0) is a variable that must be either 1 if one uses the Jacobi method or 0 for the Krylov
method, for the BESP scheme.
• Solver_FD (N,0) is a variable that must be either 1 if one uses the direct Gauss solver from
Matlab (i.e. backslash \) or 0 for the Krylov method.
• Iterative_tol (R+ , 1e-9) is a variable corresponding to the stopping criterion related to the
difference between two successive iterates in the Krylov solver.
For example, we want to compute a stationary solution for a single-component BEC by using
the BESP scheme. We choose a time step ∆t = 10−2 and a stopping criterion for ε = 10−8 . We set
the maximal number of iterations to 106 and we choose to compute outputs during the simulation.
This gives the code in table 3.13.
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 1e-2;
Stop_time = [];
Stop_crit = 1e-8;
Max_iter = 10e6;
Precond_type = ’None’;
Output = 1;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time, Stop_crit,
Max_iter, Precond_type, Output;
The aim of the Geometry2D_Var2d.m function is to create the Geometry2D structure which
contains the size of the computational box and the number of points in each spatial direction
(including the boundaries). Note that the spatial domain is always rectangular with a uniform
mesh grid. The output is the Geometry2D structure. As for the Method_Var2d function, this
function includes default values for the input arguments. The optional arguments are the following
• xmin (R,-10) is a variable corresponding to the left endpoint of the computational domain in
the x-direction.
• xmax (R,10) is a variable corresponding to the right endpoint of the computational domain in
the x-direction.
• ymin (R,-10) is a variable corresponding to the lower endpoint of the computational domain
in the y-direction.
• ymax (R,10) is a variable corresponding to the upper endpoint of the computational domain
in the y-direction.
• Nx (N,2^7+1) is a variable corresponding to the number of points in the x-direction.
• Ny (N,2^7+1) is a variable corresponding to the number of points in the y-direction.
In the case of a 1d simulation, one has to discard ymin, ymax and Ny. Moreover, in the case of
a 3d simulation, one must add zmin and zmax after ymax and Nz after Ny.
If one wants to take a larger computational box [−15, 15] × [−15, 15] and a large number of grid
points Nx = Ny = 29 + 1 to use a spectral scheme, then one builds the Geometry2D structure as in
table 3.15.
xmin = -15;
xmax = 15;
ymin = -15;
ymax = 15;
Nx = 2^9+1;
Ny = 2^9+1;
Geometry2D = Geometry2D_Var2d(xmin, xmax, ymin, ymax, Nx, Ny);
This system corresponds to the one developed in Section 2.6, page 30. Here δ, β are two real-valued
constants in R. The energy for each component is set as
Z
Ej (Ψ) = δ |∇ψj (t, x)|2 dx
R d
Z " d
# !
X
+ < ψ(t, x)∗j V(x) + Gk (x)∂xk + Fenergy (Ψ(t, x), x) Ψ(t, x) dx,
Rd k=1 j
(3.2)
for each j ∈ {1, ..., Nc }, and the chemical potential for each component is set as
Z
µj (Ψ) = δ |∇ψj (t, x)|2 dx
Rd !
d (3.3)
Z " #
X
+ < ψ(t, x)∗j V(x) + Gk (x)∂xk + F(Ψ(t, x), x) Ψ(t, x) dx,
Rd k=1 j
Physics2D = Physics2D_Var2d(Method,Delta,Beta,Omega);
The Physics2D_Var2d function builds the Physics2D structure and enables the user to define the
basic physical constants δ, β and the rotation speed Ω (if the gradients operators are set as default
(see section 3.6.5)). The Physics2D structure also contains the physical operators as explained
below. The Method structure is a required argument and the optional arguments are the following
• Delta (R,1/2) is a variable corresponding to the constant of the Laplacian operator i.e. δ in
equation (3.1).
• Beta (R,0) is a variable corresponding to the constant in front of the nonlinearity (β in
equation (3.1)).
• Omega (R,0 or M1,3 (R),0) is a variable that defines the rotation speed if the default gradient
operators ((x∂y − y∂x ) in 2d, or (x × ∇) in 3d) are present in the equation (otherwise, it has
no effect). It is a real-valued parameter (Ω ∈ R) in the 2d case or a vector (Ω ∈ M1,3 (R))
in the 3d case. We note that this variable does not exist in the 1d situation. If the default
gradient operators are set, then we have the following rotation operators
Ω (x∂y − y∂x ) 0 ··· 0
2
X 0 Ω (x∂y − y∂x ) · · · 0
Gj (x)∂xj = ,
.. .. .. ..
j=1
. . . .
0 0 ··· Ω (x∂y − y∂x )
in the 2d physical problem, and
Ω · (x × ∇) 0 ··· 0
3
X 0 Ω · (x × ∇) · ·· 0
Gj (x)∂xj = ,
.. .. .. ..
j=1
. . . .
0 0 ··· Ω · (x × ∇)
for the 3d case.
3.6. SETTING THE PHYSICAL PROBLEM 45
We remind that in the case where one puts a rotational operator, with a rotation speed ranging
from 0 to 1 excluded, then a quadratic potential (V (x) ≈ |x|2 ) is enough to compensate the
centrifugal force. However, for a rotation speed larger than 1, one must use a stronger potential,
for example a quartic potential (V (x) ≈ |x|4 ). In table 3.17, we show the code where we create the
Physics2D structure with δ = 21 , β = 1000 and Ω = 0.7.
Delta = 0.5;
Beta = 1000;
Omega = 0.7;
Physics2D = Physics2D_Var2d(Method,Delta,Beta,Omega);
The Potential_Var2d function allows to define the time-independent potential operator (i.e.
V(t, x) = V(x)) in the problem by modifying the Physics2D structure. It must be provided with
the Method and Physics2D structures. The optional arguments are the following
• Potential: If a function Potential in F(MNy ,Nx (R)2 ; MNy ,Nx (C)) is provided, the physical
potential is defined as follow, for each j, k ∈ {1, ..., Nc },
Potential(x, y) if j = k
Vj,k (x, y) =
0 if j 6= k
Note that in the case of a stationary state computation, the potential operator should be
time-independent.
• G (MNc ,Nc (C), ones(N_c)) is a complex variable that multiplies the potential element-by-
element, leading to the following potential
For example, we want to set a quadratic potential for the computation of a ground state for
a multi-components BEC with internal atomic Josephson junction, as in [17] where the system of
two-components Bose-Einstein condensate is modeled by the following system of equations
1 2 2
i∂t ψ1 = − 2 ∆ + V (x) + δ + (β11 |ψ1 | + β12 |ψ2 | ) ψ1 + λψ2 ,
1 2 2
i∂t ψ2 = − ∆ + V (x) + (β22 |ψ2 | + β12 |ψ1 | ) ψ2 + λψ1 ,
2
where δ is the detuning constant for the Raman transition, βjk are the interactions constants and
λ is the effective Rabi frequency.
Thus we have to build a potential operator, where the diagonal terms are quadratic potentials
(plus the detuning constant δ for the first component) and the extradiagonal terms are the effective
Rabi frequency λ. To this end, we have to create a cell array of functions and then we modify the
Physics2D structure to define the potential operator, as it is done in table 3.19.
function P = Example_potential(Detuning_constant,Rabi_frequency)
P = cell(2);
P{1,1} = @(x,y) (1/2)*(x.^2+y.^2)+Detuning_constant;
P{1,2} = @(x,y) Rabi_frequency;
P{2,1} = @(x,y) Rabi_frequency;
P{2,2} = @(x,y) (1/2)*(x.^2+y.^2);
end
Detuning_constant = 1;
Rabi_frequency = -5;
Physics2D = Potential_Var2d(Method, Physics2D, ...
Example_potential(Detuning_constant,Rabi_frequency) );
The Nonlinearity_Var2d function allows to define the nonlinear term, i.e. F(Ψ(t, x), x), in the
problem by modifying the Physics2D structure. Note that in GPELab, the solution of the system
is defined as a cell array of matrices (CNc ,Nc {MN y,N x (C)}). This function must be provided with
the Method and Physics2D structures and it has the following optional arguments
F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 ; MNy ,Nx (C))
is given, the physical nonlinearity will be defined as follows, for each j, k ∈ {1, ..., N },
Nonlinearity(Ψ(t, x), x, y) if j = k
Fj,k (Ψ(t, x), x, y) =
0 if j 6= k
3.6. SETTING THE PHYSICAL PROBLEM 47
CNc ,Nc {F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 ; MNy ,Nx (C))},
• G (MNc ,Nc (C), ones(N_c)) is a complex-valued variable that multiplies the nonlinearity
element-by-element, leading to the following nonlinearity definition
F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 ; MNy ,Nx (C))
is given, the nonlinear energy operator is defined as follows, for each j, k ∈ {1, ..., N },
Nonlinearity_energy(Ψ(t, x), x, y) if j = k
(Fenergy )j,k (Ψ(t, x), x, y) =
0 if j 6= k
If Nonlinearity_energy is a cell array of function in
CNc ,Nc {F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 ; MNy ,Nx (C))}
This way of proceeding allows us to continue the example from Section 3.6.2, page 45, where
we set a potential in the case of an internal atomic Josephson junction. We also need to define
the coupled nonlinearities if we want to effectively take into account all the effects in the system
of equations [17]. In the case of a two-components Gross-Pitaevskii equation with a Josephson
junction, we have
F11 (Ψ(t, x), x) = β11 |ψ1 |2 + β12 |ψ2 |2 ,
function NL = Example_nonlinearity(Beta_11,Beta_22,Beta_12)
NL = cell(2);
NL{1,1} = @(Phi,x,y) Beta_11*abs(Phi{1}).^2 + Beta_12*abs(Phi{2}).^2;
NL{2,2} = @(Phi,x,y) Beta_22*abs(Phi{2}).^2 + Beta_12*abs(Phi{1}).^2;
NL{1,2} = @(Phi,x,y) 0;
NL{2,1} = @(Phi,x,y) 0;
end
Beta_11 = 2;
Beta_12 = 1;
Beta_22 = 2;
Physics2D = Nonlinearity_Var2d(Method, Physics2D, ...
Example_nonlinearity(Beta_11,Beta_22,Beta_12));
In the case where one wants to consider a nonlocal (integral-type) nonlinearity in the GPE, this
can be done in GPELab by using the Fourier transform. The aim is to be able to define general
nonlinear interactions through the representation formula
for j, k ∈ {1, ..., Nc }. For each j, k, the symbol Kj,k (x, ξ) is a Matlab function in
Here above, fft and ifft designate the FFT and inverse FFT in Matlab, respectively. The symbol
.∗ is the point wise multiplication of arrays in Matlab. For example, if one wants to compute a
convolution form (like in a one-component dipolar gaz)
where K is the Fourier transform of the kernel K. Another example is the derivation operator ∂x
which has symbol −iξx . A full example is given in Section 4.7, page 79. We remark that this
function is effective only in the case of spectral schemes.
The FFTNonlinearity_Var2d function allows to define the nonlinear operator (i.e. F(Ψ(t, x), x)
in our equation) in the problem. To this end, it modifies the Physics2D structure. The Method and
Physics2D structures are required arguments and the optional arguments are the following
3.6. SETTING THE PHYSICAL PROBLEM 49
F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 , MNy ,Nx (C)2 ; MNy ,Nx (C)),
the physical nonlocal nonlinearity is such that, for each j, k ∈ {1, ..., Nc },
FFTNonlinearity(Ψ(t, x), x, y, ξx , ξy ) if j = k
Fj,k (Ψ(t, x), x, y) =
0 if j 6= k
where ξx and ξy are the discrete Fourier frequencies in the x- and y-directions, respectively.
If FFTNonlinearity is given by a cell array of functions in
CNc ,Nc {F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 , MNy ,Nx (C)2 ; MNy ,Nx (C))},
• G (MNc ,Nc (C), ones(N_c)) is a variable that multiplies the nonlocal nonlinearity element-by-
element, leading to
F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 , MNy ,Nx (C)2 ; MNy ,Nx (C))
is given, the nonlocal nonlinear energy operator is, for each j, k ∈ {1, ..., Nc },
FFTNonlinearity_energy(Ψ(t, x), x, y, ξx , ξy ) if j = k
(Fenergy )j,k (Ψ(t, x), x, y) =
0 if j 6= k
CNc ,Nc {F(CNc ,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 , MNy ,Nx (C)2 ; MNy ,Nx (C))}
A standard example of nonlocal nonlinearity comes from the dipolar interaction. This interaction
is usually described in 3d, however, a reduction to the 2d case is possible. The dipolar interaction
in the 2d case with a single component ψ is given by (see [18])
√ 2
F (ψ(t, x), x) = F −1 2 − 3 π|ξ|e|ξ| erfc(|ξ|) F |ψ(t, x)|2 ,
where erfc is the complementary error function2 . This nonlinearity can be easily implemented by
using a Matlab script. This is done in table 3.22 where we define the previous nonlocal nonlinearity
which is then added to the Physics2D structure by using the FFTNonlinearity_Var2d.m function.
Table 3.22: An example of application of the FFTNonlinearity_Var2d function with the dipolar
operator.
2
http://www.mathworks.fr/fr/help/matlab/ref/erfc.html
3.6. SETTING THE PHYSICAL PROBLEM 51
The gradient functions allow to define the derivation operators dj=1 Gj (x)∂xj in the problem
P
by modifying the Physics2D structure. Here, we take for example the function Gradientx_Var2d,
as the other gradient functions work similarly. We remark that we can only define Gradientx in
1d, Gradientx and Gradienty in 2d and Gradientx, Gradienty and Gradientz in 3d. The Method
and Physics2D structures are required arguments. It is possible to include the following optional
arguments
• Gradientx: Let us provide a function Gradientx in
for j, k ∈ {1, ..., Nc }. The default argument is the part of the rotational operator corresponding
to
1 iΩy if j = k
Gj,k (x, y) =
0 if j 6= k
for the Gradientx_Var2d function, where Ω is to the rotational speed defined in the Physics2D
structure, i.e. Omega (∈ R). In the case of the Gradienty_Var2d function, we have
2 −iΩx if j = k
Gj,k (x, y) =
0 if j 6= k
Note that in the 1d case, the default argument is
G1j,k (x) = 0.
• G (MNc ,Nc (C), ones(N_c)) is a variable that multiplies the gradient operator element by
element
G1j,k (x, y) = G(j, k)Gradientx{j, k}(x, y)
for j, k ∈ {1, ..., Nc }.
An interesting case of coupling between Gross-Pitaevskii equations is the Rashba coupling. For
example, in the case of a system of two Gross-Pitaevskii equations with a quadratic potential, a
coupled cubic nonlinearity and a Rashba coupling, we obtain the following equations
1 2 2
i∂t ψ1 = − ∆ + V (x) + (β11 |ψ1 | + β12 |ψ2 | ) ψ1 − κ (i∂x + ∂y ) ψ2
2
1 2 2
i∂t ψ2 = − ∆ + V (x) + (β22 |ψ2 | + β12 |ψ1 | ) ψ2 − κ (i∂x − ∂y ) ψ1
2
where V (x) = 12 x2 + y 2 is the quadratic potential, βjk are the interactions constants and κ is
the intensity of the Rashba coupling. For defining the operator effect, we have to set the derivation
operators such that the gradient operators are
1 0 −iκ
G (x, y) = ,
−iκ 0
2 0 −κ
G (x, y) = .
κ 0
In GPELab, we thus have to create a cell array of functions and use the Gradientx_Var2d and
Gradienty_Var2d functions like in Table 3.24 to add the Rashba coupling to a system of two
Gross-Pitaevskii equations.
The InitialData_Var2d function builds an initial wave function (i.e. Ψ0 (x)) for the simu-
lations. Already defined initial data corresponding to the Thomas-Fermi approximation or the
centered Gaussian are existing in GPELab. Note that the user can also create its own initial wave
function without using this function. The Method, Geometry2D and Physics2D structures are needed
arguments for the function. Optional arguments are
• InitialData_Choice (N,1) is a variable that must be either 1 if one uses centered gaussians or
2 for Thomas-Fermi approximations as initial data. The option 3 allows to use the imaginary-
time method with the BESP scheme to compute ground-states for each component where the
operators are restricted to their diagonal parts (i.e. the components are decoupled).
• X0,Y0 (M1,Nc (R), 0) are variables corresponding to the coordinates of the center of the gaus-
sian or Thomas-Fermi approximation as initial data. We note that, in the 1d case, we only
have to define X0 and, in the 3d case, Z0 is required.
• gamma_x, gamma_y (R, 1) are variables corresponding to the parameters of the centered gaus-
sian. We note that, in the 1d case, we only have to define gamma_x and, in the 3d case, we
have to add gamma_z.
For example, if we want to compute a Thomas-Fermi approximation for initial data, we proceed
as in table 3.26.
InitialData_Choice = 2;
Phi_0 = InitialData_Var2d(Method, Geometry2D, Physics2D, InitialData_Choice);
The OutputsINI_Var2d function initializes the outputs of a simulation by building the Outputs
structure. Outputs are scalar values computed using each component of the wave function during
the simulation. In GPELab, the predefined outputs are: the modulus of the wave function at the
center of the domain, the root mean-square in each direction, the energy, the chemical potential
and the angular momentum. More outputs can be computed by using user-defined functions. The
outputs are computed and displayed in the command window at each iteration incremented by
the value of the Evo_outputs variable. They are also stored after the simulation in the Outputs
54 CHAPTER 3. HOW TO USE GPELAB: STATIONARY SOLUTIONS
structure (see the GPELab2d function, Section 3.7.6, page 60). The Method structure is a required
argument of this function. Concerning the optional arguments, we have
C1,nLout {F(MNy ,Nx (C), MNy ,Nx (R)2 , MNy ,Nx (C)2 ; R)}
that allows the user to define itself nLout relevant physical output quantities. These quantities
are computed through nLout Matlab functions that the user must write himself under the form
(ψ` (t, x), x, y, ξx , ξy ) → userdef_outputs{j}(ψ` (t, x), x, y, ξx , ξy )
for j ∈ {1, ..., nLout }, where ξx and ξy are the discrete Fourier frequencies in the x- and y-
directions. We remark that userdef_outputs must have (ψ` (t, x), x, y, ξx , ξy ) as arguments
only in the case where a spectral scheme is used. Otherwise, the arguments are (ψ` (t, x), x, y).
By default, there is no other output computed than the predefined ones.
• userdef_outputs_names (C1,nLout {S},’User defined function’) is a cell array of character
strings, where the j-th component corresponds to the name displayed in the command window
of the j-th physical quantity appearing in userdef_outputs.
• globaluserdef_outputs is a cell array of functions in
C1,nGout {F(C1,Nc {MNy ,Nx (C)}, MNy ,Nx (R)2 , MNy ,Nx (C)2 ; R)}
that defines nGout relevant physical output quantities. We remark that, compared with the
previous variable userdef_outputs, these physical quantities can be defined through expres-
sions involving the full wave function Ψ and not only its one-by-one components. They are
evaluated through nGout Matlab functions that must be of the form
(Ψ(t, x), x, y, ξx , ξy ) → globaluserdef_outputs{j}(Ψ(t, x), x, y, ξx , ξy )
for j ∈ {1, ..., nGout }, where ξx and ξy are the discrete Fourier frequencies in the x- and
y-directions. We remark that globaluserdef_outputs must have (ψ` (t, x), x, y, ξx , ξy ) as
arguments only in the case where a spectral scheme is used. Otherwise, the arguments are
(ψ` (t, x), x, y). By default, there is no predefined output quantity in GPELab which means
that the user must define its own functions.
• globaluserdef_outputs_names (C1,nGout {S},’User defined function’) is a variable that
has the same role as userdef_outputs_names but for globaluserdef_outputs.
Let us assume that we launch a simulation that ends after Niter iterations. Therefore, the
outputs are computed
Niter
Nout = Int +1
Evo_outputs
times at tk := k Evo_outputs ∆t, 1 ≤ k ≤ Nout , and tNout +1 = Niter ∆t. In the above equation,
Int[[r]] designates the integer part of a real-valued number r. The resulting Outputs structure has
the following variables
3.7. LAUNCHING THE SIMULATION... 55
• Solution (C1,Nout {C1,Nc {MNy ,Nx (C)}}) contain the computed solutions for times tk if save =
1.
• phi_abs_0 (C1,Nc {M1,Nout (R)}) is a cell array of vectors that contains the values of the square
modulus of each wave function ψ` at the center of the domain for times tk
where x_max, x_min, y_max and y_min have been defined by the Geometry2D_Var2d function
(see subsection 3.5.2, page 43).
• x_rms, y_rms (C1,Nc {M1,Nout (R)}) is a cell array of vectors containing the values of the root
mean-square of each wave function ψ` with respect to the x- and y-directions. They are
computed by
Z 1/2
x_rms{`}(k) = x2 |ψ` (tk , x, y)|2 dxdy
O
and Z 1/2
2 2
y_rms{`}(k) = y |ψ` (tk , x, y)| dxdy .
O
Energy{`}(k) = E` (Ψ)(tk )
Chemical_potential{`}(k) = µ` (Ψ)(tk )
• User_defined_local (C1,nLout {M1,Nout (R)}) are the user defined functions userdef_outputs.
For example, if one wants to compute the L2 -norm of the gradient of each component of a
Bose-Einstein condensate on the computational domain
Z
Grad_norm = |∇ψ(t, x)|2 dxdy,
O
one has to first define a function that computes the L2 -norm of the gradient by using a FFT and
then create the Outputs structure by using the OutputsINI_Var2d function with the function as
argument. This is done in table 3.28.
56 CHAPTER 3. HOW TO USE GPELAB: STATIONARY SOLUTIONS
Table 3.28: An example to use the OutputsINI_Var2d function for a user-defined function with a
single-component.
However, if one wants to compute the root mean-square of the sum of two components
Z
RMS = (|x|2 + |y|2 )|ψ1 (t, x) + ψ2 (t, x)|2 dxdy,
O
one has to proceed differently because a function computing the root mean-square of the sum of
two components takes the cell vector of the two wave functions as argument. Therefore, we have to
use globaluserdef_outputs. We show how to do this in table 3.29.
Table 3.29: An example to use the OutputsINI_Var2d function for a user-defined function with
multi-components.
The Continuation_Var2d function allows to define what continuation means in GPELab when
you want to compute a stationary state. By continuation, we mean that the computation is
initialized by an initial state, and then doing loops on a chosen parameter p ∈ C1,ncont {C} or
C1,ncont {MNc ,Nc (C)}, where ncont is the total number of iterations. At each iteration k, the new
initial state is taken to be equal to the stationary state computed at the previous iteration k − 1.
The continuation continues until the end of the loop and gives a stationary state solution at the
final iteration ncont . This way of proceeding is expected to provide at the end of the calculations a
ground state solution through small increments of the parameter p at the iteration k.
In addition, the Continuation_Var2d function allows to define a multi-parameter continuation
path. More precisely, let us assume that the Continuation_Var2d function is called successively
nparam times with nparam different continuation parameters pj ∈ C1,ncont {C} or C1,ncont {MNc ,Nc (C)},
j ∈ nparam , where ncont must be the same for all pj . Then, the multi-parameter continuation path
is defined by
cont
path ∈ (Rparam )n ,
3.7. LAUNCHING THE SIMULATION... 57
• Coefficient_name (S) identifies the parameter on which the continuation applies. This pa-
rameter can be one of the following arguments
• Coefficient (C1,ncont {C} or C1,ncont {MNc ,Nc (C)}) is the p variable containing the values of
the parameter that will be changed during the continuation method. For a scalar parameter
(’Delta’, ’Beta’ or ’Omega’), it must be a cell array of scalars. In the case of a ma-
trix parameters ( ’GPotential’, ’GNonlinearity’, ’GFFTNonlinearity’, ’GGradientx’ or
’GGradienty’), it must be a cell array of matrices.
• Continuation (S,[]): the continuation structure must be taken as an argument if one wants
to add parameters in the continuation method for multi-parameter paths.
A simple example for the continuation method is to increment a single parameter. We know
that, if one wants to compute the ground state of a fast rotating Bose-Einstein condensate, one
should do this by a continuation method on the rotation speed. In GPELab, the rotation speed
is denoted by Ω, which corresponds to the Omega parameter in the Physics2D structure (see 3.6.1,
page 44). Therefore, a continuation on Ω, where one wants to increase it from 1 to 5 for example,
could be defined like in Table 3.31, where we have set the evolution of the parameter as Ω =
1, 2, 3, 3.5, 4, 4.5, 5.
Continuation = Continuation_Var2d(’Omega’,{1,2,3,3.5,4,4.5,5});
Table 3.31: An example for using the Continuation_Var2d function when the parameter is a scalar.
Another interesting case is when there is a coupling between multiple components. In this
scenario, a continuation method could be interesting to smoothly couple the two components. For
example, if the two components have coupled nonlinearities, one can use a continuation method on
the G matrix of the nonlinearity to increment the extradiagonal terms. This is done in Table 3.33,
where we have defined a cell vector of G matrices with increasing extradiagonal terms from 0 to 1
in 5 steps.
58 CHAPTER 3. HOW TO USE GPELAB: STATIONARY SOLUTIONS
GNL1 = [1,0;0,1];
GNL2 = [0,1;1,0];
for i=1:5
GNL{i} = GNL1 + (i/5)*GNL2
end
Continuation = Continuation_Var2d(’GNonlinearity’,GNL);
Table 3.32: An example for using the Continuation_Var2d function when the parameter is a matrix.
Finally, let us consider, for example, the case of a coupled fast rotating two-components Bose-
Einstein condensate. We can proceed by using a continuation simultaneously on the G matrix for
the coupling and on the Omega parameter. Thus, we first have to create the continuation structure
for a parameter and then update it by inserting a second parameter. This is done in Table 3.33,
where we first define the continuation on the Omega parameter and then we add the G matrix of the
nonlinearity.
Continuation = Continuation_Var2d(’Omega’,{1,2,3,3.5,4});
GNL1 = [1,0;0,1];
GNL2 = [0,1;1,0];
for i=1:5
GNL{i} = GNL1 + (i/5)*GNL2
end
Continuation = Continuation_Var2d(’GNonlinearity’,GNL,Continuation);
Print = Print_Var2d(Printing,Evo,Draw);
The Print_Var2d function builds the Print structure. The aim is to provide to the program
the printing informations displayed during the computation. The following optional arguments are
• Printing (N,1) is a variable equals to 1 for printing informations during the computation and
0 otherwise.
• Evo (N,5) is a variable corresponding to the number of iterations between each displayed
information (including drawing some figures). It must be bigger or equal to Evo_outputs
from the OutputsINI_Var2d function (see Section 3.7.1, page 53).
• Draw (N,1) is a variable equal to 1 if the modulus and the phase of the wave functions are
drawn during the simulation and 0 if not.
For example, if one wants to print informations every 10 iterations but does not want to slow
the program by drawing the wave function’s modulus and angle, then one can define the Print
structure by using the Print_Var2d function like in table 3.35.
3.7. LAUNCHING THE SIMULATION... 59
Printing = 1;
Evo = 10;
Draw = 0;
Print = Print_Var2d(Printing,Evo,Draw);
Figure = Figure_Var2d(map);
The Figure_Var2d function builds the Figure structure which contains informations needed to
draw figures in 2d. We have the following optional argument
• map (S,’jet’) is a variable corresponding to the colormap of the figures. It must be either
’jet’, ’hsv’, ’hot’, ’cool’, ’spring’, ’summer’, ’autumn’, ’winter’, ’gray’, ’bone’,
’copper’, ’pink’ or ’lines’ (see the Matlab documentation for further informations about
colormap3 ).
If one wants to draw figures using the ’hot’ colormap for example, then it can be done by
defining the Figure structure as in table 3.39.
map = ’hot’;
Figure = Figure_Var2d(map);
Figure = Figure_Var3d(view,iso,alpha,aspect,Sx,Sy,Sz,map);
The Figure_Var3d function builds the Figure structure which contains informations needed to
display the wave functions in 3d. The square modulus of the wave function is drawn in 3d by using
an isovalues surface, and the phase of the wave function which is displayed by using some slices
along the x-, y- and z-directions. The function has the following optional arguments
• view (N or M1,3 (R),3) is a variable corresponding to the viewing angle. For more informations
see the view4 Matlab function.
• iso (R+ ,0.001) is the isovalue chosen for drawing the modulus of the wave functions.
• aspect (M1,3 (R),[1,1,1]) is a variable corresponding to the data aspect ratio. For more
informations see the daspect6 Matlab function.
• Sx (R,0) (respectively Sy, Sz) is a coordinate on the x-axis where an orthogonal slice to the
x-axis (respectively y-axis, z-axis) will be drawn.
• map (S,’jet’) is a variable corresponding to the colormap of the figures. It must be either
’jet’, ’hsv’, ’hot’, ’cool’, ’spring’, ’summer’, ’autumn’, ’winter’, ’gray’, ’bone’,
’copper’, ’pink’ or ’lines’.
For example, suppose that one wants to compute a rotating Bose-Einstein condensate, where
the rotation is along the z-direction, and then to see the condensate along the z-axis to get a view
from above. Thus, the view angle, as set by Matlab, should be [0, 0, 1]. Moreover, it would be
convenient to set a slightly larger isovalue than the default one for the surface of the modulus of
the wave function, say 0.01, to better distinguish the vortices. Then the Figure structure should
be defined the same way as in table 3.39.
view = [0,0,1];
iso = 0.01;
Figure = Figure_Var3d(view,iso);
[Phi,Outputs] = GPELab2d(Phi_0,Method,Geometry2D,Physics2D,Outputs,Continuation,
Print,Figure);
The GPELab2d function is the main function to launch a full simulation with respect to the given
configuration. The output arguments are
• Phi (C1,Nc {MNy ,Nx (C)}), the wave functions computed at the final time (with respect to a
stopping criterion for a stationary state or a fixed time for a dynamical computation)
• and Outputs (S) which is a structure that contains all the outputs computed during the
simulation.
The initial data Phi_0 (C1,Nc {MNy ,Nx (C)}) and the Method, Geometry2D, Physics2D and Outputs
structures are required arguments. The optional arguments that can be considered are the following
• Continuation (S,[]) is the continuation structure if one wants to use a continuation method.
• Figure (S,Figure_Var2d.) is the structure that fixes the parameters for drawing the figures.
6
http://www.mathworks.fr/fr/help/matlab/ref/daspect.html
3.7. LAUNCHING THE SIMULATION... 61
[Phi,Outputs] = GPELab2d(Phi_0,Method,Geometry2D,Physics2D,Outputs);
MakeVideo2d(Method,Geometry2D,Outputs, Function,VideoName,Figure);
The MakeVideo2d function creates a movie from the saved wave functions during the computa-
tion. It assembles snapshots from each saved component’s wave function and creates a video. Due
to the fact that Matlab takes snapshots of the figures, the user must be extremely careful when
building the movie by not covering the figure during the construction process. This function must
be provided with the Method structure, the Geometry2D structure and the Outputs structure. We
have the following optional arguments
is provided, then the snapshots are considered by applying Function to each component
C1,Nc {F(MNy ,Nx (C), MNy ,Nx (R)2 ; MNy ,Nx (R))}
If one wants to make a video of the angle of a wave function after a simulation, then one should
proceed as in table 3.43.
This Section is devoted to different physical examples treated by GPELab for computing station-
ary states. The user has a direct access to the source codes in the subdirectories 1d/examples,
2d/examples and 3d/examples of GPELab. We will be happy to add some of your examples that
are different from the ones given here.
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 5e-2;
Stop_time = [];
Stop_crit = 1e-8;
Method = Method_Var1d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -16;
xmax = 16;
Nx = 2^10+1;
Geometry1D = Geometry1D_Var1d(xmin,xmax, Nx);
We now define the physics of the problem to compute the ground state of the following Gross-
Pitaevskii equation
|x|2
πx
1
i∂t ψ(t, x) = ∆ψ(t, x) + + 25 sin2 ψ(t, x) + β|ψ(t, x)|2 ψ(t, x),
2 2 4
63
64 CHAPTER 4. EXAMPLES OF SIMULATIONS FOR STATIONARY SOLUTIONS
with β = 250. Let us remark that since we consider the cubic case, this is the default nonlinearity
in GPELab and we therefore do not have to define it. We have
• and finally to add the default nonlinear operator to the physics of the problem.
We follow this construction in Table 4.2 where we directly define the optical potential in the argu-
ments of the Potential_Var1d function.
Delta = 0.5;
Beta = 250;
Physics1D = Physics1D_Var1d(Method,Delta,Beta);
Physics1D = Potential_Var1d(Method, Physics1D, @(x) x.^2 /2 + 25*sin(pi*x/4).^2);
Physics1D = Nonlinearity_Var1d(Method, Physics1D);
We then set the initial function to use for the computation. We choose a centered gaussian by
setting the InitialData_choice to 1 in the InitialData_Var1d function, as in Table 4.3.
InitialData_choice = 1 ;
Phi_0 = InitialData_Var1d(Method, Geometry1D, Physics1D,InitialData_choice);
We finally set the outputs and the printing informations and then launch the simulation. We
choose to print informations in the command window every 15 iterations and to draw a figure of
the square of the modulus of the solution. This is done in Table 4.4.
Outputs = OutputsINI_Var1d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var1d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab1d(Phi_0,Method,Geometry1D,Physics1D,Outputs,[],Print);
Table 4.4: Setting the outputs, the Print structure and launching the computation.
4.1. GROUND STATE OF A 1D GROSS-PITAEVSKII EQUATION WITH AN OPTICAL POTENTIAL AND
At the end of the simulation, we obtain the following informations on the command window of
Matlab.
––––––––––––––––––––
Iteration 249 on 1000000
–-Outputs of component 1–––––––-
Square at the origin: 0.15144001489396
x-radius mean square: 3.36090790724700
Energy: 26.08386211010322
Chemical potential: 38.06922564389800
Energy evolution: 0.00000000000002
––––––––––––––––––––
CPU time: 7.36
»
The solution as also been printed out during the simulation. At the end, we obtain the solution
given on Figure 4.1.
2
|phi(x) | of component 1
0.16
0.14
0.12
0.1
0.08
0.06
0.04
0.02
0
−20 −15 −10 −5 0 5 10 15 20
x
Moreover, we can draw the evolution of the energy and the chemical potential during the com-
putation by plotting Outputs.Energy{1} and Outputs.Chemical_potential{1} (see Figure 4.2).
50
Energy
Chemical potential
45
40
35
30
25
0 5 10 15 20 25 30 35 40 45 50
Figure 4.2: Evolution of the energy and the chemical potential during the computation.
66 CHAPTER 4. EXAMPLES OF SIMULATIONS FOR STATIONARY SOLUTIONS
Table 4.5: The potential function used for the Josephson junction.
function NL = Josephson_Nonlinearity(Beta_11,Beta_22,Beta_12)
NL = cell(2);
NL{1,1} = @(Phi,x) Beta_11*abs(Phi{1}).^2 + Beta_12*abs(Phi{2}).^2;
NL{2,2} = @(Phi,x) Beta_22*abs(Phi{2}).^2 + Beta_12*abs(Phi{1}).^2;
NL{1,2} = @(Phi,x) 0;
NL{2,1} = @(Phi,x) 0;
end
Table 4.6: The nonlinearity function used for the Josephson junction.
Moreover, we define in Table 4.7 the energy (2.50) (see page 31) which is associated to the
nonlinearity.
Table 4.7: The function computing the energy (2.50), page 31, associated to the nonlinearity used
for the Josephson junction.
We now show how to compute the ground state of this system of coupled Gross-Pitaevskii
equations by using similar parameters as in [17]. First, we have to build the Method and Geometry1D
4.2. GROUND STATE OF A SYSTEM OF 1D GROSS-PITAEVSKII EQUATIONS WITH A QUADRATIC PO
structures. We use the BESP scheme and a time step equal to 10−1 , with a spatial grid of 210 + 1
points in [−16, 16]. Moreover, the stopping criterion is fixed to 10−6 (see Table 4.8).
Computation = ’Ground’;
Ncomponents = 2;
Type = ’BESP’;
Deltat = 1e-1;
Stop_time = [];
Stop_crit = 1e-6;
Method = Method_Var1d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -16;
xmax = 16;
Nx = 2^10+1;
Geometry1D = Geometry1D_Var1d(xmin,xmax, Nx);
We now define the physics of the problem. We build the Physics1D structure according to
equation (4.1). Moreover, one wishes to reproduce the numerical results in [17] with the set of
physical parameters
λ = −1 δ=0
β = 500 β11 = β
β12 = 0.94β β22 = 0.97β
We proceed as in table 4.9 where we use the two operators defined in Tables 4.5 and 4.6, and
the function defining the energy associated to the nonlinearity in Table 4.7.
Delta = 0.5;
Rabi_frequency = -1;
Detuning_constant = 0;
Beta = 500;
Beta_11 = 1;
Beta_12 = 0.94;
Beta_22 = 0.97;
Physics1D = Physics1D_Var1d(Method,Delta,Beta);
Physics1D = Potential_Var1d(Method, Physics1D,...
Josephson_Potential(Detuning_constant,Rabi_frequency));
Physics1D = Nonlinearity_Var1d(Method, Physics1D,...
Josephson_Nonlinearity(Beta_11,Beta_22,Beta_12),[],...
Josephson_Nonlinearity_Energy(Beta_11,Beta_22,Beta_12));
We then set the initial function to use for the computation that we choose as a centered gaussian
(see Table 4.10).
68 CHAPTER 4. EXAMPLES OF SIMULATIONS FOR STATIONARY SOLUTIONS
InitialData_choice = 1 ;
Phi_0 = InitialData_Var1d(Method, Geometry1D, Physics1D,InitialData_choice);
We finally set the outputs and the printing informations and launch the simulation. We display
the informations in the command window every 15 iterations. We furthermore draw a figure of the
square of the modulus of the solution. The corresponding GPELab code is detailed in Table 4.11.
Outputs = OutputsINI_Var1d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var1d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab1d(Phi_0,Method,Geometry1D,Physics1D,Outputs,[],Print);
At the end of the simulation, we obtain the informations concerning the ground state in Table
4.12 and the modulus of each component in figure 4.3. Moreover, we can plot the two modulii on
the same figure and obtain the same result as in [17] (see Figure 4.4).
––––––––––––––––––––
Iteration 164 on 1000000
–-Outputs of component 1–––––––-
Square at the origin: 0.03512761887793
x-radius mean square: 2.67309309073190
Energy: 9.97806793424214
Chemical potential: 32.84198217411518
Energy evolution: 0.00000000000000
–-Outputs of component 2–––––––-
Square at the origin: 0.04853615539806
x-radius mean square: 2.99189318517412
Energy: 13.16187704973455
Chemical potential: 38.16552799804442
Energy evolution: 0.00000000000000
––––––––––––––––––––
CPU time: 8.28
»
2 2
|phi(x) | of component 1 |phi(x) | of component 2
0.04 0.05
0.045
0.035
0.04
0.03
0.035
0.025
0.03
0.02 0.025
0.02
0.015
0.015
0.01
0.01
0.005
0.005
0 0
−20 −15 −10 −5 0 5 10 15 20 −20 −15 −10 −5 0 5 10 15 20
x x
(a) Component 1 of the ground state (b) Component 2 of the ground state
0.2
0.15
0.1
0.05
−0.05
−20 −15 −10 −5 0 5 10 15 20
x
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 1e-2;
Stop_time = [];
Stop_crit = 1e-6;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -15;
xmax = 15;
ymin = -15;
ymax = 15;
Nx = 2^8+1;
Ny = 2^8+1;
Geometry2D = Geometry2D_Var2d(xmin,xmax, ymin,ymax, Nx, Ny);
We now define the physics of the problem. Let us consider the computation of the ground state
of the following Gross-Pitaevskii equation
2
1 |x| + |y|2 πx πy
i∂t ψ(t, x, y) = ∆ψ(t, x, y) + + κ sin2 + sin2 ψ(t, x, y)
2 2 4 4
+β|ψ(t, x, y)|2 ψ(t, x, y),
with κ = 100 and β = 1000. Let us recall that, since the default nonlinearity is the cubic nonlinear-
ity, we do not have to redefine it. Therefore, we only have to impose the optical potential and then
to build the Physics2D structure. We end by adding the potential operator to Physics2D which is
defined as the optical potential and the default nonlinear operator (see Table 4.14).
Delta = 0.5;
Beta = 1000;
Kappa = 100;
Optical_Potential = @(x,y) (1/2)*(x.^2 + y.^2) + ...
Kappa*(sin(pi*x/4).^2+sin(pi*y/4).^2);
Physics2D = Physics2D_Var2d(Method,Delta,Beta);
Physics2D = Potential_Var2d(Method, Physics2D,Optical_Potential)
Physics2D = Nonlinearity_Var2d(Method, Physics2D);
InitialData_choice = 2 ;
Phi_0 = InitialData_Var2d(Method, Geometry2D, Physics2D,InitialData_choice);
The outputs and the printing informations are then defined (see Table 4.15).
Outputs = OutputsINI_Var2d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var2d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab2d(Phi_0,Method,Geometry2D,Physics2D,Outputs,[],Print);
Table 4.15: Setting the outputs and the printing of informations, and then launching the simulation.
The results of the simulation are reported in Table 4.16 and the solution is given in Figure 4.6.
The evolution of the energy and the chemical potential are plotted in Figure 4.7.
––––––––––––––––––––
Iteration 157 on 1000000
–-Outputs of component 1–––––––-
Square at the origin: 0.06528267039451
x-radius mean square: 3.96548348047485
y-radius mean square: 3.96548346927846
Energy: 51.22028604002639
Chemical potential: 66.24901258432952
Angular momentum: -0.00000000000000
Energy evolution: -0.00000000003103
––––––––––––––––––––
CPU time: 172.47
»
Table 4.16: Printed outputs for the 2d GPE with cubic nonlinearity and optical lattice.
110
Energy
Chemical potential
100
90
80
70
60
50
0 5 10 15 20 25 30 35
Figure 4.7: Evolution of the energy and the chemical potential during the computation.
computation of a ground state where a fast rotation can be considered. We begin by constructing
the Method and Geometry2D structures. We use the BESP scheme, with a time step equal to 10−3 ,
to solve the problem on a spatial grid involving 28 + 1 points in the x- and y- directions for the
72 CHAPTER 4. EXAMPLES OF SIMULATIONS FOR STATIONARY SOLUTIONS
domain [−10, 10] × [−10, 10]. The stopping criterion is fixed to 10−5 (see Table 4.17).
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 1e-3;
Stop_time = [];
Stop_crit = 1e-5;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -10;
xmax = 10;
ymin = -10;
ymax = 10;
Nx = 2^8+1;
Ny = 2^8+1;
Geometry2D = Geometry2D_Var2d(xmin,xmax, ymin,ymax, Nx, Ny);
with the parameters α = 1.2, κ = 0.3, γx = γy = 1, β = 1000 and Ω = 3.5. We know that
the default nonlinearity is the cubic nonlinearity and the default gradients define the rotational
operator. Therefore, we only have to define the quadratic-plus-quartic potential by using a Matlab
script (Table 4.18) and then construct the Physics2D structure with the desired coefficients.
We can now construct the Physics2D structure by using the Physics2D_Var2d function and
then add the quadratic-plus-quartic potential that we have defined, the default nonlinear operators
and the default gradients to the Physics2D structure, thus including them in the physics of the
problem (see Table 4.19).
4.4. GROUND STATE OF 2D GPE EQUATION WITH A FAST ROTATION 73
Delta = 0.5;
Beta = 1000;
Omega = 3.5;
Physics2D = Physics2D_Var2d(Method,Delta,Beta,Omega);
Alpha = 1.2;
Kappa = 0.3;
Gamma_x = 1;
Gamma_y = 1;
Physics2D = Potential_Var2d(Method, Physics2D,...
@(X,Y) quadratic_plus_quartic_potential2d(Gamma_x, Gamma_y,Alpha,Kappa,X,Y));
Physics2D = Nonlinearity_Var2d(Method, Physics2D);
Physics2D = Gradientx_Var2d(Method, Physics2D);
Physics2D = Gradienty_Var2d(Method, Physics2D);
InitialData_choice = 2 ;
Phi_0 = InitialData_Var2d(Method, Geometry2D, Physics2D,InitialData_choice);
Outputs = OutputsINI_Var2d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var2d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab2d(Phi_0,Method,Geometry2D,Physics2D,Outputs,[],Print);
Table 4.21: Defining the Outputs and Print structures and then launching the computation using
GPELab2d.
We obtain in Table 4.22 the informations on the ground state at the end of the computation.
––––––––––––––––––––
Iteration 46766 on 1000000
–-Outputs of component 1–––––––-
Square at the origin: 0.00000000000000
x-radius mean square: 4.57951169686043
y-radius mean square: 4.57951071463754
Energy: 115.52164061561449
Chemical potential: 122.58168418655728
Angular momentum: 146.32747911959200
Energy evolution: -0.00000000141087
»
Table 4.22: Printed outputs for the 2d GPE with cubic nonlinearity, rotation and quadratic-plus-
quartic potential.
74 CHAPTER 4. EXAMPLES OF SIMULATIONS FOR STATIONARY SOLUTIONS
We report on figure 4.8 the modulus of the stationary state solution at the end of the computa-
tions. We can observe the creation of an annulus with uniformly spaced vortices inside.
Computation = ’Ground’;
Ncomponents = 2;
Type = ’BESP’;
Deltat = 1e-2;
Stop_time = [];
Stop_crit = 1e-6;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -10;
xmax = 10;
ymin = -10;
ymax = 10;
Nx = 2^8+1;
Ny = 2^8+1;
Geometry2D = Geometry2D_Var2d(xmin,xmax, ymin,ymax, Nx, Ny);
Table 4.23: Using the Method_Var2d and Geometry2D_Var2d functions to build the Method and
Geometry2D structures.
4.5. GROUND STATE OF 2D GPE SYSTEM WITH COUPLED NONLINEARITIES 75
We now define the physics of the problem. Let us consider the problem of computing the ground
state of the following system of Gross-Pitaevskii equations
1 1 2 2
2 2
i∂t ψ1 (t, x, y) = ∆ψ1 (t, x, y) + |x| + |y| + β1 |ψ1 (t, x, y)| + β12 |ψ2 (t, x, y)| ψ1 (t, x, y)
2 2
+iΩ (y∂x − x∂y ) ψ1 (t, x, y),
1 1 2 2
2 2
i∂t ψ2 (t, x, y) = ∆ψ2 (t, x, y) + |x| + |y| + β2 |ψ2 (t, x, y)| + β12 |ψ1 (t, x, y)| ψ2 (t, x, y)
2 2
+iΩ (y∂x − x∂y ) ψ2 (t, x, y),
with β1 = β2 = 400, β12 = 200 and Ω = 0.8. We recall that, since the default potential is the
quadratic potential and the default gradients define the rotational operator, we only have to define
the coupled cubic nonlinearity. This is done in Table 4.24.
We also have to impose the energy associated to the coupled cubic nonlinearity (Table 4.25).
Table 4.25: Defining the energy associated with the coupled nonlinearity.
We can now build the Physics2D structure accordingly to our problem. We set the coefficients for
the Laplacian, the nonlinearity and the rotational operator by using the Physics2D_Var2d function.
Then we add the default potential, the default gradients and the coupled cubic nonlinearity to the
physics of the problem thanks to the functions associated to each operator (see Table 4.26).
76 CHAPTER 4. EXAMPLES OF SIMULATIONS FOR STATIONARY SOLUTIONS
Delta = 0.5;
Beta = 200;
Beta_coupled= [2,1;1,1];
Omega = 0.8;
Physics2D = Physics2D_Var2d(Method,Delta,[],Omega);
Physics2D = Potential_Var2d(Method, Physics2D);
Physics2D = Nonlinearity_Var2d(Method, Physics2D,...
Coupled_Cubic2d(Method,Beta_coupled),...
[],Coupled_Cubic_energy2d(Method,Beta_coupled));
Physics2D = Gradientx_Var2d(Method, Physics2D);
Physics2D = Gradienty_Var2d(Method, Physics2D);
We then set the initial function as the Thomas-Fermi approximation (see Table 4.27).
InitialData_choice = 2 ;
Phi_0 = InitialData_Var2d(Method, Geometry2D, Physics2D,InitialData_choice);
Table 4.28 provides the informations for the outputs and printing options.
Outputs = OutputsINI_Var2d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var2d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab2d(Phi_0,Method,Geometry2D,Physics2D,Outputs,[],Print);
We report on figure 4.9 the moduli of the stationary state solutions at the end of the computa-
tions.
(a) Component 1 of the ground state (b) Component 2 of the ground state
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 1e-2;
Stop_time = [];
Stop_crit = 1e-4;
Method = Method_Var3d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -10;
xmax = 10;
ymin = -10;
ymax = 10;
zmin = -10;
zmax = 10;
Nx = 2^6+1;
Ny = 2^6+1;
Nz = 2^6+1;
Geometry3D = Geometry3D_Var3d(xmin,xmax, ymin,ymax, zmin,zmax, Nx, Ny, Nz);
The ground state that we want to compute is associated to the following Gross-Pitaevskii equa-
tion
1 1
γx |x|2 + γy |y|2 + γz |z|2 Ψ(t, x, y, z)
i∂t Ψ(t, x, y, z) = ∆Ψ(t, x, y, z) +
2 2
2
+β|Ψ(t, x, y, z)| Ψ(t, x, y, z) + Ω · (x × ∇) Ψ(t, x, y, z),
with γx = γy = γz = 1, β = 500 and Ω = (0, 0, 0.9). We keep in mind that the default nonlinearity
is the cubic nonlinearity, the default potential is the quadratic potential and the default gradients
operators are the rotational operators. This implies that we only have to build the Physics3D
structure with the desired coefficients and then add each operator (see Table 4.30 for more details).
78 CHAPTER 4. EXAMPLES OF SIMULATIONS FOR STATIONARY SOLUTIONS
Delta = 0.5;
Beta = 500;
Omega = [0,0,0.9];
Physics3D = Physics3D_Var3d(Method,Delta,Beta,Omega);
Physics3D = Potential_Var3d(Method, Physics3D);
Physics3D = Gradientx_Var3d(Method, Physics3D);
Physics3D = Gradienty_Var3d(Method, Physics3D);
Physics3D = Gradientz_Var3d(Method, Physics3D);
Physics3D = Nonlinearity_Var3d(Method, Physics2D);
Table 4.30: Setting the coefficients and adding the default operators to the Physics3D structure.
We then set the initial function by using the InitialData_Var3d. We choose the Thomas-Fermi
approximation (see Table 4.31).
InitialData_choice = 2 ;
Phi_0 = InitialData_Var3d(Method, Geometry3D, Physics3D,InitialData_choice);
We finally set the outputs and the printing informations, then we launch the simulation following
Table 4.32.
Outputs = OutputsINI_Var3d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var3d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab3d(Phi_0,Method,Geometry3D,Physics3D,Outputs,[],Print);
Table 4.32: Creating the Outputs and Print structure and launching the computation.
At the end of the computation, we obtain on Figure 4.10 the isovalues of the modulus of the
stationary state solution.
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 1e-2;
Stop_time = [];
Stop_crit = 1e-6;
Method = Method_Var3d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -10;
xmax = 10;
ymin = -10;
ymax = 10;
zmin = -10;
zmax = 10;
Nx = 2^6+1;
Ny = 2^6+1;
Nz = 2^6+1;
Geometry3D = Geometry3D_Var3d(xmin,xmax, ymin,ymax, zmin,zmax, Nx, Ny, Nz);
Delta = 0.5;
Beta = 1000;
Dipolar_direction = [0,0,1];
d = 0.5;
Physics3D = Physics3D_Var3d(Method,Delta,Beta);
Physics3D = Potential_Var3d(Method, Physics3D);
Physics3D = Nonlinearity_Var3d(Method, Physics2D);
Physics3D = FFTNonlinearity_Var3d(Method, Physics3D,...
@(Phi,X,Y,Z,FFTX,FFTY,FFTZ)Dipolar_interaction3d(Phi, FFTX, FFTY, FFTZ,
Dipolar_direction , d));
InitialData_choice = 2 ;
Phi_0 = InitialData_Var3d(Method, Geometry3D, Physics3D,InitialData_choice);
We finally set the outputs and the printing informations, then we launch the simulation (see
Table 4.37).
Outputs = OutputsINI_Var3d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var3d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab3d(Phi_0,Method,Geometry3D,Physics3D,Outputs,[],Print);
Table 4.37: Initializing the outputs, setting the informations to print and launching the computation.
At the end of the computation, we obtain (see Figure 4.11) the isovalues of the modulus of the
stationary state solution.
After having computed the stationary states of a GPE, one can be interested in the dynamics of the
stationary solutions for a modified GPE (for example by changing the potential). More generally,
the dynamics of an initial data is very important to analyze the dynamical properties of a BEC.
For this reason, we first introduce the main schemes that are included in GPELab. The first
class of methods is Time Splitting SPectral (TSSP) schemes. We briefly explain how these schemes
work in Section 5.1 and how an increased accuracy can be obtained by using suitable weighted
approximations of the exponential operators appearing in the splitting formulae. Another scheme
that is discussed is the relaxation scheme in time, coupled with pseudospectral approximation
methods based on FFTs. This approach is described in Section 5.2. In Section 5.4, we explain
the Richardson’s extrapolation method that is coded in GPELab. This simple technique allows
to increase easily the order of the time scheme by linear combinations between computations for
fractional uniform time steps. We next provide in Section 5.5 the different functions that are met in
GPELab to compute the dynamics of a given (system of) GP equation(s). Finally, in Section 5.6,
we end the Chapter by a few computational examples to show how to use the GPELab functions
for the dynamics and provide the solutions that are expected.
and we denote by ψ(t, x) = e(A+B)t ψ0 (x) its solution, t > 0 and x ∈ Rd . The Time-Splitting (TS)
schemes consist in approximating the solution of this PDE by the exponential operators of A and
B, which means that we approximately split A and B into the exponential representation. In fact,
a general approximation of the solution by a time splitting scheme can be written in the following
form
ψ(tn + ∆t, x) ≈ ψ n+1 (x) = ea1 A∆t eb1 B∆t ea2 A∆t eb2 B∆t ...eap A∆t ebp B∆t ψ n (x),
where {ak , bk }1≤k≤p ⊂ R are some weights that must be computed in such a way that the approxi-
mation of e(A+B)∆t is of a given order for a time step ∆t which is supposed to be relatively small.
83
84CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
Two of the most commonly used time-splitting schemes are the Lie (a1 = b1 = 1) (cf. subsection
5.1.1) and the Strang (a1 = a2 = 1/2 and b1 = 1, b2 = 0) (cf. subsection 5.1.2) schemes which are
first- and second-order time schemes, respectively. Higher-order schemes 1 can be constructed for
appropriately chosen weights {ak , bk }1≤k≤p . The main idea behind the splitting of operators is that
each equation associated with each operator A or B can be solved easily.
Let us first begin by the Lie splitting scheme. Let us recall the rotating cubic GPE equation in 2d
1
i∂t ψ(t, x) = − ∆ψ(t, x) + V (t, x)ψ(t, x) + β|ψ(t, x)|2 ψ(t, x) − ΩLz ψ, t > 0, x ∈ R2 . (5.1)
2
i
A = ∆ + iΩLz ,
2
2) and next the ODE with respect to the potential and nonlinear terms
Indeed, as we will see later, the equation associated to the partial differential operator can be solved
with the help of spectral methods. Furthermore, the equation related to the nonlinearity and the
potential parts can be integrated exactly. Indeed, for a time step ∆t, it can be proved that an
approximation of the solution is given by
1 2 )∆t
ψ n+1 (x) = ei( 2 ∆+iΩLz )∆t e−i(V (t,x)+β|ψ(t,x)| ψ n (x).
2) and next
i∂t ψ2 (t, x) = V (t, x)ψ2 (t, x) + β|ψ2 (t, x)|2 ψ2 (t, x), n∆t < t ≤ (n + 1)∆t,
(5.3)
ψ2 (n∆t, x) = ψ1 ((n + 1)∆t, x).
A second step (which corresponds in fact to consider (5.3)) is to solve the following PDE, from time
t = tn to t = tn+1
i∂t ψ (3) (t, x) = V (t, x)ψ (3) (t, x) + β|ψ (3) (t, x)|2 ψ (3) (t, x),
(5.7)
ψ (3) (tn , x) = ψ (2) (tn+1 , x).
We know that this equation can be solved exactly and the solution is given by,
(2) (t 2
Rt
ψ (3) (t, x) = ψ (2) (tn+1 , x)e−iβ|ψ n+1 ,x)| (t−tn )−i tn V (s,x)ds
(5.8)
This ODE can be integrated in time exactly and we obtain, ∀t ∈ [tn , tn+1 ] and ∀p, 1−J/2 ≤ p ≤ J/2,
1 2
ψbp(1) (t, y) = e−i( 2 µp +Ωyµp )(t−tn ) ψbp(1) (tn , y).
Similarly, for Eq. (5.6), one gets, ∀t ∈ [tn , tn+1 ] and ∀q, 1 − K/2 ≤ q ≤ K/2,
1 2
ψbq(2) (t, x) = e−i( 2 λq −Ωxλq )(t−tn ) ψbq(2) (tn , x).
Thus, the first step of the Lie scheme, where we solve equation (5.5) and then equation (5.6) on the
time interval [tn , tn+1 ] and the domain OJ,K , will be implemented in the following way
J/2−1
1 1 2
e−i( 2 µp +Ωyk µp )(tn+1 −tn ) ψ
X
(1) cn (yk )eiµp (xj +Lx ) ,
ψ (tn+1 , xj , yk ) = p
J
p=−J/2
K/2−1
1 1 2
e−i( 2 λq −Ωxj λq )(tn+1 −tn ) ψbq(1) (tn+1 , xj )eiλq (yk +Ly ) .
X
ψ (2) (tn+1 , xj , yk ) =
K
q=−K/2
Of course these operations are based on the fft() and ifft() Matlab functions. The frequency de-
pendent quantities (µ2p /2+Ωyk µp ) and (λ2q /2−Ωxj λq ) are obtained through the Delta_grad_Fourier()
(to compute µp and λq ) and the meshgrid() functions. Then, the exponential matrix is computed
by the usual exponential Matlab function. To discretize (5.8), we use the standard Simpson’s
quadrature rule in time
Z tn+1
1
V (s, xj , yk )ds ≈ V (tn , xj , yk ) + 6V tn+1/2 , xj , yk + V (tn+1 , xj , yk ) (tn+1 − tn )
tn 6
:= Ṽn (xj , yk )(tn+1 − tn ),
This corresponds to only change the phase of the solution by a suitable shift. Let us also remark
that all we have done above extend directly to the case of a general nonlinearity f (|ψ|, x). This
scheme is globally first-order in time and spectral in space.
i∂t ψ (3) (t, x) = V (t, x)ψ (3) (t, x) + β|ψ (3) (t, x)|2 ψ (3) (t, x),
(5.11)
ψ (3) (tn , x) = ψ (2) (tn+1/2 , x),
by the change of phase.
4) Solve from t = tn to t = tn+1/2
( 1
i∂t ψ (4) (t, x) = − ∂yy ψ (4) (t, x) + iΩx∂y ψ (4) (t, x),
2 (5.12)
ψ (4) (tn , x) = ψ (3) (tn+1 , x).
This last step finally gives ψ n+1 (x) := ψ (5) (tn+1/2 , x). Each partial differential equation with respect
to x or y is solve through FFTs and iFFTs.
The Lie ADI-TSSP scheme is first-order in time and spectral in space, while the Strang ADI-
TSSP scheme is second-order in time and spectrally accurate in space. Their computational costs
are O(M log M ). The extension to the three-dimensional case is direct. Other properties are related
to the fact that these schemes are time reversible, mass conserving (if it is true at the continuous
level), time transverse invariant and the dispersion relation holds. However, there is no energy
conservation. Indeed, it can be proved that only the energy of a closely related system is conserved.
These explicit schemes are unconditionally stable. More details can be found in [?].
The initial data is Ψ(t = 0, x) = Ψ0 (x). To derive the TSSP scheme for this system, we choose the
same kind of splitting strategy. For the Lie scheme, this leads to solving the equation in two steps.
Let ∆t > 0 and Ψn the approximation of the solution at time tn . Then the splitting yields
88CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
i∂t Ψ(2) (t, x) = V (x)Ψ(2) (t, x) + βF (|Ψ(2) (t, x)|, x)Ψ(2) (t, x),
(5.16)
Ψ(2) (tn , x) = Ψ(1) (tn+1 , x).
We furthermore have: Ψ0 (x) := Ψ0 (x). We remark now that (5.16) leads to: ∀t > tn , |Ψ(2) (t, x)| =
|Ψ(2) (tn , x)|. Indeed, we have
Nc
X Nc
X
∗
∂t |Ψ(2)
m (t, x)|
2
= 2 < Ψ(2)
m (t, x) ∂t Ψ(2)
m (t, x)
m=1 m=1
Nc
X
∗
= −2 = Ψ(2) (2) (2)
m (t, x) (Vmo (x) + Fmo (|Ψ (t, x)|, x))Ψo (t, x) .
m,o=1
Using the fact that Vmo (x) = Vom (x) and Fmo (|Ψ(2) (t, x)|, x) = Fom (|Ψ(2) (t, x)|, x), we obtain that
Nc
X
∂t |Ψ(2) 2
m (t, x)| =
m=1 X
∗ (2) ∗ (2)
−2 = (Vmo (x) + Fmo (|Ψ(2) (t, x)|, x))(Ψ(2)
m (t, x) Ψ o (t, x) + Ψ (2)
o (t, x) Ψm (t, x))
Nc ≥o>m≥1
X
−2 = (Vmm (x) + Fmm (|Ψ(2) (t, x)|, x))|Ψ(2) m (t, x)|
2
Nc ≥m≥1
X
∗ (2)
= −4 = (Vmo (x) + Fmo (|Ψ(2) (t, x)|, x))<(Ψ(2) m (t, x) Ψ o (t, x)) = 0.
Nc ≥o>m≥1
(5.17)
As a conclusion, we have that: |Ψ(2) (t, x)|
= |Ψ(2) (t
n , x)|, for t > tn .
Let n ∈ N and Ψn (x) ∈ L2 (O)Nc , compactly supported in O. For the sake of simplicity, we
explicit the method in the two-dimensional case, e.g. d = 2. A first step is to solve, from t = tn to
t = tn+1 ,
2
(1) 1 (1)
X
Gj (x\xj )∂xj Ψ(1) (t, x),
i∂t Ψ (t, x) = − ∆Ψ (t, x) +
2 (5.18)
j=1
(1) n
Ψ (tn , x) = Ψ (x).
As in the one-component case, an ADI method must be used to decouple the effects of Gj . Therefore,
we split Eq. (5.15) in two equations, and solve from t = tn to t = tn+1 ,
( 1
i∂t Ψ(1,1) (t, x) = − ∂xx Ψ(1,1) (t, x) + G1 (y)∂x Ψ(1,1) (t, x),
2 (5.19)
Ψ(1,1) (tn , x) = Ψn (x),
A second step is to solve Eq. (5.16) for a well-chosen initial data, from t = tn to t = tn+1 , e.g.
i∂t Ψ(2) (t, x) = V (x)Ψ(2) (t, x) + βF (|Ψ(2) (t, x)|, x)Ψ(2) (t, x),
(5.21)
Ψ(2) (tn , x) = Ψ(1,2) (tn+1 , x).
This finally gives: Ψn+1 (x) ≈ Ψ(2) (tn+1 , x). Let us remark that we have to compute the exponential
of a matrix to effectively calculate (5.22).
For the full approximation, we adapt to each component the spectral approximation based on
fft and ifft in space. For both the Lie and Strang schemes, the spectral approximation is written
under a symmetrical form as for the one-component case.
5.2.1 A Relaxation pseudo SPectral scheme (ReSP) for the one-component case
If we consider the 2d cubic GPE
1
i∂t ψ(t, x) = − ∆ψ(t, x) + V (x, t)ψ(t, x) + β|ψ(t, x)|2 ψ(t, x) − ΩLz ψ, x ∈ R2 , t > 0, (5.23)
2
then the relaxation scheme is
φn+1/2 + φn−1/2
= β|ψ n |2 ,
2
ψ n+1 − ψ n n+1
+ ψn V n+1 ψ n+1 + V n ψ n
1 ψ
i = (− ∆ − ΩLz ) + (5.24)
∆t 2 n+1 2 n 2
ψ + ψ
+φn+1/2
,
2
with the uniform time step ∆t = tn+1 − tn , and where φn+1/2 = φ(tn+1/2 , x), ψ n = ψ(tn , x) and
V n = V (tn , x). The initial conditions are ψ 0 (x) = ψ0 (x) and φ−1/2 (x) = β|ψ0 (x)|2 . The extension
to a general nonlinearity is direct.
We now have to discretize the operator (−∆ − ΩLz ). To this end, we use the pseudospectral
approximation of the spatial derivatives based on the Fourier series transforms (2.36)-(2.37), page
27. Keeping the same notations, we have the following discretization
n+1/2
φ = cRe,n ,
(5.25)
ARE,n ψ = bRe,n ,
Like for the stationary case, the evaluation of the differential operators is made through the
FFT/iFFTs while the diagonal matrices in the physical space are applied directly. The linear
system in (5.27) is solved at each iteration with the BiCGStab. A preconditioner, in the spirit
of the Laplace/Thomas-Fermi preconditioners (see []), is used to accelerate the convergence of the
iterative Krylov subspace solver.
The resulting scheme is called Relaxation pseudo SPectral scheme (ReSP). The scheme is second-
order in time, and spectrally accurate in space. It computational cost is O(M log M ). The extension
to the three-dimensional case and other nonlinearities is direct. Other properties are related to
the fact that it is time reversible, mass and energy (for a cubic nonlinearity) conserving when the
property holds at the continuous level. It is not time transverse invariant and the dispersion relation
is not preserved. The scheme is unconditionally stable. We refer to [?] for more details.
Φn+1/2 + Φn−1/2
= βF (Ψn , x), 1 ≤ n ≤ M, x ∈ Rd ,
2
d
Ψn+1 − Ψn 1 X Ψn+1 + Ψn
= −i − ∆ + V (x) + Gj (x)∂xj + Φn+1/2 , x ∈ Rd
∆t 2 2
j=1
for n ≥ 0. Concerning the spatial discretization, we use again a pseudo spectral method based on
the FFTs/iFFTs. Let us detail the two-dimensional case, e.g. d = 2. For the relaxation scheme, we
have
MRe,n+1/2 = 2βF(Ψn , x) − MRe,n−1/2 ,
(5.27)
ARe,n Ψn+1 = BRe,n Ψn ,
with M := JK.
The nonlinear operator MRe,n+1/2 ∈ MM Nc (C) is updated through the matrix
ARe,n Ψ = ARe,n Re
TF Ψ + A∆,∇ Ψ,
INc 1
ARe,n
TF Ψ := i Ψ − V + M Re,n+1/2
Ψ, (5.28)
∆t
2
1 1 1 2
ARe
∆,∇ Ψ := [[∆]] − G [[∂ x ]] − G [[∂ y ]] Ψ.
2 2
5.2. RELAXATION PSEUDO SPECTRAL SCHEME (RESP) 91
and
[[∂x ]]Ψ := ([[∂x ψ` ]])`=1,...,Nc ∈ CM Nc , [[∂y ]]Ψ := ([[∂y ψ` ]])`=1,...,Nc ∈ CM Nc . (5.29)
BRe,n Ψ = BRe,n Re
TF Ψ + B∆,Ω Ψ,
INc 1
BRe,n
TF Ψ := i Ψ + V + M Re,n+1/2
Ψ, (5.30)
∆t
2
Re 1 1 1 2
B∆,∇ Ψ := − [[∆]] + G [[∂x ]] + G [[∂y ]] Ψ.
2 2
For solving the second equation of (5.27), we again use the preconditioned BiCGStab. Concern-
ing the TF(-like) preconditioner, since we have some coupling effects between the gazes through V
and MRe,n+1/2 , the matrix ARe,n
TF is non diagonal. We propose here to only keep the diagonal part
of ARe,n
TF for preconditioning, that is, to include the potential and nonlinear self-interactions in each
gas. Concretely, we build the following diagonal TF preconditioner PRe,nTF,diag given by
1 Re,n+1/2 −1
INc 1
PRe,n
TF,diag := i − Vdiag − Mdiag ,
∆t 2 2
Re,n+1/2 Re,n+1/2
where Vdiag := (V`` )`=1,...,Nc and Mdiag := (M`` )`=1,...,Nc .
We can also build the full TF preconditioner PRe,n
by including the full potential and nonlinear
TF,full
operators and inverting the matrix. This preconditioner is therefore given by
1 Re,n+1/2 −1
Re,n INc 1
PTF,full := i − V− M .
∆t 2 2
Finally, we have the Laplace preconditioner PRe
∆ which is built by inverting the laplacian, which
is a diagonal operator in the frequencies space, by using a fast Fourier transform. It is given by
−1
Re INc 1
P∆ := i + [[∆]] .
∆t 4
92CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
1
i∂t ψ(t, x) = − ∆ψ(t, x) + V (ẇ(t), x)ψ(t, x) + β|ψ(t, x)|2 ψ(t, x) − ΩLz ψ, x ∈ R2 , t > 0,
2
NX
stoch
and {ẇ(t)}t≥0 is the time derivative of a multidimensional noise w(t) = (w1 (t), ..., wNstoch (t)). Here,
we will focus ourselves on the two previous schemes that we have introduced to solve such equations:
the time splitting scheme and the relaxation scheme.
2) and next
i∂t ψ2 (t, x) = V (ẇ(t), x)ψ2 (t, x) + β|ψ2 (t, x)|2 ψ2 (t, x), n∆t < t ≤ (n + 1)∆t,
(5.32)
ψ2 (n∆t, x) = ψ1 ((n + 1)∆t, x).
Equation (5.31) is solved using the ADI technique and fast Fourier transforms (see section 5.1.1,
page 85). Concerning equation (5.32), we have seen in section 5.1.1 that we can exactly integrate
the nonlinearity and the time-dependent potential in time. Therefore we obtain, for all n∆t < t ≤
(n + 1)∆t,
2 (t−t )−i t
R
ψ2 (t, x) = ψ1 ((n + 1)∆t, x)e−iβ|ψ1 ((n+1)∆t,x)| n tn V (ẇ(s),x)ds
.
Z t NX
stoch Z t NX
stoch
V (ẇ(s), x)ds = Vj (x)ẇj (s)ds = Vj (x)(wj (t) − wj (tn )) = V (w(t) − w(tn ), x).
tn j=1 tn j=1
Z tn+1 NX
stoch Z tn+1
V (ẇ(s), x)ψ(s, x)ds = Vj (x) ẇj (s)ψ(s, x)ds
tn j=1 tn
NX
stoch
ψ(tn+1 , x) + ψ(tn , x)
≈ Vj (x) (wj (tn+1 ) − wj (tn )).
2
j=1
Therefore, for our stochastic Gross-Pitaevskii equation, we obtain the following relaxation
scheme
φn+1/2 + φn−1/2
= β|ψ n |2 ,
2 (5.33)
ψ n+1 − ψ n
n+1
+ ψn
n+1
+ ψn
1 n ψ n+1/2 ψ
i = (− ∆ − ΩLz + V ) +φ ,
∆t 2 2 2
w(tn+1 )−w(tn )
where φn+1/2 = φ(tn+1/2 , x), ψ n = ψ(tn , x) and V n = V ∆t ,x . The initial conditions
are ψ 0 (x) = ψ0 (x) and φ−1/2 (x) = β|ψ0 (x)|2 .
(∆t)p (∆t)p+1
u∆t/2 = u + Cp + C p+1 + o((∆t)p+1 ). (5.35)
2p 2p+1
The Richardson’s extrapolation method consists in combining the approximations (5.34) and (5.35)
to eliminate the error term Cp (∆t)p . It is easy to see that
This equation provides an approximation v∆t/2 which is at least of order p + 1. In fact, depending
on the scheme used, it is possible to even gain a higher order of accuracy. This process can be used
iteratively to get high-order schemes. This results in the following triangular table
94CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
Approximations Extrapolations
In GPELab, the Richardson’s extrapolation method is used for the TSSP and ReSP schemes to
get an increased accuracy in time.
The Method_Var2d function creates the Method structure that contains all the parameters rela-
tive to the method. We refer to section 3.5.1, page 41, for further details. The optional arguments
are the following
• Type (S, ’BESP’) is a variable corresponding to the scheme used in the computation. In the
case of a dynamical computation, it must either be ’Splitting’ to use a splitting scheme
(see section 5.1, page 83) or ’Relaxation’ to use the relaxation scheme (see section 5.2, page
89).
• Deltat (R+ ,1e-3) is a variable corresponding to the time step of the method. The time
discretization is always uniform.
5.5. GPELAB FUNCTIONS FOR THE DYNAMICS 95
• Stop_time (R+ ,1) is a variable corresponding to the final time of computation in the case of
a dynamic problem. This corresponds to the following stopping criterion
Iter = 0
while { Deltat*Iter < Stop_time }
Compute the solution of the dynamic problem at iteration Iter for Deltat
Iter = Iter + 1
end
• Stop_crit (R+ ,1e-8) is a variable corresponding to the stopping criterion in the case of a
ground state computation (see section 3.5.1, page 41).
• Max_iter (N, 1e6) is a variable corresponding to the maximum number of iterations for a
stationary state computation.
• Output (N,1) is a variable that must either be 1 if one computes outputs during the compu-
tations or 0 if not.
• Splitting (S,’Strang’) is a variable that must be either ’Lie’ to use the Lie type of splitting,
’Strang’ to use the Strang type of splitting or ’Fourth’ to use the Fourth-order type of
splitting for the splitting scheme.
• BESP (N,0) is a variable corresponding to the type of method used to invert the linear system
in BESP (see section 3.5.1, page 41).
• Solver_FD (N,0) is a variable corresponding to the type of method used to invert the linear
system in BEFD (see section 3.5.1, page 41)
• Iterative_tol (R+ , 1e-9) is a variable corresponding to the stopping criterion related to the
difference between two successive iterates in the Krylov solver.
For example, we want to compute the dynamic solution for a single-component BEC by using
a splitting scheme. We choose a time step ∆t = 10−3 , a stopping time T = 1 and the Laplace
preconditioner. Moreover we choose to compute outputs during the simulation. This gives the code
in table 5.2.
We now want to set the physical problem. This is done exactly like in section 3.6, page 43. Here
we list some of the physical operators that are used only in a dynamic problem.
Computation = ’Dynamic;
Ncomponents = 1;
Type = ’Splitting’;
Deltat = 1e-3;
Stop_time = 1;
Stop_crit = [];
Max_iter = [];
Precond_type = ’Laplace’;
Output = 1;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time, Stop_crit,
Max_iter, Precond_type, Output;
• TimePotential: If a function TimePotential in F(R+ , MNy ,Nx (R)2 ; MNy ,Nx (C)) is provided,
the physical time-dependent potential will be defined as follows, for each j, k ∈ {1, ..., Nc },
TimePotential(t, x, y) if j = k
Vj,k (t, x, y) =
0 if j 6= k
Note that in the case of a stationary state computation, the potential operator should be
time-independent.
• G (MNc ,Nc (C), ones(N_c)) is a complex-valued variable that is used to multiply each compo-
nent of the potential
For example, we want to set a quadratic potential with an intensity which varies in time. We
would like to set V (t, x) = ( 32 + cos(t))|x|2 for each component. To this end, we first need to create
a square cell array of functions such that the diagonal part is the desired potential and 0 otherwise.
This is done in table 5.4 where we set the cell array of functions and then modify the Physics2D
by using the TimePotential_Var2d function.
5.5. GPELAB FUNCTIONS FOR THE DYNAMICS 97
function P = Example_timepotential(Method)
Ncomp = Method.Ncomponents;
P = cell(Ncomp);
for j = 1:Ncomp
for k = 1:Ncomp
if (j==k)
P{j,k} = @(t,x,y) (3/2+cos(t))*(x.^2+y.^2)
else
P{j,k} = @(t,x,y) 0
end
end
end
Physics2D = TimePotential_Var2d(Method, Physics2D, Example_timepotential(Method)
);
• G (MNc ,Nc (C), ones(N_c)) is a complex-valued variable that is used to multiply each compo-
nent of the potential
Vj,k (ẇ(t)x, y) = G(j, k)StochasticPotential{j, k}(ẇ(t), x, y)
for j, k ∈ {1, ..., Nc }.
98CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
function P = Example_stochasticpotential(Method)
Ncomp = Method.Ncomponents;
P = cell(Ncomp);
for j = 1:Ncomp
for k = 1:Ncomp
if (j==k)
P{j,k} = @(W,x,y(1/2)*(x.^2*W{1}+y.^2 W{2})
else
P{j,k} = @(W,x,y) 0
end
end
end
functionW = Example_stochasticprocess(Method)
W = cell(1,2);
W{1} = Brownian_Process2d(Method);
W{2} = Brownian_Process2d(Method);
end
Physics2D = TimePotential_Var2d(Method, Physics2D, ...
Example_stochasticpotential(Method), [] , Example_stochasticprocess(Method) );
The initial data can be set using the InitialData_Var2d function (see section 3.6.6, page 53)
just like in the stationary case. The outputs of a computation are set using the OutputsINI_Var2d
function (see section 3.7.1, page 53). We remark that the outputs are computed like in the stationary
case, that is we have to set the variable Evo_outputs which corresponds to the number of iterations
between each computation of the outputs. Here the number of iterations corresponds to the number
of time steps. We also need the Print and Figure structures, which are built using the Print_Var2d
function (see section 3.7.3, page 58) and Figure_Var2d function (see sections 3.7.4, page 59, and
3.7.5, page 59) respectively. Finally, we use the GPELab2d function to launch the simulation (see
section 3.7.6, page 60).
structures. We want to use a ’Splitting’ scheme and a step time of 10−3 , with a spatial grid of
210 + 1 points on the interval [−15, 15]. Moreover, we want to set the stopping time to 1. All of
this is coded in Table 5.7.
Computation = ’Dynamic’;
Ncomponents = 1;
Type = ’Splitting’;
Deltat = 1e-3;
Stop_time = 1;
Stop_crit = [];
Method = Method_Var1d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -15;
xmax = 15;
Nx = 2^10+1;
Geometry1D = Geometry1D_Var1d(xmin,xmax, Nx);
We now have to define the physics of the problem. We want to compute the soliton for the
following Gross-Pitaevskii equation.
i∂t Ψ(t, x) = ∆Ψ(t, x) + β|Ψ(t, x)|2 Ψ(t, x)
with β = −10. We know that the default nonlinearity is the cubic nonlinearity. Therefore, we only
have to build the Physics1D structure with the desired coefficients and to add the default non linear
operator to the physics of the problem. We report on Table 5.8 how it is coded.
Delta = 1;
Beta = -10;
Physics1D = Physics1D_Var1d(Method,Delta,Beta);
Physics1D = Nonlinearity_Var1d(Method, Physics1D);
Table 5.8: Setting the Physics1D structure and adding the nonlinear operator.
We then set the initial function to use for the computation. We want to simulate a soliton and
we would like the initial data to be like
r
2a √ c
Ψ0 (x) = sech( ax) exp i x + iθ0
100 2
To do so, we have to use the mesh grid contained in the geometry structure and define the initial
data. We choose the following parameters: a = 1, c = 5 and θ0 = 0. This is done in Table 5.9.
a = 1 ;
c = 5 ;
theta0 = 0 ;
X = Geometry1D.X ;
Phi_0{1} = sqrt(2*a/100)*sech(sqrt(a)*X).*exp(1i*c*X/2+1i*theta0);
We want to save the position of the center of the soliton, corresponding to the position of its
highest module, as an output. Therefore, we define the function that locates the center of the
soliton, which done in Table 5.10.
100CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
We finally set the outputs and the printing informations, then we launch the simulation. We
choose to print informations in the command window every 15 iterations and to draw a figure of
the square of the module of the solution. Moreover, we add the previous function as an output
to compute with the name ’Center of the soliton’ and we want it to be computed each 10
iterations. We do not save the solution during the simulation. This is done in Table 5.11.
Solution_save = 0;
Outputs_iterations = 10;
Output_function{1} = @(Phi,X)Soliton_center(Phi,X);
Output_name{1} = ’Center of the soliton’;
Outputs = OutputsINI_Var1d(Method,Outputs_iterations,Solution_save,Output_function,...
Output_name);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var1d(Printing,Evo,Draw);
[Phi,Outputs]= GPELab1d(Phi_0,Method,Geometry1D,Physics1D,Outputs,[],Print);
Table 5.11: Setting the outputs and the Print structure then launching the simulation.
At the end of the simulation, we can retrieve the informations about the soliton using the
Outputs structure. For instance, we have computed the center of the soliton at each 10 iterations.
We can print it using the plot function from Matlab. This is coded in Table 5.12.
Time = [0:0.01:1];
plot(Time, Outputs.User_defined_local{1})
xlabel(’Time’)
ylabel(’Center of the soliton’)
We obtain Figure 5.1(a). We can also plot the evolution of the energy and the chemical potential,
which are conserved quantities, and can be seen on Figure 5.1(b).
6 3
5 2.5
4 2
Center of the soliton
3 1.5
Energy
Chemical Potential
2 1
1 0.5
0 0
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1 0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
Time Time
(a) Evolution of the center of the soliton. (b) Evolution of the energy of the soliton.
Computation = ’Ground’;
Ncomponents = 1;
Type = ’BESP’;
Deltat = 1e-1;
Stop_time = [];
Stop_crit = 1e-8;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
xmin = -10;
xmax = 10;
ymin = -10;
ymax = 10;
Nx = 2^9+1;
Ny = 2^9+1;
Geometry2D = Geometry2D_Var2d(xmin,xmax, ymin,ymax, Nx, Ny);
Table 5.13: Building the Method and Geometry2D structures for the computation of a stationary
state.
Delta = 0.5;
Beta = 10000;
Physics2D = Physics2D_Var2d(Method,Delta,Beta);
Physics2D = Potential_Var2d(Method, Physics2D, @(x,y) (1/2)*(x.^2+y.^2));
Physics2D = Nonlinearity_Var2d(Method, Physics2D, @(phi,x,y) abs(phi).^2 );
Table 5.14: Setting the Physics2D structure to compute the stationary state.
We wish to use the Thomas-Fermi approximation as an initial wave function for the computation.
102CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
Therefore, we set the initial data using the InitialData_Var2d as in Table 5.15
InitialData_choice = 2 ;
Phi_0 = InitialData_Var2d(Method, Geometry2D, Physics2D,InitialData_choice);
We finally launch the simulation. We set the defaults Outputs using the OutputsINI_Var2d
function and the default Print structure using the Print_Var2d function. Then we launch the
computation using the GPELab2d function and store the ground state under the variable Phi_1.
This is done in Table 5.16
Outputs = OutputsINI_Var2d(Method);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var2d(Printing,Evo,Draw);
[Phi_1,Outputs]= GPELab2d(Phi_0,Method,Geometry2D,Physics2D,Outputs,[],Print);
At the end of the computation, we obtain the ground state whose modulus is depicted in Figure
5.2.
Figure 5.2: Ground state computed with GPELab using the parameters from Section 5.6.2.
It is now possible to phase imprint a dark soliton in the Bose-Einstein condensate and simulate
its time evolution. First, we have to rebuild the Method structure for this dynamical problem. We
want to use a ’Relaxation’ scheme and a step time of 10−3 . Moreover, we want to set the stopping
time to 1.5. We coded this in GPELab as in Table 5.17.
We now have to phase-imprint the dark soliton [24]. This is done by multiplying the initial data
by
∆θ0 x−x0
i 1+tanh
ξ(x, y) = e 2 s
where ∆θ0 = π/3, x0 = 5 and s = 0.2. This is done in Table 5.18 where we multiply the ground
state Phi_1 by the previous function.
We finally set the outputs and the printing informations, then we launch the simulation. We
choose to print informations in the command window every 15 iterations and to draw a figure of
5.6. EXAMPLES OF COMPUTATIONS 103
Computation = ’Dynamic’;
Ncomponents = 1;
Type = ’Relaxation’;
Deltat = 1e-3;
Stop_time = 1.5;
Stop_crit = [];
Method = Method_Var1d(Computation,Ncomponents, Type, Deltat, Stop_time ,
Stop_crit);
X_0 = 5;
ăDelta_theta_0 = pi/3;
s = 0.2;
ăPhi_1{1} = Phi_1{1}.*exp(1i*(Delta_theta_0/2)*(1+tanh((Geometry2D.X-X_0)./s)));
save = 1;
Evo_save = 100;
Outputs = OutputsINI_Var1d(Method,save,Evo_save);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var1d(Printing,Evo,Draw);
Figure = Figure_Var1d(’hot’);
[Phi,Outputs]= GPELab1d(Phi_1,Method,Geometry1D,Physics1D,Outputs,[],Print,Figure);
the square of the module of the solution. Moreover, we choose to draw the figure using the ’hot’
colormap, which is done using the function Figure_Var2d and to save the solution.
At the end of the simulation, we obtain the saved solution in the outputs which can be used to
print the modulus of the solution and show the evolution of the dark soliton in the Bose-Einstein
condensate. This can be seen on Figure 5.3. We can also plot the evolution of the energy
We now show how to compute the dynamic of a fast rotating Bose-Einstein condensate when
changing the intensity of the potential. The initial data for this simulation is the ground state
computed in section 4.4. Therefore, we assume that Phi_1 is the ground state that is already
computed.
First, we build the Method and Geometry2D structures. We remark that the geometry must be
the same as in section 4.4. We choose to use the fourth order splitting scheme to compute the
dynamic of the solution. This is done by directly changing the variable Splitting in the Method
structure. We fix the time step ∆t = 10−3 and the stopping time T = 1. The geometry is set on a
computational domain O =] − 10, 10[×] − 10, 10[ and the number of grid points J = K = 28 . This
is coded in Table 5.19.
Now, we define the physical problem. In this case, we want to keep the same physical operators
as the one used for the computation of the stationary state but we change the parameters of the
104CHAPTER 5. COMPUTATION OF THE DYNAMICS OF GPE: METHODS, FUNCTIONS, EXAMPLES
(a) Soliton at time t = 0.25. (b) Soliton at time t = 0.5. (c) Soliton at time t = 0.75.
(d) Soliton at time t = 1. (e) Soliton at time t = 1.25. (f) Soliton at time t = 1.5.
Computation = ’Dynamic’;
Ncomponents = 1;
Type = ’Splitting’;
Deltat = 1e-3;
Stop_time = 1;
Method = Method_Var2d(Computation,Ncomponents, Type, Deltat, Stop_time);
Method.Splitting = ’Fourth’;
xmin = -10;
xmax = 10;
ymin = -10;
ymax = 10;
Nx = 2^8+1;
Ny = 2^8+1;
Geometry2D = Geometry2D_Var2d(xmin,xmax, ymin,ymax, Nx, Ny);
Table 5.19: Building the Method and Geometry2D structures for the simulation.
with the parameters α = 1.2, κ = 0.7, γx = γy = 1, β = 1000 and Ω = 3.5. Here, we have
changed the parameter κ from 0.3 for the stationary to 0.7 for the dynamical problem. We define
the potential operator and add the defaults nonlinear and gardients operators. The resulting code
can be seen in Table 5.20.
We finally launch the simulation. We set the defaults Outputs that we compute each 100
iterations and store the solution using the OutputsINI_Var2d function. Moreover, we build the
5.6. EXAMPLES OF COMPUTATIONS 105
Delta = 0.5;
Beta = 1000;
Omega = 3.5;
Physics2D = Physics2D_Var2d(Method,Delta,Beta,Omega);
Alpha = 1.2;
Kappa = 0.7;
Gamma_x = 1;
Gamma_y = 1;
Physics2D = Potential_Var2d(Method, Physics2D,...
@(X,Y) quadratic_plus_quartic_potential2d(Gamma_x, Gamma_y,Alpha,Kappa,X,Y));
Physics2D = Nonlinearity_Var2d(Method, Physics2D);
Physics2D = Gradientx_Var2d(Method, Physics2D);
Physics2D = Gradienty_Var2d(Method, Physics2D);
default Print structure using the Print_Var2d function. Then we launch the computation using
the GPELab2d function. This is done in Table 5.21.
Outputs_iterations = 100;
Outputs_save = 1:
Outputs = OutputsINI_Var2d(Method,Outputs_iterations,Outputs_save);
Printing = 1;
Evo = 15;
Draw = 1;
Print = Print_Var2d(Printing,Evo,Draw);
[Phi_2,Outputs]= GPELab2d(Phi_1,Method,Geometry2D,Physics2D,Outputs,[],Print);
At the end of the simulation, we obtain the saved solution in the outputs which can be used to
show the evolution of the rotating Bose-Einstein condensate. This evolution can be seen on Figure
5.4.
We can also plot the evolution of the x_rms and y_rms. This is done in Table 5.22. The resulting
figures can be seen on Figure 5.5.
Time = [0:0.01:1];
plot(Time, Outputs.x_rms{1})
xlabel(’Time’)
ylabel(’Root Mean Square in the x-direction’)
(a) BEC at time t = 0. (b) BEC at time t = 0.12. (c) BEC at time t = 0.23.
(d) BEC at time t = 0.34. (e) BEC at time t = 0.45. (f) BEC at time t = 0.56.
Figure 5.4: Evolution of a fast rotating Bose-Einstein condensate when changing the intensity of
the potential.
4.8 4.8
4.6 4.6
4.4 4.4
4.2 4.2
x−rms
y−rms
4 4
3.8 3.8
3.6 3.6
3.4 3.4
0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1 0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1
Time Time
(a) Evolution of the mean root square in the x- (b) Evolution of the mean root square in the y-
direction. direction.
Figure 5.5: Evolution of the root mean square in the x- and y-direction.
Appendix A
Xavier Antoine
<xavier.antoine at univ-lorraine.fr>
and
Romain Duboscq
<romain.duboscq at univ-lorraine.fr>
107
108 APPENDIX A. COPYRIGHTS & CREDITS
Appendix B
License
Preamble.
The GNU General Public License is a free, copyleft license for software and other kinds of works.
The licenses for most software and other practical works are designed to take away your freedom
to share and change the works. By contrast, the GNU General Public License is intended to
guarantee your freedom to share and change all versions of a program–to make sure it remains free
software for all its users. We, the Free Software Foundation, use the GNU General Public License
for most of our software; it applies also to any other work released this way by its authors. You can
apply it to your programs, too.
When we speak of free software, we are referring to freedom, not price. Our General Public
Licenses are designed to make sure that you have the freedom to distribute copies of free software
(and charge for them if you wish), that you receive source code or can get it if you want it, that
you can change the software or use pieces of it in new free programs, and that you know you can
do these things.
To protect your rights, we need to prevent others from denying you these rights or asking you
to surrender the rights. Therefore, you have certain responsibilities if you distribute copies of the
software, or if you modify it: responsibilities to respect the freedom of others.
For example, if you distribute copies of such a program, whether gratis or for a fee, you must
pass on to the recipients the same freedoms that you received. You must make sure that they, too,
receive or can get the source code. And you must show them these terms so they know their rights.
Developers that use the GNU GPL protect your rights with two steps: (1) assert copyright on
the software, and (2) offer you this License giving you legal permission to copy, distribute and/or
modify it.
109
110 APPENDIX B. LICENSE
For the developers’ and authors’ protection, the GPL clearly explains that there is no warranty
for this free software. For both users’ and authors’ sake, the GPL requires that modified versions be
marked as changed, so that their problems will not be attributed erroneously to authors of previous
versions.
Some devices are designed to deny users access to install or run modified versions of the software
inside them, although the manufacturer can do so. This is fundamentally incompatible with the aim
of protecting users’ freedom to change the software. The systematic pattern of such abuse occurs
in the area of products for individuals to use, which is precisely where it is most unacceptable.
Therefore, we have designed this version of the GPL to prohibit the practice for those products.
If such problems arise substantially in other domains, we stand ready to extend this provision to
those domains in future versions of the GPL, as needed to protect the freedom of users.
Finally, every program is threatened constantly by software patents. States should not allow
patents to restrict development and use of software on general-purpose computers, but in those
that do, we wish to avoid the special danger that patents applied to a free program could make it
effectively proprietary. To prevent this, the GPL assures that patents cannot be used to render the
program non-free.
The precise terms and conditions for copying, distribution and modification follow.
0. Definitions.
”Copyright” also means copyright-like laws that apply to other kinds of works, such as semicon-
ductor masks.
”The Program” refers to any copyrightable work licensed under this License. Each licensee is
addressed as ”you”.”Licensees” and ”recipients” may be individuals or organizations.
To ”modify” a work means to copy from or adapt all or part of the work in a fashion requiring
copyright permission, other than the making of an exact copy. The resulting work is called a
”modified version” of the earlier work or a work ”based on” the earlier work.
A ”covered work” means either the unmodified Program or a work based on the Program.
To ”propagate” a work means to do anything with it that, without permission, would make you
directly or secondarily liable for infringement under applicable copyright law, except executing it
on a computer or modifying a private copy. Propagation includes copying, distribution (with or
without modification), making available to the public, and in some countries other activities as well.
To ”convey” a work means any kind of propagation that enables other parties to make or receive
copies. Mere interaction with a user through a computer network, with no transfer of a copy, is not
conveying.
An interactive user interface displays ”Appropriate Legal Notices” to the extent that it includes
a convenient and prominently visible feature that (1) displays an appropriate copyright notice, and
111
(2) tells the user that there is no warranty for the work (except to the extent that warranties are
provided), that licensees may convey the work under this License, and how to view a copy of this
License. If the interface presents a list of user commands or options, such as a menu, a prominent
item in the list meets this criterion.
1. Source Code.
The ”source code” for a work means the preferred form of the work for making modifications to
it. ”Object code” means any non-source form of a work.
A ”Standard Interface” means an interface that either is an official standard defined by a recog-
nized standards body, or, in the case of interfaces specified for a particular programming language,
one that is widely used among developers working in that language.
The ”System Libraries” of an executable work include anything, other than the work as a whole,
that (a) is included in the normal form of packaging a Major Component, but which is not part of
that Major Component, and (b) serves only to enable use of the work with that Major Component, or
to implement a Standard Interface for which an implementation is available to the public in source
code form. A ”Major Component”, in this context, means a major essential component (kernel,
window system, and so on) of the specific operating system (if any) on which the executable work
runs, or a compiler used to produce the work, or an object code interpreter used to run it.
The ”Corresponding Source” for a work in object code form means all the source code needed to
generate, install, and (for an executable work) run the object code and to modify the work, including
scripts to control those activities. However, it does not include the work’s System Libraries, or
general-purpose tools or generally available free programs which are used unmodified in performing
those activities but which are not part of the work. For example, Corresponding Source includes
interface definition files associated with source files for the work, and the source code for shared
libraries and dynamically linked subprograms that the work is specifically designed to require, such
as by intimate data communication or control flow between those subprograms and other parts of
the work.
The Corresponding Source need not include anything that users can regenerate automatically
from other parts of the Corresponding Source.
The Corresponding Source for a work in source code form is that same work.
2. Basic Permissions.
All rights granted under this License are granted for the term of copyright on the Program,
and are irrevocable provided the stated conditions are met. This License explicitly affirms your
unlimited permission to run the unmodified Program. The output from running a covered work
is covered by this License only if the output, given its content, constitutes a covered work. This
License acknowledges your rights of fair use or other equivalent, as provided by copyright law.
You may make, run and propagate covered works that you do not convey, without conditions
so long as your license otherwise remains in force. You may convey covered works to others for the
sole purpose of having them make modifications exclusively for you, or provide you with facilities
for running those works, provided that you comply with the terms of this License in conveying all
material for which you do not control copyright. Those thus making or running the covered works
for you must do so exclusively on your behalf, under your direction and control, on terms that
112 APPENDIX B. LICENSE
prohibit them from making any copies of your copyrighted material outside their relationship with
you.
Conveying under any other circumstances is permitted solely under the conditions stated below.
Sublicensing is not allowed; section 10 makes it unnecessary.
No covered work shall be deemed part of an effective technological measure under any applicable
law fulfilling obligations under article 11 of the WIPO copyright treaty adopted on 20 December
1996, or similar laws prohibiting or restricting circumvention of such measures.
When you convey a covered work, you waive any legal power to forbid circumvention of techno-
logical measures to the extent such circumvention is effected by exercising rights under this License
with respect to the covered work, and you disclaim any intention to limit operation or modification
of the work as a means of enforcing, against the work’s users, your or third parties’ legal rights to
forbid circumvention of technological measures.
You may convey verbatim copies of the Program’s source code as you receive it, in any medium,
provided that you conspicuously and appropriately publish on each copy an appropriate copyright
notice; keep intact all notices stating that this License and any non-permissive terms added in
accord with section 7 apply to the code; keep intact all notices of the absence of any warranty; and
give all recipients a copy of this License along with the Program.
You may charge any price or no price for each copy that you convey, and you may offer support
or warranty protection for a fee.
You may convey a work based on the Program, or the modifications to produce it from the
Program, in the form of source code under the terms of section 4, provided that you also meet all
of these conditions:
a) The work must carry prominent notices stating that you modified it, and giving a relevant date.
b) The work must carry prominent notices stating that it is released under this License and any
conditions added under section 7. This requirement modifies the requirement in section 4 to ”keep
intact all notices”.
c) You must license the entire work, as a whole, under this License to anyone who comes into pos-
session of a copy. This License will therefore apply, along with any applicable section 7 additional
terms, to the whole of the work, and all its parts, regardless of how they are packaged. This License
gives no permission to license the work in any other way, but it does not invalidate such permission
if you have separately received it.
d) If the work has interactive user interfaces, each must display Appropriate Legal Notices; however,
if the Program has interactive interfaces that do not display Appropriate Legal Notices, your work
113
need not make them do so. A compilation of a covered work with other separate and independent
works, which are not by their nature extensions of the covered work, and which are not combined
with it such as to form a larger program, in or on a volume of a storage or distribution medium, is
called an ”aggregate” if the compilation and its resulting copyright are not used to limit the access
or legal rights of the compilation’s users beyond what the individual works permit. Inclusion of a
covered work in an aggregate does not cause this License to apply to the other parts of the aggregate.
You may convey a covered work in object code form under the terms of sections 4 and 5, provided
that you also convey the machine-readable Corresponding Source under the terms of this License,
in one of these ways:
a) Convey the object code in, or embodied in, a physical product (including a physical distribution
medium), accompanied by the Corresponding Source fixed on a durable physical medium custom-
arily used for software interchange.
b) Convey the object code in, or embodied in, a physical product (including a physical distribution
medium), accompanied by a written offer, valid for at least three years and valid for as long as you
offer spare parts or customer support for that product model, to give anyone who possesses the
object code either (1) a copy of the Corresponding Source for all the software in the product that is
covered by this License, on a durable physical medium customarily used for software interchange,
for a price no more than your reasonable cost of physically performing this conveying of source, or
(2) access to copy the Corresponding Source from a network server at no charge.
c) Convey individual copies of the object code with a copy of the written offer to provide the
Corresponding Source. This alternative is allowed only occasionally and noncommercially, and only
if you received the object code with such an offer, in accord with subsection 6b.
d) Convey the object code by offering access from a designated place (gratis or for a charge), and
offer equivalent access to the Corresponding Source in the same way through the same place at no
further charge. You need not require recipients to copy the Corresponding Source along with the
object code. If the place to copy the object code is a network server, the Corresponding Source
may be on a different server (operated by you or a third party) that supports equivalent copying
facilities, provided you maintain clear directions next to the object code saying where to find the
Corresponding Source. Regardless of what server hosts the Corresponding Source, you remain
obligated to ensure that it is available for as long as needed to satisfy these requirements.
e) Convey the object code using peer-to-peer transmission, provided you inform other peers where
the object code and Corresponding Source of the work are being offered to the general public at no
charge under subsection 6d. A separable portion of the object code, whose source code is excluded
from the Corresponding Source as a System Library, need not be included in conveying the object
code work.
A ”User Product” is either (1) a ”consumer product”, which means any tangible personal property
which is normally used for personal, family, or household purposes, or (2) anything designed or sold
for incorporation into a dwelling. In determining whether a product is a consumer product, doubtful
cases shall be resolved in favor of coverage. For a particular product received by a particular user,
”normally used” refers to a typical or common use of that class of product, regardless of the status
of the particular user or of the way in which the particular user actually uses, or expects or is
114 APPENDIX B. LICENSE
expected to use, the product. A product is a consumer product regardless of whether the product
has substantial commercial, industrial or non-consumer uses, unless such uses represent the only
significant mode of use of the product.
”Installation Information” for a User Product means any methods, procedures, authorization
keys, or other information required to install and execute modified versions of a covered work in
that User Product from a modified version of its Corresponding Source. The information must
suffice to ensure that the continued functioning of the modified object code is in no case prevented
or interfered with solely because modification has been made.
If you convey an object code work under this section in, or with, or specifically for use in, a User
Product, and the conveying occurs as part of a transaction in which the right of possession and use
of the User Product is transferred to the recipient in perpetuity or for a fixed term (regardless of
how the transaction is characterized), the Corresponding Source conveyed under this section must
be accompanied by the Installation Information. But this requirement does not apply if neither
you nor any third party retains the ability to install modified object code on the User Product (for
example, the work has been installed in ROM).
The requirement to provide Installation Information does not include a requirement to continue
to provide support service, warranty, or updates for a work that has been modified or installed
by the recipient, or for the User Product in which it has been modified or installed. Access to a
network may be denied when the modification itself materially and adversely affects the operation
of the network or violates the rules and protocols for communication across the network.
Corresponding Source conveyed, and Installation Information provided, in accord with this
section must be in a format that is publicly documented (and with an implementation available to
the public in source code form), and must require no special password or key for unpacking, reading
or copying.
7. Additional Terms.
”Additional permissions” are terms that supplement the terms of this License by making excep-
tions from one or more of its conditions. Additional permissions that are applicable to the entire
Program shall be treated as though they were included in this License, to the extent that they are
valid under applicable law. If additional permissions apply only to part of the Program, that part
may be used separately under those permissions, but the entire Program remains governed by this
License without regard to the additional permissions.
When you convey a copy of a covered work, you may at your option remove any additional
permissions from that copy, or from any part of it. (Additional permissions may be written to
require their own removal in certain cases when you modify the work.) You may place additional
permissions on material, added by you to a covered work, for which you have or can give appropriate
copyright permission.
Notwithstanding any other provision of this License, for material you add to a covered work, you
may (if authorized by the copyright holders of that material) supplement the terms of this License
with terms:
a) Disclaiming warranty or limiting liability differently from the terms of sections 15 and 16 of this
License; or
115
b) Requiring preservation of specified reasonable legal notices or author attributions in that material
or in the Appropriate Legal Notices displayed by works containing it; or
c) Prohibiting misrepresentation of the origin of that material, or requiring that modified versions
of such material be marked in reasonable ways as different from the original version; or
d) Limiting the use for publicity purposes of names of licensors or authors of the material; or
e) Declining to grant rights under trademark law for use of some trade names, trademarks, or service
marks; or
f) Requiring indemnification of licensors and authors of that material by anyone who conveys the
material (or modified versions of it) with contractual assumptions of liability to the recipient, for
any liability that these contractual assumptions directly impose on those licensors and authors. All
other non-permissive additional terms are considered ”further restrictions” within the meaning of
section 10. If the Program as you received it, or any part of it, contains a notice stating that it is
governed by this License along with a term that is a further restriction, you may remove that term.
If a license document contains a further restriction but permits relicensing or conveying under this
License, you may add to a covered work material governed by the terms of that license document,
provided that the further restriction does not survive such relicensing or conveying.
If you add terms to a covered work in accord with this section, you must place, in the relevant
source files, a statement of the additional terms that apply to those files, or a notice indicating
where to find the applicable terms.
Additional terms, permissive or non-permissive, may be stated in the form of a separately written
license, or stated as exceptions; the above requirements apply either way.
8. Termination.
You may not propagate or modify a covered work except as expressly provided under this
License. Any attempt otherwise to propagate or modify it is void, and will automatically terminate
your rights under this License (including any patent licenses granted under the third paragraph of
section 11).
However, if you cease all violation of this License, then your license from a particular copyright
holder is reinstated (a) provisionally, unless and until the copyright holder explicitly and finally
terminates your license, and (b) permanently, if the copyright holder fails to notify you of the
violation by some reasonable means prior to 60 days after the cessation.
Moreover, your license from a particular copyright holder is reinstated permanently if the copy-
right holder notifies you of the violation by some reasonable means, this is the first time you have
received notice of violation of this License (for any work) from that copyright holder, and you cure
the violation prior to 30 days after your receipt of the notice.
Termination of your rights under this section does not terminate the licenses of parties who
have received copies or rights from you under this License. If your rights have been terminated and
not permanently reinstated, you do not qualify to receive new licenses for the same material under
section 10.
116 APPENDIX B. LICENSE
You are not required to accept this License in order to receive or run a copy of the Program.
Ancillary propagation of a covered work occurring solely as a consequence of using peer-to-peer
transmission to receive a copy likewise does not require acceptance. However, nothing other than
this License grants you permission to propagate or modify any covered work. These actions infringe
copyright if you do not accept this License. Therefore, by modifying or propagating a covered work,
you indicate your acceptance of this License to do so.
Each time you convey a covered work, the recipient automatically receives a license from the
original licensors, to run, modify and propagate that work, subject to this License. You are not
responsible for enforcing compliance by third parties with this License.
You may not impose any further restrictions on the exercise of the rights granted or affirmed
under this License. For example, you may not impose a license fee, royalty, or other charge for
exercise of rights granted under this License, and you may not initiate litigation (including a cross-
claim or counterclaim in a lawsuit) alleging that any patent claim is infringed by making, using,
selling, offering for sale, or importing the Program or any portion of it.
11. Patents.
A ”contributor” is a copyright holder who authorizes use under this License of the Program or a
work on which the Program is based. The work thus licensed is called the contributor’s ”contributor
version”.
A contributor’s ”essential patent claims” are all patent claims owned or controlled by the con-
tributor, whether already acquired or hereafter acquired, that would be infringed by some manner,
permitted by this License, of making, using, or selling its contributor version, but do not include
claims that would be infringed only as a consequence of further modification of the contributor
version. For purposes of this definition, ”control” includes the right to grant patent sublicenses in a
manner consistent with the requirements of this License.
Each contributor grants you a non-exclusive, worldwide, royalty-free patent license under the
contributor’s essential patent claims, to make, use, sell, offer for sale, import and otherwise run,
modify and propagate the contents of its contributor version.
In the following three paragraphs, a ”patent license” is any express agreement or commitment,
however denominated, not to enforce a patent (such as an express permission to practice a patent
or covenant not to sue for patent infringement). To ”grant” such a patent license to a party means
to make such an agreement or commitment not to enforce a patent against the party.
If you convey a covered work, knowingly relying on a patent license, and the Corresponding
Source of the work is not available for anyone to copy, free of charge and under the terms of this
117
License, through a publicly available network server or other readily accessible means, then you must
either (1) cause the Corresponding Source to be so available, or (2) arrange to deprive yourself of
the benefit of the patent license for this particular work, or (3) arrange, in a manner consistent with
the requirements of this License, to extend the patent license to downstream recipients. ”Knowingly
relying” means you have actual knowledge that, but for the patent license, your conveying the
covered work in a country, or your recipient’s use of the covered work in a country, would infringe
one or more identifiable patents in that country that you have reason to believe are valid.
If, pursuant to or in connection with a single transaction or arrangement, you convey, or propa-
gate by procuring conveyance of, a covered work, and grant a patent license to some of the parties
receiving the covered work authorizing them to use, propagate, modify or convey a specific copy of
the covered work, then the patent license you grant is automatically extended to all recipients of
the covered work and works based on it.
A patent license is ”discriminatory” if it does not include within the scope of its coverage,
prohibits the exercise of, or is conditioned on the non-exercise of one or more of the rights that are
specifically granted under this License. You may not convey a covered work if you are a party to
an arrangement with a third party that is in the business of distributing software, under which you
make payment to the third party based on the extent of your activity of conveying the work, and
under which the third party grants, to any of the parties who would receive the covered work from
you, a discriminatory patent license (a) in connection with copies of the covered work conveyed by
you (or copies made from those copies), or (b) primarily for and in connection with specific products
or compilations that contain the covered work, unless you entered into that arrangement, or that
patent license was granted, prior to 28 March 2007.
Nothing in this License shall be construed as excluding or limiting any implied license or other
defenses to infringement that may otherwise be available to you under applicable patent law.
If conditions are imposed on you (whether by court order, agreement or otherwise) that con-
tradict the conditions of this License, they do not excuse you from the conditions of this License.
If you cannot convey a covered work so as to satisfy simultaneously your obligations under this
License and any other pertinent obligations, then as a consequence you may not convey it at all.
For example, if you agree to terms that obligate you to collect a royalty for further conveying from
those to whom you convey the Program, the only way you could satisfy both those terms and this
License would be to refrain entirely from conveying the Program.
Notwithstanding any other provision of this License, you have permission to link or combine any
covered work with a work licensed under version 3 of the GNU Affero General Public License into a
single combined work, and to convey the resulting work. The terms of this License will continue to
apply to the part which is the covered work, but the special requirements of the GNU Affero General
Public License, section 13, concerning interaction through a network will apply to the combination
as such.
The Free Software Foundation may publish revised and/or new versions of the GNU General
Public License from time to time. Such new versions will be similar in spirit to the present version,
but may differ in detail to address new problems or concerns.
118 APPENDIX B. LICENSE
Each version is given a distinguishing version number. If the Program specifies that a certain
numbered version of the GNU General Public License ”or any later version” applies to it, you have
the option of following the terms and conditions either of that numbered version or of any later
version published by the Free Software Foundation. If the Program does not specify a version
number of the GNU General Public License, you may choose any version ever published by the Free
Software Foundation.
If the Program specifies that a proxy can decide which future versions of the GNU General
Public License can be used, that proxy’s public statement of acceptance of a version permanently
authorizes you to choose that version for the Program.
Later license versions may give you additional or different permissions. However, no additional
obligations are imposed on any author or copyright holder as a result of your choosing to follow a
later version.
If the disclaimer of warranty and limitation of liability provided above cannot be given local
legal effect according to their terms, reviewing courts shall apply local law that most closely approx-
imates an absolute waiver of all civil liability in connection with the Program, unless a warranty or
assumption of liability accompanies a copy of the Program in return for a fee.
If you develop a new program, and you want it to be of the greatest possible use to the public,
the best way to achieve this is to make it free software which everyone can redistribute and change
under these terms.
To do so, attach the following notices to the program. It is safest to attach them to the start
of each source file to most effectively state the exclusion of warranty; and each file should have at
least the "copyright" line and a pointer to where the full notice is found.
<one line to give the program’s name and a brief idea of what it does.> Copyright (C) <year>
<name of author>
This program is free software: you can redistribute it and/or modify it under the terms of the
GNU General Public License as published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WAR-
RANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PAR-
TICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program.
If not, see: http://www.gnu.org/licenses/.
Also add information on how to contact you by electronic and paper mail.
If the program does terminal interaction, make it output a short notice like this when it starts
in an interactive mode:
<program> Copyright (C) <year> <name of author> This program comes with ABSOLUTELY
NO WARRANTY; for details type ‘show w’. This is free software, and you are welcome to redis-
tribute it under certain conditions; type ‘show c’ for details.
The hypothetical commands ‘show w’ and ‘show c’ should show the appropriate parts of the
General Public License. Of course, your program’s commands might be different; for a GUI interface,
you would use an "about box".
You should also get your employer (if you work as a programmer) or school, if any, to sign a
"copyright disclaimer" for the program, if necessary. For more information on this, and how to
apply and follow the GNU GPL, see <http://www.gnu.org/licenses/>.
The GNU General Public License does not permit incorporating your program into proprietary
programs. If your program is a subroutine library, you may consider it more useful to permit linking
proprietary applications with the library. If this is what you want to do, use the GNU Lesser General
Public License instead of this License. But first, please read http://www.gnu.org/philosophy/why-
not-lgpl.html.
120 APPENDIX B. LICENSE
Bibliography
[1] F. Kh. Abdullaev, B.B. Baizakov and V.V. Konotop, Dynamics of a Bose-Einstein condensate
in optical trap, Nonlinearity and Disorder: Theory and Applications, edited by F. Kh. Abdullaev,
O. Bang and M.P. Soerensen, NATO Science Series vol. 45, Kluwer Dodrecht (2001).
[2] F. Kh. Abdullaev, J.C. Bronski and R.M. Galimzyanov, Dynamics of a trapped 2D Bose-Einstein
condensate with periodically and randomly varying atomic scattering length, Physica D vol. 184,
pp. 319-332 (2003).
[3] J. Garnier, F. Kh. Abdullaev and B.B. Baizakov, Collapse of a Bose-Einstein condensate induced
by fluctuations of laser intensity, Phy. Rev. A vol. 69, 053607, pp. 369-386 (2004).
[4] R. Marty, On a splitting scheme for the nonlinear Schrödinger equation in a random media,
Commun. Math. Sci. 4 679-705 (2006).
[5] Engel, Klaus-Jochen; Nagel, Rainer, One-parameter semigroups for linear evolution equations,
Springer (2000).
[6] C. Besse, B. Bidégaray and S. Descombes, Order estimates in time of splitting methods for the
nonlinear schrödinger equation, SIAM J. Numer. Anal. Vol 40, No. 1, pp. 26-40 (2002).
[7] C. Besse, A relaxation scheme for the non-linear schrödinger equation, SIAM J. Numer. Anal.
Vol 42, No. 3, pp. 934-952 (2004).
[8] G. Da Prato and J. Zabczyk, Stochastic equations in infinite dimensions, Encyclopedia of math-
ematics and its applications, Cambridge University Press: Cambridge, England (1992).
[9] A. De Bouard and R. Fukuizumi, Stochastic fluctuations in the Gross-Pitaevskii equation, Non-
linearity 20, pp. 2821-2844 (2007).
[10] A. De Bouard and A. Debussche, The stochastic nonlinear Schrödinger equation in H1, Stochas-
tic Analysis and Appl., vol. 21, p. 97-126 (2003).
[11] A. De Bouard and R. Fukuizumi, Representation formula for stochastic Schrodinger evolution
equations and applications, preprint.
[12] W. Bao and H. Wang, An efficient and spectrally accurate numerical method for computing
dynamics of rotating Bose-Einstein condensates, J. of Comp. Physics, Vol 217, pp. 612-626
(2006).
[13] J. Lee and B. Fornberg, Some unconditionally stable time stepping methods for the 3-D
Maxwell’s equations, J. of Comp. and Applied Mathematics, Vol 166, Issue 2, pp. 497-523 (2004).
[14] E. Faou, Analysis of splitting methods for reaction-diffusion problems using stochastic calculus,
Math. Comp. Vol. 78, pp 1467-1483 (2009).
121
122 BIBLIOGRAPHY
[15] W. Bao, H. Wang and P. Markowich, Ground, symmetric and central vortex states in rotating
Bose-Einstein condensates, Comm. Math. Sci. 3 (1), pp.57-88 (2005).
[16] W. Bao and Q. Du, Computing the ground state solution of Bose-Einstein condensates by a
normalized gradient flow, SIAM J. Sci. Comput. 25 (5), pp.1674-1697 (2004).
[17] W. Bao and Y. Cai, Ground States of Two-component Bose-Einstein Condensates with an
Internal Atomic Josephson Junction, East Asia Journal on Applied Mathematics, Vol. 1, pp.
49-81, (2010).
[18] P. Pedri and L. Santos, Phys. Rev. Lett. 95, 200404 (2005).
[19] R. Zeng and Y. Zhang, Efficiently computing vortex lattices in rapid rotating Bose-Einstein
condensates, Comput. Phys. Comm. 180, pp.854-860 (2009).
[20] W. Bao and H. Wang, An efficient and spectrally accurate numerical method for computing
dynamics of rotating Bose-Einstein condensates, J. Comp. Phys. 217, pp.612-626 (2006).
[21] W. Bao, I-L. Chern and F.Y. Lim, Efficient and spectrally accurate numerical methods for
computing ground and first excited states in Bose-Einstein condensates, J. Comp. Phys. 219, pp
836-854 (2006). An efficient and spectrally accurate numerical method for computing dynamics
of rotating Bose-Einstein condensates, J. Comp. Phys. 217, pp.612-626 (2006).
[22] L. Wen, H. Xiong and B. Wu, Hidden vortices in a Bose-Einstein condensate in a rotating
double-well potential, Phys. Rev. A, 82, 053627 (2010).
[24] Denschlag, J and Simsarian, JE and Feder, DL and Clark, Charles W and Collins, LA and
Cubizolles, J and Deng, L and Hagley, EW and Helmerson, K and Reinhardt, WP and others,
Generating solitons by phase engineering of a Bose-Einstein condensate, Science 287, pp 97-101
(2000).