Open Access Article
This Open Access Article is licensed under a
Creative Commons Attribution 3.0 Unported Licence

Real-space grids and the Octopus code as tools for the development of new simulation approaches for electronic systems

Xavier Andrade *ab, David Strubbe c, Umberto De Giovannini d, Ask Hjorth Larsen d, Micael J. T. Oliveira e, Joseba Alberdi-Rodriguez df, Alejandro Varas d, Iris Theophilou g, Nicole Helbig g, Matthieu J. Verstraete e, Lorenzo Stella h, Fernando Nogueira i, Alán Aspuru-Guzik b, Alberto Castro jk, Miguel A. L. Marques l and Angel Rubio dm
aLawrence Livermore National Laboratory, Livermore, CA 94550, USA. E-mail: xavier@tddft.org
bDepartment of Chemistry and Chemical Biology, Harvard University, 12 Oxford Street, Cambridge, MA 02138, USA
cDepartment of Materials Science and Engineering, Massachusetts Institute of Technology, Cambridge, Massachusetts 02139, USA
dNano-Bio Spectroscopy Group and European Theoretical Spectroscopy Facility (ETSF), Universidad del País Vasco CFM CSIC-UPV/EHU-MPC & DIPC, 20018 Donostia-San Sebastián, Spain
eUnité Nanomat, Département de Physique, Université de Liège, Allée du 6 Août 17, B-4000 Liège, Belgium
fDept. of Computer Architecture and Technology, University of the Basque Country UPV/EHU, M. Lardizabal, 1, 20018 Donostia-San Sebastian, Spain
gPeter-Grünberg Institut and Institute for Advanced Simulation, Forschungszentrum Jülich, D-52425 Jülich, Germany
hAtomistic Simulation Centre, School of Mathematics and Physics, Queen's University Belfast, University Road, Belfast BT7 1NN, Northern Ireland, UK
iCenter for Computational Physics, University of Coimbra, Rua Larga, 3004-516 Coimbra, Portugal
jInstitute for Biocomputation and Physics of Complex Systems (BIFI) and Zaragoza Center for Advanced Modeling (ZCAM), University of Zaragoza, E-50009 Zaragoza, Spain
kARAID Foundation, María de Luna 11, Edificio CEEI Aragón, Zaragoza E-50018, Spain
lInstitut für Physik, Martin-Luther-Universität Halle-Wittenberg, Von-Seckendorff-Platz 1, 06120 Halle (Saale), Germany
mMax Planck Institute for the Structure and Dynamics of Matter, Hamburg, Germany

Received 19th January 2015 , Accepted 20th February 2015

First published on 20th February 2015


Abstract

Real-space grids are a powerful alternative for the simulation of electronic systems. One of the main advantages of the approach is the flexibility and simplicity of working directly in real space where the different fields are discretized on a grid, combined with competitive numerical performance and great potential for parallelization. These properties constitute a great advantage at the time of implementing and testing new physical models. Based on our experience with the Octopus code, in this article we discuss how the real-space approach has allowed for the recent development of new ideas for the simulation of electronic systems. Among these applications are approaches to calculate response properties, modeling of photoemission, optimal control of quantum systems, simulation of plasmonic systems, and the exact solution of the Schrödinger equation for low-dimensionality systems.


1 Introduction

The development of theoretical methods for the simulation of electronic systems is an active area of study. This interest has been fueled by the success of theoretical tools like density functional theory (DFT)1,2 that can predict many properties with good accuracy at a relatively modest computational cost. On the other hand, these same tools are not good enough for many applications,3 and more accurate and more efficient methods are required.

Current research in the area covers a broad range of aspects of electronic structure simulations: the development of novel theoretical frameworks, new or improved methods to calculate properties within existing theories, or even more efficient and scalable algorithms. In most cases, this theoretical work requires the development of test implementations to assess the properties and predictive power of the new methods.

The development of methods for the simulations of electrons requires continual feedback and iteration between theory and results from implementation, so the translation to code of new theory needs to be easy to implement and to modify. This is a factor that is usually not considered when comparing the broad range of methods and codes used by chemists, physicists and material scientists.

The most popular representations for electronic structure rely on basis sets that usually have a certain physical connection to the system being simulated. In chemistry, the method of choice is to use atomic orbitals as a basis to describe the orbitals of a molecule. When these atomic orbitals are expanded in Gaussian functions, it leads to an efficient method as many integrals can be calculated from analytic formulae.4 In condensed-matter physics, the traditional basis is a set of plane waves, which correspond to the eigenstates of a homogeneous electron gas. These physics-inspired basis sets have, however, some limitations. For example, it is not trivial to simulate crystalline systems using atomic orbitals,5 and, on the other hand, in plane-wave approaches finite systems must be approximated as periodic systems using a super-cell approach.

Several alternatives to atomic-orbital and plane-wave basis sets exist.6–10 One particular approach that does not depend on a basis set uses a grid to directly represent fields in real-space. The method was pioneered by Becke,11 who used a combination of radial grids centered around each atom. In 1994 Chelikowsky, Troullier and Saad12 presented a practical approach for the solution of the Kohn–Sham (KS) equations using uniform grids combined with pseudo-potentials. What made the approach competitive was the use of high-order finite differences to control the error of the Laplacian without requiring very dense meshes. From that moment, several real-space implementations have been presented.13–33

Discretizing in real-space grids does not benefit from a direct physical connection to the system being simulated. However, the method has other advantages. In first place, a real-space discretization is, in most cases, straight-forward to perform starting from the continuum description of the electronic problem. Operations like integration are directly translated into sums over the grid and differential operators can be discretized using finite differences. In fact, most electronic structure codes must rely on an auxiliary real-space discretization used, for example, for the calculation of the exchange and correlation (xc) term of DFT.

Grids are flexible enough to directly simulate different kinds of systems: finite, and fully or partially periodic. It is also possible to perform simulations with reduced (or increased) dimensionality. Additionally, the discretization error can be systematically and continuously controlled by adjusting the spacing between mesh points, and the physical extension of the grid.

The simple discretization and flexibility of the real space grids makes them an ideal framework to implement, develop and test new ideas. Modern electronic structure codes are quite complex, which means that researchers seldom can write a standalone code from scratch, but instead need to resort to existing codes to implement their developments.

From the many codes available, in our experience the real-space code Octopus22,34 provides an ideal framework for theory-development work. To illustrate this point, in this article we will explore some recent advances that have been made in computational electronic structure and that have been developed using the Octopus code as a base. We will pay special attention to the most unusual capabilities of the code, and in particular to the ones that have not been described in previous articles.22,34,35

2 The Octopus code

Octopus was started around 2000 in the group of professor Angel Rubio who, at that moment, was at the University of Valladolid, Spain. The first article using Octopus was published in 2001.36 Today, the code has grown to 200[thin space (1/6-em)]000 lines of code. Octopus receives contributions from many developers from several countries and its results have been used for hundreds of scientific publications.

The original purpose of Octopus was to perform real-time time-dependent density functional theory (TDDFT) calculations, a method that had been recently proposed at the time for the calculation of excited-state properties in molecules.37 Beyond this original feature, over the time the code has become able to perform many types of calculations of ground-state and excited-state properties. These include most of the standard features of a modern electronic-structure package and some not-so-common capabilities.

Among the current capabilities of Octopus are an efficient real-time TDDFT implementation for both finite and periodic systems.38,39 Some of the research presented in this article is based on that feature, such as the simulation of photoemission, quantum optimal control, and plasmonic systems. The code can also perform molecular-dynamics simulations in the Born–Oppenheimer and Ehrenfest approximations. It also implements a modified Ehrenfest approach for adiabatic molecular dynamics40,41 that has favorable scaling for large systems. Octopus can perform linear-response TDDFT calculations in different frameworks; these implementations are discussed in Sections 3 and 5. For visualization, analysis and post-processing, Octopus can export quantities such as the density, orbitals, the current density, or the time-dependent electron localization function42 to different formats, including the required DFT data to perform GW/Bethe–Salpeter calculations with the BerkeleyGW code.43

Octopus is publicly and freely available under the GPL free/open-source license, this includes all the releases as well as the development version. The code is written using the principles of object oriented programming. This means that the code is quite flexible and modular. It provides a full toolkit for code developers to perform the operations required for the implementation of new approaches for electronic-structure calculations.

In order to control the quality of the package, Octopus uses continuous integration tools. The code includes a set of tests that checks most of the functionality by verifying the calculation results. After a new change is committed to the main repository, a set of servers with different configurations compiles the code and runs a series of short tests. This setup quickly detects most of the problems in a commit, from syntax that a compiler will not accept, to unexpected changes in the results. Every night a more comprehensive set of tests is executed by these same servers. The test-suite framework is quite general and is also successfully in use for the BerkeleyGW43 and APE44 codes.

3 The Sternheimer formulation of linear-response

In textbooks, perturbation theory is formulated in terms of sums over states and response functions. These are useful theoretical constructions that permit a good description and understanding of the underlying physics. However, this is not always a good starting point for numerical applications, since it involves the calculation of a large number of eigenvectors, infinite sums over these eigenvectors, and functions that depend on two or more spatial variables.

An interesting approach that avoids the problems mentioned above is the formulation of perturbation theory in terms of differential equations for the variation of the wave-functions. In the literature, this is usually called the Sternheimer equation45 or density functional perturbation theory (DFPT).46 Although a perturbative technique, it avoids the use of empty states, and has a favorable scaling with the number of atoms.

Octopus implements a generalized version of the Sternheimer equation that is able to cope with both static and dynamic response in and out of resonance.47 The method is suited for linear and non-linear response; higher-order Sternheimer equations can be obtained for higher-order variations. For second-order response, however, we apply the 2n + 1 theorem (also known as Wigner's 2n + 1 rule)48,49 to get the coefficients directly from first-order response variations.

In the Sternheimer formalism, we consider the response to a monochromatic perturbative field λδ[v with combining circumflex](r)cos(ωt). This perturbation induces a variation in the time-dependent KS orbitals, which we denote δφn(r,ω). These variations allow us to calculate response observables, for example, the frequency-dependent polarizability.

In order to calculate the variations of the orbitals we need to solve a linear equation that only depends on the occupied orbitals (atomic units are used throughout)

 
{Ĥεn ± ω + φn(r, ±ω) = −[P with combining circumflex]cδĤω)φn(r),(1)
where the variation of the time-dependent density, given by
 
image file: c5cp00351b-t1.tif(2)
needs to be calculated self-consistently. The first-order variation of the KS Hamiltonian is
 
image file: c5cp00351b-t2.tif(3)
[P with combining circumflex]c is a projection operator, and η a positive infinitesimal, essential to obtain the correct position of the poles of the causal response function, and consequently to obtain the imaginary part of the polarizability and remove the divergences of the equation for resonant frequencies. In the usual implementation of DFPT, image file: c5cp00351b-t3.tif which effectively removes the components of δφn(r, ±ω) in the subspace of the occupied ground-state wave-functions. In linear response, these components do not contribute to the variation of the density.

We have found that it is not strictly necessary to project out the occupied subspace, the crucial part is simply to remove the projection of δφn on φn (and any other states degenerate with it), which is not physically meaningful and arises from a phase convention. To fix the phase, it is sufficient to apply a minimal projector image file: c5cp00351b-t4.tif. We optionally use this approach to obtain the entire response wavefunction, not just the projection in the unoccupied subspace, which is needed for obtaining effective masses in k·p theory. While the full projection can become time-consuming for large systems, it saves time overall since it increases the condition number of the matrix for the linear solver, and thus reduces the number of solver iterations required to attain a given precision.

We also have implemented the Sternheimer formalism when non-integer occupations are used, as appropriate for metallic systems. In this case weighted projectors are added to both sides of eqn (1).50 We have generalized the equations to the dynamic case.51 The modified Sternheimer equation is

 
image file: c5cp00351b-t5.tif(4)
where
 
αn = max(εF − 3σεn,0),(5)
 
image file: c5cp00351b-t6.tif(6)
σ is the broadening energy, and [small theta, Greek, tilde]ij is the smearing scheme's approximation to the Heaviside function θ((εiεj)/σ). Apart from semiconducting smearing (i.e. the original equation above, which corresponds to the zero temperature limit), the code offers the standard Fermi–Dirac,52 Methfessel–Paxton,53 spline,54 and cold55 smearing schemes. Additionally, we have developed a scheme for handling arbitrary fractional occupations, which do not have to be defined by a function of the energy eigenvalues.51

In order to solve eqn (1) we use a self-consistent iteration scheme similar to the one used for ground-state DFT. In each iteration we need to solve a sparse linear problem where the operator to invert is the shifted KS Hamiltonian. For real wavefunctions and a real shift (as for the static case), we can use conjugate gradients. When the shift is complex, a non-Hermitian iterative solver is required. We have found that a robust and efficient solver is the quasi-minimal residual (QMR) method.56

We can solve for linear response to various different perturbations. The most straight-forward case is the response of a finite system to an electric field [scr E, script letter E]i,ω with frequency ω in the direction i, where the perturbation operator is δ[v with combining circumflex] = [r with combining circumflex]i.47 In this case the polarizability can be calculated as

 
image file: c5cp00351b-t7.tif(7)
The calculation of the polarizability yields optical response properties (that can be extended to nonlinear response)47,57 and, for imaginary frequencies, van der Waals coefficients.58

It is also possible to use the formalism to compute vibrational properties for finite and periodic systems.46,59 Currently Octopus implements the calculations of vibrations for finite systems. In this case the perturbation operator is an infinitesimal ionic displacement ∂Ĥ/∂R = ∂[v with combining circumflex]α/∂R, for each direction i and atom α. The quantity to calculate is the dynamical matrix, or Hessian, given by

 
image file: c5cp00351b-t8.tif(8)
The contribution from the ion–ion interaction energy is
 
image file: c5cp00351b-t9.tif(9)
where Zα is the ionic charge of atom α. We have found that an alternative expression for the perturbation operator yields more accurate results when discretized. This is discussed in Section 6.

Vibrational frequencies ω are obtained by solving the eigenvalue equation

 
image file: c5cp00351b-t10.tif(10)
where mα is the mass for ion α. For a finite system of N atoms, there should be 3 zero-frequency translational modes and 3 zero-frequency rotational modes. However, they may appear at positive or imaginary frequencies, due to the finite size of the simulation domain, the discretization of the grid, and finite precision in solution of the ground state and Sternheimer equation. Improving convergence brings them closer to zero.

The Born effective charges can be computed from the response of the dipole moment to ionic displacement:

 
image file: c5cp00351b-t11.tif(11)
The intensities for each mode for absorption of radiation polarized in direction i, which can be used to predict infrared spectra, are calculated by multiplying by the normal-mode eigenvector x
 
image file: c5cp00351b-t12.tif(12)

The Born charges must obey the acoustic sum rule, from translational invariance

 
image file: c5cp00351b-t13.tif(13)
For each ij, we enforce this sum rule by distributing the discrepancy equally among the atoms, and thus obtaining corrected Born charges:
 
image file: c5cp00351b-t14.tif(14)
The discrepancy arises from the same causes as the non-zero translational and rotational modes.

By mixing the response to ionic displacements and electric perturbations it is possible to calculate vibrational Raman response coefficients.60 This feature however, it is still not implemented in Octopus.

The Sternheimer equation can be used in conjunction with k·p perturbation theory61 to obtain band velocities and effective masses, as well as to apply electric fields via the quantum theory of polarization. In this case the perturbation is a displacement in the k-point. Using the effective Hamiltonian for the k-point

 
Ĥk = eik·rĤeik·r,(15)
the perturbation is represented by the operator
 
image file: c5cp00351b-t15.tif(16)
including the effect on the non-local pseudopotentials. The first-order term gives the band group velocities in a periodic system,
 
image file: c5cp00351b-t16.tif(17)

Inverse effective mass tensors can be calculated by solving the Sternheimer equation for the k·p perturbation. The equation is not solved self-consistently, since the variation of k-point is not a physical perturbation to the system; a converged k-grid should give the same density even if displaced slightly. The perturbation ∂Ĥk/∂k is purely anti-Hermitian. We use instead −iĤk/∂k to obtain a Hermitian perturbation, which allows the response to real wavefunctions to remain real. The effective mass tensors are calculated as follows:

 
image file: c5cp00351b-t17.tif(18)

The k·p wavefunctions can be used to compute the response to electric fields in periodic systems. In finite systems, a homogeneous electric field can be represented simply via the position operator r. However, this operator is not well defined in a periodic system and cannot be used. According to the quantum theory of polarization, the solution is to replace rφ with −iφ/∂k,62 and then use this as the perturbation on the right hand side in the Sternheimer equation.63 While this is typically done with a finite difference with respect to k,49,64 we use an analytic derivative from a previous k·p Sternheimer calculation. Using the results in eqn (7) gives a formula for the polarization of the crystal:

 
image file: c5cp00351b-t18.tif(19)
The polarizability is most usefully represented in a periodic system via the dielectric constant
 
image file: c5cp00351b-t19.tif(20)
where V is the volume of the unit cell. This scheme can also be extended to non-linear response.

We can compute the Born charges from the electric-field response in either finite or periodic systems (as a complementary approach to using the vibrational response):

 
image file: c5cp00351b-t20.tif(21)
This expression can be evaluated with the same approach as for the dynamical matrix elements, and is easily generalized to non-zero frequency too. We can also make the previous expression eqn (11) for Born charges from the vibrational perturbation usable in a periodic system with the replacement rφ → −iφ/∂k.

Unfortunately, the k·p perturbation is not usable to calculate the polarization,62 and a sum over strings of k-points on a finer grid is required. We have implemented the special case of a Γ-point calculation for a large super-cell, where the single-point Berry phase can be used.65 For cell sizes Li in each direction, the dipole moment is derived from the determinant of a matrix whose basis is the occupied KS orbitals:

 
image file: c5cp00351b-t21.tif(22)

4 Magnetic response and gauge invariance in real-space grids

In the presence of a magnetic field B(r,t), generated by a vector potential A(r,t), additional terms describing the coupling of the electrons to the magnetic field must be included in the Hamiltonian
 
image file: c5cp00351b-t22.tif(23)
The first part describes the orbital interaction with the field, and the second one is the Zeeman term that represents the coupling of the electronic spin with the magnetic field.

As our main interest is the evaluation of the magnetic susceptibility, in the following, we consider a perturbative uniform static magnetic field B applied to a finite system with zero total spin. In the Coulomb gauge the corresponding vector potential, A, is given as

 
image file: c5cp00351b-t23.tif(24)
In orders of B the perturbing potentials are
 
image file: c5cp00351b-t24.tif(25)
with [L with combining circumflex] the angular momentum operator, and
 
image file: c5cp00351b-t25.tif(26)

The induced magnetic moment can be expanded in terms of the external magnetic field which, to first order, reads

 
image file: c5cp00351b-t26.tif(27)
where χ is the magnetic susceptibility tensor. For finite systems the permanent magnetic moment can be calculated directly from the ground-state wave-functions as
 
image file: c5cp00351b-t27.tif(28)
For the susceptibility, we need to calculate the first-order response functions in the presence of a magnetic field. This can be done in practice by using the magnetic perturbation, eqn (25), in the Sternheimer formalism described in Section 3. If the system is time-reversal symmetric, since the perturbation is anti-symmetric under time-reversal, it does not induce a change in the density and the Sternheimer equation does not need to be solved self-consistently. From there we find
 
image file: c5cp00351b-t28.tif(29)
Before applying this formalism in a calculation, however, we must make sure that our calculation is gauge invariant.

In numerical implementations, the gauge freedom in choosing the vector potential might lead to poor convergence with the quality of the discretization, and to a dependence of the magnetic response on the origin of the simulation cell. In other words, an arbitrary translation of the molecule could introduce an nonphysical change in the calculated observables. This broken gauge-invariance is well known in molecular calculations with all-electron methods that make use of localized basis sets. In this case, the error can be traced to the finite-basis-set representation of the wave-functions.66,67 A simple measure of the error is to check for the fulfillment of the hyper-virial relation.68

 
iφj|[p with combining circumflex]|φn〉 = (εnεj)〈φj|[r with combining circumflex]|φn〉,(30)
where εn is the eigenvalue of the state φn.

When working with a real-space mesh, this problem also appears, though it is milder, because the standard operator representation in the grid is not gauge-invariant. In this case the error can be controlled by reducing the spacing of the mesh. On the other hand, real-space grids usually require the use of the pseudo-potential approximation, where the electron–ion interaction is described by a non-local potential [v with combining circumflex]nl. This, or any other non-local potential, introduces a fundamental problem when describing the interaction with magnetic fields or vector potentials in general. To preserve gauge invariance, this term must be adequately coupled to the external electromagnetic field, otherwise the results will strongly depend on the origin of the gauge. For example, an extra term has to be included in the hyper-virial expression, eqn (30), resulting in

 
iφj|[p with combining circumflex]|φn〉 = (εnεj)〈φj|[r with combining circumflex]|φn〉 + 〈φj|[[r with combining circumflex],[v with combining circumflex]nl]|φn〉.(31)
In general, the gauge-invariant non-local potential is given by
 
image file: c5cp00351b-t29.tif(32)
The integration path can be any one that connects the two points r and r′, so an infinite number of choices is possible.

In order to calculate the corrections required to the magnetic perturbation operators, we use two different integration paths that have been suggested in the literature. The first was proposed by Ismail-Beigi, Chang, and Louie (ICL)69 who give the following correction to the first-order magnetic perturbation term

 
image file: c5cp00351b-t30.tif(33)
and a similar term for the second-order perturbation. Using a different integration path, Pickard and Mauri70 proposed the GIPAW method, that has the form
 
image file: c5cp00351b-t31.tif(34)
where Rα and [v with combining circumflex]αnl are, respectively, the position and non-local potential of atom α. With the inclusion of either one of these methods, both implemented in Octopus, we recover gauge invariance in our formalism when pseudo-potentials are used. This allows us to predict the magnetic susceptibility and other properties that depend on magnetic observables, like optical activity.71

A class of systems with interesting magnetic susceptibilities are fullerenes. For example, it is known that the C60 fullerene has a very small magnetic susceptibility due to the cancellation of the paramagnetic and diamagnetic responses.72,73 Botti et al.74 used the real-space implementation of Octopus to study the magnetic response of the boron fullerenes depicted in Fig. 1. As shown in Table 1, they found that, while most clusters are diamagnetic, B80 is paramagnetic, with a strong cancellation of the paramagnetic and diamagnetic terms.


image file: c5cp00351b-f1.tif
Fig. 1 Structures of boron cages whose magnetic susceptibilities are given in Table 1.
Table 1 Calculated magnetic susceptibilities (χ in cgs ppm mol−1) per number of boron atoms for the selected boron clusters shown in Fig. 1. Results from ref. 74
Cluster [small chi, Greek, macron]
B20 −250.2
B38 −468.3
B44 −614.4
B80 219.3
B92 −831.3


5 Linear response in the electron–hole basis

An alternate approach to linear response is not to solve for the response function but rather for its poles (the excitation energies ωk) and residues (e.g. electric dipole matrix elements dk).75 The polarizability is given by
 
image file: c5cp00351b-t32.tif(35)
and the absorption cross-section is
 
image file: c5cp00351b-t33.tif(36)
where [small alpha, Greek, tilde] is the fine-structure constant. The simplest approximation to use is the random-phase approximation (RPA), in which the excitation energies are given by the differences of unoccupied and occupied KS eigenvalues, ωcv = εcεv. The corresponding dipole matrix elements are dcv = 〈φc|r|φv〉.76 (As implemented in the code, this section will refer only to the case of a system without partially occupied levels.)

The RPA is not a very satisfactory approximation, however. The full solution within TDDFT is given by a non-Hermitian matrix eigenvalue equation, with a basis consisting of both occupied–unoccupied (v → c) and unoccupied–occupied (c → v) KS transitions. The equation reads as

 
image file: c5cp00351b-u1.tif(37)
where the A matrices couple v → c transitions among themselves and c → v among themselves, while the B matrices couple the two types of transitions. They have the form76
 
φc′|〈φv′|A|φc〉|φv〉 = (εcεv)δcc′δvv′ + 〈φc′|〈φv′|[v with combining circumflex]c + [f with combining circumflex]xc|φc〉|φv〉,(38)
 
φc′|〈φv′|B|φc〉|φv〉 = 〈φc′|〈φv′|[v with combining circumflex]c + [f with combining circumflex]xc|φc〉|φv〉.(39)
where [v with combining circumflex]c is the Coulomb kernel, and [f with combining circumflex]xc is the exchange–correlation kernel. Currently, only the kernel for LDA-type functionals is supported in Octopus. The implementation for more advanced functionals is planned for future releases.

We do not solve the full equation in Octopus, but provide a hierarchy of approximations. An example calculation for the N2 molecule with each theory level is shown in Table 2. The lowest approximation we use is RPA. The next is the single-pole approximation of Petersilka et al.,77 in which only the diagonal elements of the matrix are considered. Like in the RPA case, the eigenvectors and dipole matrix elements are simply the KS transitions. The positive eigenvalues are ωcv = εcεv + Acvcv. This can be a reasonable approximation when there is little mixing between KS transitions, but generally fails when there are degenerate or nearly degenerate transitions.

Table 2 The first 6 excitation energies (in eV) for the N2 molecule with different approximations to TDDFT in the electron–hole basis: the random phase approximation (RPA), Petersilka, Tamm–Dancoff approximation (TDA), Casida and CV(2). The VWN LDA parametrization84 was used for the exchange–correlation functional, the bond length is 1.098 Å, the real-space grid was a sphere of radius 7.4 Å with spacing 0.16 Å, and 16 unoccupied states were used. The experimental data is from ref. 85
RPA Petersilka TDA Casida CV(2) Exp't
8.234 9.421 9.343 9.254 9.671 9.309
8.234 9.421 9.343 9.254 10.279 9.309
9.671 9.671 9.671 9.671 10.279 9.921
9.671 10.241 10.237 10.221 10.792 10.270
9.671 10.245 10.241 10.224 10.801 10.270
9.671 11.028 10.931 10.921 11.077 12.199


A next level of approximation is the Tamm–Dancoff approximation to TDDFT78 in which the B blocks are neglected and thus we need only consider the occupied–unoccupied transitions. The matrix equation is reduced to a Hermitian problem of half the size of the full problem:

 
Ax = ωx.(40)
Interestingly, the Tamm–Dancoff approximation is often found to give superior results to the full solution, for example for molecular potential-energy surfaces or when hybrid functionals are used, which can suffer from a “triplet instability” in which the lowest triplet state is lower in energy than the ground state.79 The dipole matrix elements are now a superposition of the KS ones:
 
image file: c5cp00351b-t34.tif(41)

When the wavefunctions are real, the full problem can be collapsed into a Hermitian one of the same size as the Tamm–Dancoff matrix, known as Casida's equation.80,81

 
image file: c5cp00351b-t35.tif(42)
The dipole matrix elements are
 
image file: c5cp00351b-t36.tif(43)

An alternate approach for finding excitation energies is to look for many-body eigenstates of the DFT Hamiltonian which are orthogonal to the ground state. In the “second-order constrained variational” or CV(2) theory,82 second-order perturbation theory from the ground-state density yields equations quite similar to the linear-response approach, despite their different origin:

 
image file: c5cp00351b-u2.tif(44)
We implement the case of real wavefunctions and eigenvectors, in which case (as for Casida's equation) a Hermitian matrix equation for only the occupied–unoccupied transitions can be written:
 
(A + B)x = ωx.(45)
The Tamm–Dancoff approximation to these equations is identical to the ordinary TDDFT Tamm–Dancoff approximation.

Note that all the levels of theory we have discussed use the same Coulomb and [f with combining circumflex]xc matrix elements, so the code can calculate the results for multiple levels of theory with a small extra effort. We can also consider alternative perturbations in this framework beyond the dipole approximation for properties such as inelastic X-ray scattering.83

For a non-spin-polarized system, the excitations separate into a singlet and a triplet subspace, which are superpositions of singlet and triplet KS transitions:

 
image file: c5cp00351b-t37.tif(46)
 
image file: c5cp00351b-t38.tif(47)
The signs are reversed from the situation for a simple pair of electrons, since we are instead dealing with an electron and a hole. There are of course two other triplet excitations (m = ±1) which are degenerate with the m = 0 one above. Rather than performing spin-polarized ground-state and linear-response calculations, we can use the symmetry between the spins in a non-spin-polarized system to derive a form of the kernel to use in obtaining singlet and triplet excitations76
 
φS|[v with combining circumflex]c + [f with combining circumflex]xc|φS〉 = 〈φ|[v with combining circumflex]c + [f with combining circumflex]↑↑xc + [f with combining circumflex]↑↓xc|φ〉 = 〈φ|[v with combining circumflex]c + 2[f with combining circumflex]xc|φ(48)
 
φT|[v with combining circumflex]c + [f with combining circumflex]xc|φT〉 = 〈φ|[f with combining circumflex]↑↑xc[f with combining circumflex]↑↓xc|φ〉.(49)
These kernels can be used in any of the levels of theory above: RPA, Petersilka, Tamm–Dancoff, Casida, and CV(2). The corresponding electric dipole matrix elements are as in the spin-polarized case for singlet excitations. For triplet excitations, they are identically zero, and only higher-order electromagnetic processes can excite them.

There are three main steps in the calculation: calculation of the matrix, diagonalization of the matrix, and calculation of the dipole matrix elements. The first step generally takes almost all the computation time, and is the most important to optimize. Within that step, the Coulomb part (since it is non-local) is much more time-consuming than the [f with combining circumflex]xc part. We calculate it by solving the Poisson equation (as for the Hartree potential) for each column of the matrix, to obtain a potential P for the density φc(r)*φv(r), and then for each row computing the matrix element as

 
φc′φv′|v|φcφv〉 = ∫drφc′(r)φv′(r)P[φcφv].(50)

Our basic parallelization strategy for computation of the matrix elements is by domains, as discussed in Section 15, but we add an additional level of parallelization here over occupied–unoccupied pairs. We distribute the columns of the matrix, and do not distribute the rows, to avoid duplication of Poisson solves. We can reduce the number of matrix elements to be computed by almost half using the Hermitian nature of the matrix, i.e. Mcv,c′v′ = Mc′v′,cv*. If there are N occupied–unoccupied pairs, there are N diagonal matrix elements, and the N(N − 1)/2 remaining off-diagonal matrix elements are distributed as evenly as possible among the columns. If N − 1 is even, there are (N − 1)/2 for each column; if N − 1 is odd, half of the columns have N/2 − 1 and half have N/2. See Fig. 2 for examples of the distribution. The columns then are assigned to the available processors in a round-robin fashion. The diagonalization step is performed by direct diagonalization with LAPACK86 in serial; since it generally accounts for only a small part of the computation time, parallelization of this step is not very important. The final step is calculation of the dipole matrix elements, which amounts to only a small part of the computation time, and uses only domain parallelization. Note that the triplet kernel lacks the Coulomb term, and so is considerably faster to compute.


image file: c5cp00351b-f2.tif
Fig. 2 Distribution of matrix elements to be calculated (black) among the columns, and those not calculated but inferred by Hermiticity of the response matrix (white). The columns are then distributed among the available MPI groups for electron–hole parallelization. The number of matrix elements to be calculated per column is equal for an odd size, and uneven for an even size.

Using the result of a calculation of excited states by one of these methods, and a previous calculation of vibrational modes with the Sternheimer equation, we can compute forces in each excited state, which can be used for excited-state structural relaxation or molecular dynamics.87 Our formulation allows us to do this without introducing any extra summations over empty states, unlike previous force implementations.88–90 The energy of a given excited state k is a sum of the ground-state energy and the excitation energy: Ek = E0 + ωk. The force is then given by the ground-state force, minus the derivative of the excitation energy:

 
image file: c5cp00351b-t39.tif(51)
Using the Hellmann–Feynman theorem we find the last term without introducing any additional sums over unoccupied states. In the particular case of the Tamm–Dancoff approximation we have
 
image file: c5cp00351b-t40.tif(52)
and
 
image file: c5cp00351b-t41.tif(53)
Analogous equations apply for the difference of eigenvalues, Petersilka, and CV(2) theory levels. (The slightly more complicated Casida case has not yet been implemented.) The Coulomb term, with no explicit dependence on the atomic positions, does not appear, leading to a significant savings in computational time compared to the calculation of the excited states.

6 Forces and geometry optimization on real-space grids

A function represented on a real-space grid is not invariant under translations as one would expect from a physical system. The potential of an atom sitting on top of a grid point might be slightly different from the potential of the same atom located between points. This implies that a rigid displacement of the system produces an artificial variation of the energy and other properties. If we plot the energy of the atom as a function of this rigid displacement, the energy shows an oscillation that gives this phenomenon the name of the “egg-box effect”.

The egg-box effect is particularly problematic for calculations where the atoms are allowed to move, for example to study the dynamics of the atoms (molecular dynamics) or to find the minimum energy configuration (geometry optimization).

In Octopus we have studied several schemes to control the egg-box effect.91 The first step is to use pseudo-potential filtering to eliminate Fourier components of the potential that cannot be represented on the grid.92

Additionally, we have found a formulation for the forces that reduces the spurious effect of the grid on the calculations. One term in the forces is the expectation value of the derivative of the ionic potential with respect to the ionic position Rα, which can be evaluated as

 
image file: c5cp00351b-t42.tif(54)
(For simplicity, we consider only local potentials here, but the results are valid for non-local potentials as well.) This term can be rewritten such that it does not include the derivative of the ionic potential vα, but the gradient of the orbitals with respect to the electronic coordinates:93
 
image file: c5cp00351b-t43.tif(55)
The first advantage of this formulation is that it is easier to implement than eqn (54), as it does not require the derivatives of the potential, which can be quite complex and difficult to code, especially when relativistic corrections are included. However, the main benefit of using eqn (55) is that it is more precise when discretized on a grid, as the orbitals are smoother than the ionic potential. We illustrate this point in Fig. 3, where the forces obtained with the two methods are compared. While taking the derivative of the atomic potential gives forces with a considerable oscillation due to the grid, using the derivative of the orbitals gives a force that is considerably smoother.


image file: c5cp00351b-f3.tif
Fig. 3 Calculation of the interatomic force for N2. Solid (red) line: force calculated from the derivative of the ionic potential with respect to the atomic position. Segmented (blue) line: force calculated from spatial derivatives of the molecular orbitals. Grid spacing of 0.43 Bohr.

This alternative formulation of the forces can be extended to obtain the second-order derivatives of the energy with respect to the atomic displacements,91 which are required to calculate vibrational properties as discussed in Section 3. In general, the perturbation operator associated with an ionic displacement can be written as

 
image file: c5cp00351b-t44.tif(56)
Using this expression, the terms of the dynamical matrix, eqn (8), are evaluated as
 
image file: c5cp00351b-t45.tif(57)
and
 
image file: c5cp00351b-t46.tif(58)

With our approach, the forces tend to converge faster with the grid spacing than the energy. This means that to perform geometry optimizations it would be ideal to have a local minimization method that only relies on the forces, without needing to evaluate the energy, as both values will not be entirely consistent. Such a method is the fast inertial relaxation engine (FIRE) algorithm, put forward by Bitzek et al.94 FIRE has shown a competitive performance compared with both the standard conjugate-gradient method, and more sophisticated variations typically used in ab initio calculations. A recent article shows also the FIRE as one of the most convenient algorithm due to its speed and precision to reach the nearest local minimum starting from a given initial configuration.95

The FIRE algorithm is based on molecular dynamics with additional velocity modifications and adaptive time steps which only requires first derivatives of the target function. In the FIRE algorithm, the system slides down the potential-energy surface, gathering “momentum” until the direction of the gradient changes, at which point it stops, resets the adaptive parameters, and resumes sliding. This gain of momentum is done through the modification of the time step Δt as adaptive parameter, and by introducing the following velocity modification

 
v(t) → V(t) = (1 − α)v(t) + α|v(t)|[F with combining circumflex](t),(59)
where v is the velocity of the atoms, α is an adaptive parameter, and [F with combining circumflex] is a unitary vector in the direction of the force F. By doing this velocity modification, the acceleration of the atoms is given by
 
image file: c5cp00351b-t47.tif(60)
where the second term is an introduced acceleration in a direction “steeper” than the usual direction of motion. Obviously, if α = 0 then V(t) = v(t), meaning the velocity modification vanishes, and the acceleration [v with combining dot above](t) = F(t)/m, as usual.

We illustrate how the algorithm works with a simple case: the geometry optimization of a methane molecule. The input geometry consists of one carbon atom at the center of a tetrahedron, and four hydrogen atoms at the vertices, where the initial C–H distance is 1.2 Å. In Fig. 4 we plot the energy difference ΔEtot with respect to the equilibrium conformation, the maximum component of the force acting on the ions Fmax, and the C–H bond length. On the first iterations, the geometry approaches the equilibrium position, but moves away on the 3rd. This means a change in the direction of the gradient, so there is no movement in the 4th iteration, the adaptive parameters are reset, and sliding resumes in the 5th iteration.


image file: c5cp00351b-f4.tif
Fig. 4 Geometry optimization of a methane molecule with FIRE. Top panel (orange squares): energy difference ΔEtot with respect to the equilibrium geometry. Middle panel (blue circles): maximum component of the force Fmax acting on the ions. Bottom panel (green diamonds): C–H bond length. Grid spacing is 0.33 Bohr.

7 Photoemission

Electron photoemission embraces all the processes where an atom, a molecule or a surface is ionized under the effect of an external electromagnetic field. In experiments, the ejected electrons are measured with detectors that are capable of characterizing their kinetic properties. Energy-resolved, P(E), and momentum-resolved, P(k), photoemission probabilities are quite interesting observables since they carry important information, for instance, on the parent ion96,97 or on the ionization process itself.98 The calculation of these quantities is a difficult task because the process requires the evaluation of the total wavefunction in an extremely large portion of space (in principle a macroscopic one) that would be impractical to represent in real space.

We have developed a scheme to calculate photoemission based on real-time TDDFT that is currently implemented in Octopus. We use a mixed real- and momentum-space approach. Each KS orbital is propagated in real space on a restricted simulation box, and then matched at the boundary with a momentum-space representation.

The matching is made with the help of a mask function M(r), like the one shown in Fig. 5, that separates each orbital into a bounded ϕAi(r) and an unbounded component ϕBi(r) as follows:

 
image file: c5cp00351b-t48.tif(61)


image file: c5cp00351b-f5.tif
Fig. 5 Scheme illustrating the mask method for the calculation of electron photoemission. A mask function (a) is used to effectively split each Kohn–Sham orbital into bounded and unbounded components localized in different spatial regions A and B according to the diagram in (b). In A the states are represented on a real-space grid while in B they are described in momentum space. A striped region indicates the volume where the two representations overlap. The propagation scheme of eqn (62) and (66) allows seamless transitions from one representations to the other and is capable to describe electrons following closed trajectories like the one in (b).

Starting from a set of orbitals localized in A at t = 0 it is possible to derive a time-propagation scheme with time step Δt by recursively applying the discrete time-evolution operator Ût) ≡ Û(t + Δt,t) and splitting the components with eqn (61). The result can be written in a closed form for ϕAi(r,t), represented in real space, and ϕBi(k,t), in momentum space, with the following structure:

ϕAi(r,t + Δt) = φAi(r,t + Δt) + φBi(r,t + Δt),
 
ϕBi(k,t + Δt) = ϑAi(k,t + Δt) + ϑBi(k,t + Δt),(62)
and the additional set of equations,
 
φAi(r,t + Δt) = t)ϕAi(r,t),(63)
 
image file: c5cp00351b-t49.tif(64)
 
image file: c5cp00351b-t50.tif(65)
 
image file: c5cp00351b-t51.tif(66)
The momentum-resolved photoelectron probability is then obtained directly from the momentum components as99
 
image file: c5cp00351b-t52.tif(67)
while the energy-resolved probability follows by direct integration, P(E) = ∫E=|k|2/2dkP(k).

In eqn (66) we introduced the Volkov propagator Ûvt) for the wavefunctions in B. It is the time-evolution operator associated with the Hamiltonian Ĥv describing free electrons in an oscillating field. Given a time dependent vector field A(t), the Hamiltonian image file: c5cp00351b-t53.tif expressed in the velocity gauge is diagonal in momentum and can be naturally applied to ϕBi(k,t).

For all systems that can be described by a Hamiltonian such that Ĥ(r,t) = Ĥv(r,t) for rB and all time t, eqn (62) and (66) are equivalent to a time propagation in the entire space AB. In particular, it exactly describes situations where the electrons follow trajectories crossing the boundary separating A and B as illustrated in Fig. 5(b).

In Octopus we discretize eqn (66) in real and momentum space and co-propagate the complete set of orbitals ϕAi(r,t) and ϕBi(k,t). The propagation has to take care of additional details since the discretization can introduce numerical instability. In fact, substituting the Fourier integrals in (66) with Fourier sums (usually evaluated with FFTs) imposes periodic boundary conditions that spuriously reintroduces charge that was supposed to disappear. This is illustrated with a one-dimensional example in Fig. 6(a) where a wavepacket launched towards the left edge of the simulation box reappears from the other edge.


image file: c5cp00351b-f6.tif
Fig. 6 Scheme illustrating different discretization strategies for eqn (66) in one dimension. In all the cases an initial wavepacket (green) is launched towards the left side of a simulation box of length L and discretized in n sampling points spaced by Δx. A and B indicate the space partitions corresponding to Fig. 5. Owing to the discretization of the Fourier integrals, periodic conditions are imposed at the boundaries and the wavepacket wraps around the edges of the simulation box (red). The time evolution is portrayed together with a momentum-space representation (yellow), with spacing Δk and maximum momentum kmax, in three situations differing in the strategy used to map real and momentum spaces: (a) fast Fourier transform (FFT), (b) FFT extended with zeros (zero padding) in a box enlarged by a factor α, and (c) zero padding with NFFT.

An alternative discretization strategy is zero padding. This is done by embedding the system into a simulation box enlarged by a factor α > 1, extending the orbitals with zeros in the outer region as shown in Fig. 6(b). In this way, the periodic boundaries are pushed away from the simulation box and the wavepackets have to travel an additional distance 2(α − 1)L before reappearing from the other side. In doing so, the computational cost is increased by adding (α − 1)n points for each orbital.

This cost can be greatly reduced using a special grid with only two additional points placed at ±αL as shown in Fig. 6(c). Since the new grid has non uniform spacing a non-equispaced FFT (NFFT) is used.100,101 With this strategy, a price is paid in momentum space where the maximum momentum kmax is reduced by a factor α compared to ordinary FFT. In Octopus we implemented all three strategies: bare FFT, zero padding with FFT and zero padding with NFFT.

All these discretization strategies are numerically stable for a propagation time approximately equivalent to the time that it takes for a wavepacket with the highest momentum considered to be reintroduced in the simulation box. For longer times we can employ a modified set of equations. It can be derived from (68) under the assumption that the electron flow is only outgoing. In this case we can drop the equation for φBi responsible for the ingoing flow and obtain the set

 
image file: c5cp00351b-t54.tif(68)
This new set of equations together with (62) lifts the periodic conditions at the boundaries and secures numerical stability for arbitrary long time propagations. A consequence of this approximation is the fact that the removal of charge is performed only in the equation for φAi by means of a multiplication by M(r). This is equivalent to the use of a mask function boundary absorber that is known to prevent reflections in an energy range that depends on M(r).102 Carefully choosing the most appropriate mask function thus becomes of key importance in order to obtain accurate results.

We conclude briefly summarizing some of the most important features and applications of our approach. The method allows us to retrieve P(k), the most resolved quantity available in experiments nowadays. In addition, it is very flexible with respect to the definition of the external field and can operate in a wide range of situations. In the strong-field regime, it can handle interesting situations, for instance, when the electrons follow trajectories extending beyond the simulation box, or when the target system is a large molecule. This constitutes a step forward compared to the standard theoretical tools employed in the field which, in the large majority of cases, invoke the single-active-electron approximation. In ref. 99 the code was successfully employed to study the photoelectron angular distributions of nitrogen dimers under a strong infrared laser field. The method can efficiently describe situations where more than one laser pulse is involved. This includes, for instance, time-resolved measurements where pump and probe setups are employed. In ref. 103 Octopus was used to monitor the time evolution of the π → π* transition in ethylene molecules with photoelectrons. The study was later extended to include the effect of moving ions at the classical level.104 Finally, we point out that our method is by no means restricted to the study of light-induced ionization but can be applied to characterize ionization induced by other processes, for example, ionization taking place after a proton collision.

8 Complex scaling and resonances

In this section we discuss the calculation of resonant electronic states by means of the complex-scaling method, as implemented in Octopus. By “resonant states,” we mean metastable electronic states of finite systems, such as atoms or molecules, with a characteristic energy and lifetime.

Mathematically, resonances can be defined as poles of the scattering matrix or cross-section at complex energies.105,106 If a pole is close to the real energy axis, it will produce a large, narrow peak in the cross-section of scattered continuum states. One way resonances can arise is from application of an electric field strong enough to ionize the system through tunnelling. Resonant states may temporarily capture incoming electrons or electrons excited from bound states, making them important intermediate states in many processes.

The defining characteristic of a resonant state, often called a Siegert state,105 is that it has an outgoing component but not an incoming one. They can be determined by solving the time-independent Schrödinger equation with the boundary condition that the wavefunction must asymptotically have the form

 
image file: c5cp00351b-t55.tif(69)
where the momentum k is complex and has a negative imaginary part. This causes the state to diverge exponentially in space as r → ∞. The state can further be ascribed a complex energy, likewise with a negative imaginary part, causing it to decay over time at every point in space uniformly.

Resonant states are not eigenstates of any Hermitian operator and in particular do not reside within the Hilbert space. This precludes their direct calculation with the standard computational methods from DFT. However, it turns out that a suitably chosen analytic continuation of a Siegert state is localized, and this form can be used to derive information from the state. This is the idea behind the complex-scaling method107,108 where states and operators are represented by means of the transformation

 
[R with combining circumflex]θψ(r) = ei/2ψ(reiθ),(70)
where N is the number of spatial dimensions to which the scaling operation is applied, and θ is a fixed scaling angle which determines the path in the complex plane along which the analytic continuation is taken. The transformation maps the Hamiltonian to a non-Hermitian operator Ĥθ = [R with combining circumflex]θĤ[R with combining circumflex]θ.

The Siegert states ψ(r) of the original Hamiltonian are square-integrable eigenstates ψθ(r) of Ĥθ, and their eigenvalues ε0/2 define the energy ε0 and width Γ of the resonance.109–111

A typical example of a spectrum of the transformed Hamiltonian Ĥθ is shown in Fig. 7, and the corresponding potential and lowest bound and resonant states in Fig. 8. The bound-state energies are unchanged while the continuum rotates by −2θ around the origin. Finally, resonances appear as isolated eigenvalues in the fourth quadrant once θ is sufficiently large to “uncover” them from the continuum. Importantly, matrix elements (and in particular energies) of states are independent of θ as long as the states are localized and well represented numerically—this ensures that all physical bound-state characteristics of the untransformed Hamiltonian are retained.


image file: c5cp00351b-f7.tif
Fig. 7 Spectrum of one-dimensional complex-scaled single-particle Hamiltonian with potential v(x) = 3(x2 − 2)ex2/4 and θ = 0.5. The lowest-energy resonance, here located close to the origin, does not lie exactly on the real axis but has an imaginary part of about −10−5.

image file: c5cp00351b-f8.tif
Fig. 8 Potential (blue) and the real (solid) and imaginary (dotted) parts of the two bound (green) and three lowest resonant (red) wavefunctions. For improved visualization, the wavefunctions are vertically displaced by the real parts of their energies.

Our implementation supports calculations with complex scaling for independent particles or in combination with DFT and selected xc functionals.112 The energy functional in KS-DFT consists of several terms that are all expressible as integrals of the density or the wavefunctions with the kinetic operator and various potentials. The functional is complex-scaled as per the prescribed method by rotating the real-space integration contour of every term by θ in the complex plane. The DFT energy functional becomes

 
image file: c5cp00351b-t56.tif(71)
with the now-complex electron density
 
image file: c5cp00351b-t57.tif(72)
with occupation numbers fn, and complex-scaled KS states φθn(r). Note that no complex conjugation is performed on the left component in matrix elements such as the density or kinetic energy. In order to define the complex-scaled xc potential, it is necessary to perform an analytic continuation procedure.112

In standard DFT, the KS equations are obtained by taking the functional derivative of the energy functional with respect to the density. Solving the equations corresponds to searching for a stationary point, with the idea that this minimizes the energy. In our case, since the energy functional is complex-valued,113 we cannot minimize the energy functional, but we can still search for stationary points to find the resonances.114,115 The complex-scaled version of the KS equations thereby becomes similar to the usual ones:

 
image file: c5cp00351b-t58.tif(73)
The effective potential vθ(r) is the functional derivative of the energy functional with respect to the density nθ(r), and, therefore, consists of the terms
 
image file: c5cp00351b-t59.tif(74)
where vext(reiθ) may represent atomic potentials as analytically continued pseudopotentials, and where the Hartree potential
 
image file: c5cp00351b-t60.tif(75)
is determined by solving the Poisson equation defined by the complex density. Together with the xc potential,
 
image file: c5cp00351b-t61.tif(76)
this defines a self-consistency cycle very similar to ordinary KS DFT, although more care must be taken to occupy the correct states, as they are no longer simply ordered by energy.

Fig. 9 shows calculated ionization rates for the He 1s state in a uniform Stark-type electric field as a function of field strength. In the limit of weak electric fields, the simple approximation by Ammosov, Delone and Krainov (ADK),116 which depends only on the ionization potential, approaches the accurate reference calculation by Scrinzi and co-workers.117 This demonstrates that the ionization rate is determined largely by the ionization potential for weak fields. As the local density approximation is known to produce inaccurate ionization potentials due to its wrong asymptotic form at large distances, it necessarily yields inaccurate rates at low fields. Meanwhile exact exchange, which is known to produce accurate ionization energies, predicts ionization rates much closer to the reference calculation. The key property of the xc functional that allows accurate determination of decay rates from complex-scaled DFT therefore appears to be that it must yield accurate ionization potentials, which is linked to its ability to reproduce the correct asymptotic form of the potential at large distances from the system.118


image file: c5cp00351b-f9.tif
Fig. 9 Ionization rates of the He atom in strong electric fields using the local density approximation (LDA) and exact exchange (EXX), compared to an accurate numerical ref. 117 as well as the analytic ADK approximation.116 Results from ref. 112.

9 Quantum optimal control

In recent years, we have added to Octopus some of the key advancements of quantum optimal-control theory (QOCT).119,120 In this section, we will briefly summarize what this theory is about, overview the current status of its implementation, and describe some of the results that have been obtained with it until now.

Quantum control can be loosely defined as the manipulation of physical processes at the quantum level. We are concerned here with the theoretical branch of this discipline, whose most general formulation is precisely QOCT. This is, in fact, a particular case of the general mathematical field of “optimal control”, which studies the optimization of dynamical processes in general. The first applications of optimal control in the quantum realm appeared in the 80s,121–123 and the field has rapidly evolved since then. Broadly speaking, QOCT attempts to answer the following question: given a quantum process governed by a Hamiltonian that depends on a set of parameters, what are the values of those parameters that maximize a given observable that depends on the behavior of the system? In mathematical terms: let a set of parameters u1,…,uMu determine the Hamiltonian of a system Ĥ[u,t], so that the evolution of the system also depends on the value taken by those parameters:

 
image file: c5cp00351b-t62.tif(77)
 
|ψ(0)〉 = |ψ0〉,(78)
i.e. the solution of the Schrödinger equation determines a map uψ[u]. Suppose we wish to optimize a functional of the system F = F[ψ]. QOCT is about finding the extrema of G(u) = F[ψ[u]]. Beyond this search, QOCT also studies topics such as the robustness of the optimal solutions for those parameters, the number of solutions, or the construction of suitable algorithms to compute them.

Perhaps the most relevant result of QOCT is the equation for the gradient of G, which allows use of the various maximization algorithms available. For the simple formulation given above, this gradient is given by

 
image file: c5cp00351b-t63.tif(79)
where χ is the costate, an auxiliary wave function that is defined through the following equation of motion:
 
image file: c5cp00351b-t64.tif(80)
 
image file: c5cp00351b-t65.tif(81)
This equation assumes, in order to keep this description short, that the target functional F depends on the state of the system only at the final time of the propagation T, i.e. it is a functional of ψ(T). Note the presence of a boundary value equation at the final time of the propagation, as opposed to the equation of motion for the “real” system ψ, which naturally depends on an initial value condition at time zero. With these simple equations, we may already summarize what is needed from an implementation point of view in order to perform basic QOCT calculations:

The first step is the selection of the parameters u, that constitute the search space. Frequently, these parameters are simply the values that the control function (typically, the electric-field amplitude) takes at the time intervals that are used to discretize the propagation interval, i.e. it is a “real-time parametrization”. However, more sophisticated parametrizations allow fine-tuning of the search space, introducing constraints and penalties into the formulation.

Then, one must choose an algorithm for maximizing multi-dimensional functions such as G. One possibility is the family of gradient-less algorithms, which only require a procedure to compute the value of the function, and do not need the gradient. In this case, the previous equations are obviously not needed. One only has to propagate the system forwards in time, which is what Octopus can do best. The value of the function G can then be computed from the evolution of ψ obtained with this propagation, and fed into the optimization procedure. A few gradient-less algorithms are implemented in Octopus.

The most efficient optimizations can be obtained if information about the gradient is employed. In that case, we can use standard schemes, such as the family of conjugate-gradient algorithms, or the Broyden–Fletcher–Goldfarb–Shanno (BFGS) quasi-Newton scheme – we use the implementation of these algorithms included in the GSL mathematical library.124 Some ad hoc algorithms, developed explicitly for QOCT, exist. These may in some circumstances be faster than the general purpose ones. Some of those are implemented in Octopus as well.125–127

In order to compute the gradient, one must implement a backwards-propagation scheme for the costate, which does not differ from the ones used for the normal forwards propagation.128 Note, however, that in some cases the backwards propagation does not have the exact same simple linear form than the forwards propagation, and may include inhomogeneous or non-linear terms. The final step is the computation of the gradient from the integral given in eqn (79).

The formulation of QOCT we have just sketched out is quite generic; in our case the quantum systems are those that can be modeled with Octopus (periodic systems are not supported at the moment), and the handle that is used to control the system is a time-dependent electric field, such as the ones that can be used to model a laser pulse. The set of parameters {u}i define the shape of this electric field; for example, they can be the Fourier coefficients of the field amplitude.

The usual formulation of QOCT assumes the linearity of quantum mechanics. However, the time-dependent KS equations are not linear, making both the theory and the numerics more complicated. We have extended the basic theory previously described to handle the TDDFT equations, and implemented the resulting equations in Octopus.129

We conclude this section by briefly describing some of the applications of the QOCT machinery included in Octopus, which can give an idea of the range of possibilities that can be attempted. The study presented in ref. 130 demonstrates the control of single-electron states in a two-dimensional semiconductor quantum-ring model. The states whose transitions are manipulated are the current-carrying states, which can be populated or de-populated with the help of circularly polarized light.

Ref. 131 studies double quantum dots, and shows how the electron state of these systems can be manipulated with the help of electric fields tailored by QOCT.

Another interesting application is how to tailor the shape of femtosecond laser pulses in order to obtain maximal ionization of atoms and molecules.132 The system chosen to demonstrate this possibility is the H2+ molecule, irradiated with short (≈5 fs) high-intensity laser pulses.

The feasibility of using the electronic current to define the target functional of the QOCT formalism is considered in ref. 133.

Finally, a series of works has studied the use of optimal control for photo-chemical control: the tailoring of laser pulses to create or break selected bonds in molecules. The underlying physical model should be based on TDDFT, and on a mixed quantum/classical scheme (within Octopus, Ehrenfest molecular dynamics). Some first attempts in this area were reported in ref. 134 and 135. However, these works did not consider a fully consistent optimal control theory encompassing TDDFT and Ehrenfest dynamics. This theory has been recently presented,136 and the first computations demonstrating its feasibility will be reported soon.

10 Plasmonics

The scope of real-space real-time approaches is not confined to the atomistic description of matter. For instance, finite-difference time-domain137 (FDTD) is a standard numerical tool of computational electromagnetism, while lattice Boltzmann methods138 (LBM) are widely used in computational fluid dynamics. Indeed, real-space real-time approaches can be used to model physical processes on rather different space and time scales. This observation also bears an important suggestion: numerical methods based on real-space grids can be used to bridge between these different space and time scales.

Numerical nanoplasmonics is a paradigmatic case for multiscale electronic-structure calculations. A nanoplasmonic system – e.g., made up of metal nanoparticles (MNPs) – can be a few tens of nanometers across, while the region of strong field enhancement – e.g., in the gap between two MNPs – can be less than 1 nm across.139 The field enhancement, h(r), is essentially a classical observable, defined as

 
image file: c5cp00351b-t66.tif(82)
where Etot is the total electric field, Eext is the external (or driving) electric field, and 〈⋯〉 indicates a time average. Large field enhancements are the key to single molecule surface-enhanced Raman spectroscopy (SERS) and values as large as h > 100 (the intensity of the SERS signal scales as h4) are predicted by classical electromagnetic calculations.140

In classical calculations, the electronic response is modeled by the macroscopic permittivity of the material. The classical Drude model gives the following simple and robust approximation of the metal (complex) permittivity:

 
image file: c5cp00351b-t67.tif(83)
For gold, typical values of the high-frequency permittivity ε, the plasma frequency ωp, and the relaxation rate γ, are: ε = 9.5, ℏω = 8.95 eV and ℏγ = 69.1 meV.141 A non-local correction to the Drude model can also be included by considering the plasmon dispersion.142,143 The metal (complex) permittivity then reads
 
image file: c5cp00351b-t68.tif(84)
The parameter β can be fitted to model the experimental data, although the value image file: c5cp00351b-t69.tif, where vF is the Fermi velocity, is suggested by the Thomas–Fermi approximation.144

Regardless of the level of sophistication of the permittivity model, all classical calculations assume that electrons are strictly confined inside the metal surfaces. This is a safe approximation for microscopic plasmonic structures. However, at the nanoscale the electronic delocalization (or spillout) outside the metal surfaces becomes comparable to the smallest features of the plasmonic nanostructure, e.g., to the gap between two MNPs. In this scale, the very definition of a macroscopic permittivity is inappropriate and the electronic response must be obtained directly from the quantum dynamics of the electrons.

TDDFT is currently the method of choice to model the plasmonic response of MNPs,145–151via the simplified jellium model, in which the nuclei and core electrons are described as a uniform positive charge density, and only the valence electrons are described explicitly. Early calculations – especially nanospheres146,152 – have suggested the existence of new charge-transfer plasmonic modes, which have been also demonstrated by pioneering experiments.139 In the future, as the field of quantum plasmonics153i.e., the investigation and control of the quantum properties of plasmons – will further develop, the demand for accurate, yet scalable, numerical simulations to complement the experimental findings is expected to grow. This demand represents both a challenge and an opportunity for computational physics.

Scaling up the TDDFT@jellium method to model larger and more complex plasmonic nanostructures is a challenge which can be addressed by high-performance real-space real-time codes, like Octopus. The code has been initially applied to investigate the plasmonic response of single gold nanospheres (Wigner–Seitz radius, rs = 3.0 bohr).147 A clear plasmonic resonance appears in the absorption cross section – computed by real-time propagation – for spheres containing a large enough number of electrons (Ne > 100). A new plasmonic mode, deemed the “quantum core plasmon”, has been also suggested from the analysis of the absorption cross-section. This new mode has been further characterized by probing the sphere at its resonance frequency. Within a real-time propagation scheme, this is simply done by including an external electric field, the “laser pulse”, oscillating at a given frequency.

As versatility is a major strength of real-space real-time approaches, other jellium geometries can be easily modeled by Octopus, including periodic structures. For instance, a pair of interacting sodium nanowires (with periodicity along their longitudinal direction) has been investigated to assess the accuracy of classical methods based on the model permittivity in eqn (83) and (84). Compared to pairs of nanospheres, nanowires display a stronger inductive interaction due to their extended geometry.148,149 This is manifest in the absorption cross-section which already shows a large split of the plasmonic peak for a small gap between the wires (see Fig. 10(a)). Due to the electronic spillout and the symmetry of the system, it also turns out that the largest field enhancement is reached at the center of the gap, not on the opposing surfaces of the nanowires as predicted by the classical methods (see Fig. 10(b)). The maximum field enhancement estimated by the TDDFT@jellium method is also smaller than the classical estimates. Once again, the quantum delocalization ignored by the classical methods plays a crucial role in “smearing” the singularities of the induced field, effectively curbing the local field enhancement.


image file: c5cp00351b-f10.tif
Fig. 10 Panel (a): absorption cross section of a pair of sodium nanowires. The driving electric field is polarized as shown in the inset. Curves are for different values of gap, d, between the nanowires, from top to bottom: d = 5, 2, 1, 0.5, 0.2, 0.1, 0 nm. Panel (b): field enhancement, h, for the case d = 0.5 nm. The black lines indicate the nanowire surfaces. (Adapted from ref. 148).

Simple jellium geometries have been implemented in Octopus and they can be used as effective “superatomic pseudopotentials”. The similarity between the jellium potential and atomic pseudopotentials can be further exploited to develop an external “jellium pseudopotential” generator to be used with Octopus. In this way, a larger selection of jellium geometries will be made available along with refined, yet scalable, jellium approaches to include d electron screening in noble metals.154 Efforts in this direction are being currently made.

Finally, a word of caution about the domain of applicability of the TDDFT@jellium method is in order. The non-uniformity of the atomic lattice is expected to affect the absorption cross-section of small MNPs. A careful assessment of the lattice contributions – including the lattice symmetry – on the main plasmon modes of a pair of nanosphere is available.151 This last investigation further demonstrates the possibility to bridge between atomistic and coarse-grained electronic calculations by means of a real-space real-time approach.

11 Development of exchange and correlation functionals

The central quantity of the KS scheme of DFT is the xc energy Exc[n], which describes all non-trivial many-body effects. Clearly, the exact form of this quantity is unknown and it must be approximated in any practical application of DFT. We emphasize that the accuracy of any DFT calculation depends solely on the form of this quantity, as this is the only real approximation in DFT (neglecting numerical approximations that are normally controllable).

During the past 50 years, hundreds of different forms have appeared.155 They are usually arranged in families, which have names such as generalized-gradient approximations (GGAs), meta-GGAs, hybrid functionals, etc. In 2001, John Perdew came up with a beautiful idea on how to illustrate these families and their relationship.156 He ordered the families as rungs in a ladder that leads to the heaven of “chemical accuracy”, which he christened the “Jacob's ladder” of density-functional approximations for the xc energy. Every rung adds a dependency on another quantity, thereby increasing the precision of the functional but also increasing the numerical complexity and the computational cost.

The first three rungs of this ladder are: (i) the local-density approximation (LDA), where the functional has a local dependence on the density only; (ii) the generalized-gradient approximation (GGA), which includes also a local dependence on the gradient of the density; and (iii) the meta-GGA, which adds a local dependence on the Laplacian of the density and on the kinetic-energy density. In the fourth rung we have functionals that depend on the occupied KS orbitals, such as exact exchange or hybrid functionals. Finally, the fifth rung adds a dependence on the virtual KS orbitals.

Support for the first three rungs and for the local part of the hybrid functionals in Octopus is provided through the Libxc library.157 Libxc started as a spin-off project during the initial development of Octopus. At that point, it became clear that the task of evaluating the xc functional was completely independent of the main structure of the code, and could therefore be transformed into a stand-alone library. Over the years, Libxc became more and more independent of Octopus, and is now used in a variety of DFT codes. There are currently more than 150 xc functionals implemented in Libxc that are available in Octopus, a number that has been increasing steadily over the years. All of the standard functionals are included and many of the less common ones. There is also support for LDAs and GGAs of systems of reduced dimensionality (1D and 2D), which allow for direct comparisons with the direct solution of the many-body Schrödinger equation for model systems described in Section 13.

Octopus also includes support for other functionals of the fourth rung, such as exact exchange or the self-interaction correction of Perdew and Zunger,158 through the solution of the optimized effective potential equation. This can be done exactly,159 or within the Slater160 or Krieger-Li-Iafrate approximations.161

Besides the functionals that are supported by Octopus, the code has served as a platform for the testing and development of new functionals. For example, the method described in Section 13 can be used in a straightforward way to obtain reference data against which to benchmark the performance of a given xc functional, for example a one-dimensional LDA.162 In that case, both calculations, exact and approximate, make use of the same real-space grid approach, which makes the comparison of the results obtained with both straightforward. Despite the obvious advantage of using exact solutions of the many-body problem as reference data, this is often not possible and one usually needs to resort to the more commonly used experimental or highly-accurate quantum-chemistry data. In this case, the flexibility of the real-space method, allowing for the calculation of many different properties of a wide variety of systems, is again an advantage. Octopus has therefore been used to benchmark the performance of xc functionals whose potential has a correct asymptotic behavior163 when calculating ionization potentials and static polarizabilities of atoms, molecules, and hydrogen chains.

In this vein, Andrade and Aspuru-Guzik164 proposed a method to obtain an asymptotically correct xc potential starting from any approximation. Their method is based on considering the xc potential as an electrostatic potential generated by a fictitious xc charge. In terms of this charge, the asymptotic condition is given as a simple formula that is local in real space and can be enforced by a simple procedure. The method, implemented in Octopus, was used to perform test calculations in molecules. Additionally, with this correction procedure it is possible to find accurate predictions for the derivative discontinuity and, hence, predict the fundamental gap.165

12 Real-space reduced density-matrix functional theory

An alternative approach to DFT that can model electrons using a single-particle framework is reduced density matrix functional theory (RDMFT).166 Here, we present the current results of an ongoing effort to develop a real-space version of RDMFT and to implement it in the Octopus code.

Within RDMFT, the total energy of a system is given as a functional of the one-body reduced density-matrix (1-RDM)

 
γ(r,r′) = N∫⋯∫dr2…drNΨ*(r′,r2rN)Ψ(r,r2rN)(85)
which can be written in its spectral representation as
 
image file: c5cp00351b-t70.tif(86)
where the natural orbitals ϕi(r) and their occupation numbers ni are the eigenfunctions and eigenvalues of the 1-RDM, respectively.

In RDMFT the total energy is given by

 
image file: c5cp00351b-t71.tif(87)
The third term is the Hartree energy, EH, and the fourth the xc energy, Exc. As in DFT, the exact functional of RDMFT is unknown. However, the part that needs to be approximated, Exc[γ], comes, contrary to DFT, only from the electron–electron interaction, as the interacting kinetic energy can be explicitly expressed in terms of γ. Different approximate functionals are employed and minimized with respect to the 1-RDM in order to find the ground state energy.167–169 A common approximation for Exc is the Müller functional,170 which has the form
 
image file: c5cp00351b-t72.tif(88)
and is the only Exc implemented in Octopus for the moment.

For closed-shell systems, the necessary and sufficient conditions for the 1-RDM to be N-representable,171i.e. to correspond to a N-electron wavefunction, is that 0 ≤ ni ≤ 2 and

 
image file: c5cp00351b-t73.tif(89)
Minimization of the energy functional of eqn (87) is performed under the N-representability constraints and the orthonormality requirements of the natural orbitals,
 
ϕi|ϕj〉 = δij.(90)
The bounds on the occupation numbers are automatically satisfied by setting ni = 2sin2(2πϑi) and varying ϑi without constraints. The conditions (89) and (90) are taken into account via Lagrange multipliers μ and λij, respectively. Then, one can define the following functional
 
image file: c5cp00351b-t74.tif(91)
which has to be stationary with respect to variations in {ϑi}, {ϕi(r)} and {ϕi*(r)}. In any practical calculation the infinite sums have to be truncated including only a finite number of occupation numbers and natural orbitals. However, since the occupation numbers nj decay very quickly for j > N, this is not problematic.

The variation of Ω is done in two steps: for a fixed set of orbitals, the energy functional is minimized with respect to occupation numbers and, accordingly, for a fixed set of occupations the energy functional is minimized with respect to variations of the orbitals until overall convergence is achieved. As a starting point we use results from a Hartree–Fock calculation and first optimize the occupation numbers. Since the correct μ is not known, it is determined via bisection: for every μ the objective functional is minimized with respect to ϑi until the condition (89) is satisfied.

Due to the dependence on the occupation numbers, the natural-orbital minimization does not lead to an eigenvalue equation like in DFT or Hartree–Fock. The implementation of the natural orbital minimization follows the method by Piris and Ugalde.172 Varying Ω with respect to the orbitals for fixed occupation numbers one obtains

 
image file: c5cp00351b-t75.tif(92)
At the extremum, the matrix of the Lagrange multipliers must be Hermitian, i.e.
 
λjiλij* = 0.(93)
Then one can define the off-diagonal elements of a Hermitian matrix F as:
 
Fji = θ(ij)(λjiλij*) + θ(ji)(λij* − λji),(94)
where θ is the unit-step Heaviside function. We initialize the whole matrix as Fji = (λji + λij*)/2. In every iteration we diagonalize F, keeping the diagonal elements for the next iteration, while changing the off-diagonal ones to (94). At the solution all off-diagonal elements of this matrix vanish, hence, the matrices F and γ can be brought simultaneously to a diagonal form. Thus, the {ϕi} which are the solutions of eqn (93) can be found by diagonalization of F in an iterative manner.172 The criterion to exit the natural-orbital optimization is that the difference in the total energies calculated in two successive F diagonalizations is smaller than a threshold. Overall convergence is achieved when the difference in the total energies in two successive occupation-number optimizations and the non-diagonal matrix elements of F are close to zero.

As mentioned above, one needs an initial guess for the natural orbitals both for the first step of occupation-number optimization but also for the optimization of the natural orbitals. A rather obvious choice would be the occupied and a few unoccupied orbitals resulting from a DFT or HF calculation. Unfortunately, there are unbound states among the HF/DFT unoccupied states which are a bad starting point for the weakly occupied natural orbitals. When calculated in a finite grid these orbitals are essentially the eigenstates of a particle in a box. Using the exact-exchange approximation (EXX) in an optimized-effective-potential framework results in a larger number of bound states than HF or the local density approximation (LDA) due to the EXX functional being self-interaction-free for both occupied and unoccupied orbitals. Using HF or LDA orbitals to start a RDMFT calculation, the natural orbitals do not converge to any reasonable shape, but even when starting from EXX one needs to further localize the unoccupied states. Thus, we have found that in order to improve the starting point for our calculation we can multiply each unoccupied orbital by a set of Gaussian functions centered at the positions of the atoms. As the unbound states are initially more delocalized than the bound ones, we choose a larger exponent for them.

In Fig. 11 we show the dissociation curve of H2 obtained with RDMFT in Octopus and compare it with results obtained by the Gaussian-basis-set RDMFT code HIPPO.173 For the Octopus calculation, we kept 13 natural orbitals with the smallest occupation number being of the order of 10−5 after the RDMFT calculation had converged. The HIPPO calculation was performed using 30 natural orbitals. The RDMFT curve obtained with Octopus looks similar to the one from HIPPO and other Gaussian implementations of RDMFT,167 keeping the nice feature of not diverging strongly in the dissociation limit. However, for internuclear distances R bigger than 1 a.u., the real-space energy lies above the HIPPO one. We believe that the remaining difference can be removed by further improving the initial guess for the orbitals that we use in Octopus, because a trial calculation using HF orbitals from a Gaussian implementation showed a curve almost identical to the one from the HIPPO code (not shown in the figure). In the future, we plan to include support for open-shell systems and additional xc functionals.


image file: c5cp00351b-f11.tif
Fig. 11 Dissociation curve of the hydrogen molecule. Restricted Hartree–Fock (black dotted and red dash-dotted lines) does not dissociate into two neutral atoms while the closed-shell RDMFT gives almost the correct energy of −1 Ha at the dissociation limit in a Gaussian implementation. For the grid implementation in Octopus, a deviation from the constant energy at large R remains.

13 Exact solution of the many-body Schrödinger equation for few electrons

In one-dimensional systems, the fully interacting Hamiltonian for N electrons has the form
 
image file: c5cp00351b-t76.tif(95)
where the interaction potential vint(xj,xk) is usually Coulombic, though the following discussion also applies for other types of interaction, including more than two-body ones. In 1D one often uses the soft Coulomb interaction image file: c5cp00351b-t77.tif, where a softening parameter (usually set to one) is introduced in order to avoid the divergence at xj = xk, which is non-integrable in 1D.

Mathematically, the Hamiltonian (eqn (95)) is equivalent to that of a single (and hence truly independent) electron in N dimensions, with the external potential

 
image file: c5cp00351b-t78.tif(96)
For small N it is numerically feasible to solve the N-dimensional Schrödinger equation
 
ĤΨj(x1xN) = EjΨj(x1xN)(97)
which provides a spatial wave function for a single particle in N dimensions. This equivalence is not restricted to one-dimensional problems. One can generally map a problem of N electrons in d dimensions onto the problem of a single particle in Nd dimensions, or indeed a problem with multiple types of particles (e.g. electrons and protons) in d dimensions, in the same way.

What we exploit in Octopus is the basic machinery for solving the Schrödinger equation in an arbitrary dimension, the spatial/grid bookkeeping, the ability to represent an arbitrary external potential, and the intrinsic parallelization. In order to keep our notation relatively simple, we will continue to discuss the case of an originally one-dimensional problem with N electrons. Grid-based solutions of the full Schrödinger equation are not new, and have been performed for many problems with either few electrons (in particular H2, D2 and H2+)174,175 or model interactions,176 including time-dependent cases.177

The time-dependent propagation of the Schrödinger equation can be carried out in the same spirit, since the Hamiltonian is given explicitly and each “single-particle orbital” represents a full state of the system. A laser or electric-field perturbation can also be applied, depending on the charge of each particle (given in the input), and taking care to apply the same effective field to each particle along the polarization direction of the field (in 1D, the diagonal of the hyper-cube).

Solving eqn (97) leaves the problem of constructing a wave function which satisfies the anti-symmetry properties of N electrons in one dimension. For fermions one needs to ensure that those spatial wave functions Ψj which are not the spatial part of a properly anti-symmetric wave function are removed as allowed solutions for the N-electron problem. A graphical representation of which wave functions are allowed is given by the Young diagrams (or tableaux) for permutation symmetries, where each electron is assigned a box, and the boxes are then stacked in columns and rows (for details see, for example, ref. 178). Each box is labeled with a number from 1 to N such that the numbers increase from top to bottom and left to right.

All possible decorated Young diagrams for three and four electrons are shown in Fig. 12. Since there are two different spin states for electrons, our Young diagrams for the allowed spatial wave functions contain at most two columns. The diagram (d) is not allowed for the wave function of three particles with spin 1/2, and diagrams (k) to (n) are not allowed for four particles. To connect a given wave function Ψj with a diagram one has to symmetrize the wave function according to the diagram. For example, for diagram (b) one would perform the following operations on a function Ψ(x1,x2,x3)

 
[Ψ(x1,x2,x3) + Ψ(x2,x1,x3)] − [Ψ(x3,x2,x1) + Ψ(x3,x1,x2)].(98)
Hence, one symmetrizes with respect to an interchange of the first two variables, because they appear in the same row of the Young diagram, and anti-symmetrizes with respect to the first and third variable, as they appear on the same column. We note that we are referring to the position of the variable in the list, not the index, and that symmetrization always comes before anti-symmetrization. At the end of these operations one calculates the norm of the resulting wave function. If it passes a certain threshold, by default set to 10−5, one keeps the obtained function as a proper fermionic spatial part. If the norm is below the threshold, one continues with the next allowed diagram until either a norm larger than the threshold is found or all diagrams are used up. If a solution Ψj does not yield a norm above the threshold for any diagram it is removed since it corresponds to a wave function with only bosonic or other non-fermionic character. Generally, as the number of forbidden diagrams increases with N, the number of wave functions that need to be removed also increases quickly with N, in particular in the lowest part of the spectrum. The case of two electrons is specific, as all solutions of eqn (97) correspond to allowed fermionic wave functions: the symmetric ones to the singlet states and the anti-symmetric ones to the triplet states.


image file: c5cp00351b-f12.tif
Fig. 12 Young diagrams for three [(a)–(d)] and four [(e)–(n)] electrons. For three electrons, only diagrams (a)–(c) are allowed for spin-1/2 particles, while only diagrams (e)–(j) are allowed for four electrons.

For example, for a one-dimensional Li atom with an external potential

 
image file: c5cp00351b-t79.tif(99)
and the soft Coulomb interaction, we obtain the states and energy eigenvalues given in Table 3.

Table 3 Eigenstates for a one-dimensional lithium atom. The first and the fourth eigenstates show norms that are smaller than 10−13 and 10−11, respectively, for all diagrams. Hence, these states are bosonic and removed from any further calculations. The second and third states are energetically degenerate and correspond to diagrams (b) and (c) in Fig. 12. The same is true for the fifth and sixth states
State Energy Young diagram Norm
1 −4.721 Bosonic <10−13
2 −4.211 (b) 0.2
3 −4.211 (c) 0.6
4 −4.086 Bosonic <10−11
5 −4.052 (b) 0.4
6 −4.052 (c) 0.7


If certain state energies are degenerate, the Young diagram “projection” contains an additional loop, ensuring that the same diagram is not used to symmetrize successive states: this would yield the same spatial part for each wave function in the degenerate sub-space. A given diagram is only used once in the sub-space, on the first state whose projection has significant weight.

The implementation also allows for the treatment of bosons, in which case the total wave function has to be symmetric under exchange of two particles. Here one will use a spin part symmetrized with the same Young diagram (instead of the mirror one for fermions), such that the total wave function becomes symmetric.

In order for the (anti-)symmetrization to work properly one needs to declare each particle in the calculation to be a fermion, a boson, or an anyon. In the latter case, the corresponding spatial variables are not considered at all in the (anti-)symmetrization procedure. One can also have more than one type of fermion or boson, in which case the symmetric requirements are only enforced for particles belonging to the same type.

There are also numerical constraints on the wave-functions: space must be represented in a homogeneous hyper-cube, eventually allowing for different particle masses by modifying the kinetic-energy operator for the corresponding directions. All of the grid-partitioning algorithms intrinsic to octopus carry over to arbitrary dimensions, which allows for immediate parallelization of the calculations of the ground and excited states. The code can run with an arbitrary number of dimensions, however, the complexity and memory size grow exponentially with the number of particles simulated, as expected. Production runs have been executed up to 6 or 7 dimensions.

Most of the additional treatment for many-body quantities is actually post-processing of the wave-functions. For each state, the determination of the fermionic or bosonic nature by Young-tableau symmetrization is followed by the calculation and output of the density for each given particle type, if several are present. Other properties of the many-body wave-function can also be calculated. For example, Octopus can also output the one-body density matrix, provided in terms of its occupation numbers and natural orbitals.

This type of studies, even when they are limited to model systems of a few electrons, allows us to produce results that can be compared to lower levels of theory like approximate DFT or RDMFT, and to develop better approximations for the exchange and correlation term. Exact results obtained from such calculations have been used to assess the quality of a 1D LDA functional162 and adiabatic 1D LDA and exact exchange in a TDDFT calculation calculation of photoemission spectra.162,179

14 Compressed sensing and atomistic simulations

In order to obtain frequency-resolved quantities from real-time methods like molecular dynamics or electron dynamics, it is necessary to perform a spectral representation of the time-resolved signal. This is a standard operation that is usually performed using a discrete Fourier transform. Since the resolution of the spectrum is given by the length of the time signal, it is interesting to look for more methods that can provide us a spectrum of similar quality with shorter time series, as this is directly reflected in shorter computation times. Several such methods exist, but a particular one that has been explored in Octopus, due to its general applicability and efficiency, is compressed sensing.

Compressed sensing180 is a general theory aimed at optimizing the amount of sampling required to reconstruct a signal. It is based on the idea of sparsity, a measure of how many zero coefficients a signal has when represented in a certain basis. Compressed sensing has been applied to many problems in experimental sciences181–183 and technology184,185 in order to perform more accurate measurements. Its ideas, however, can also be applied to computational work.

In order to calculate a spectrum in compressed sensing, we need to solve the so-called basis-pursuit optimization problem

 
image file: c5cp00351b-t80.tif(100)
where image file: c5cp00351b-t81.tif is the standard 1-norm, τ is the discretized time series, σ is the frequency-resolved function (the spectrum that we want to calculate) and F is the Fourier-transform matrix.

Since τ is a short signal, its dimension is smaller than the one of σ. This implies that the linear equation Fσ = τ is under-determined and has many solutions, in this particular case, all the spectra that are compatible with our short time propagation. From all of these possible solutions, eqn (100) takes the one that has the smallest 1-norm, that corresponds to the solution that has the most zero coefficients. For spectra, this means we are choosing the one with the fewest frequencies, which will tend to be the physical one, as for many cases we know that the spectra is composed of a discrete number of frequencies.

To solve eqn (100) numerically, we have implemented in Octopus the SPGL1 algorithm.186 The solution typically takes a few minutes, which is two orders of magnitude more expensive than the standard Fourier transform, but this is negligible in comparison with the cost of the time propagation.

By applying compressed sensing to the determination of absorptional or vibrational spectra, it was found that a time signal a fifth of the length can be used in comparison with the standard Fourier transform.35 This is translated into an impressive factor-of-five reduction in the computational time. This is illustrated in Fig. 13 where we show a spectrum calculated with compressed sensing from a 10 fs propagation, which has a resolution similar to a Fourier transform spectrum obtained with 50 fs of propagation time.


image file: c5cp00351b-f13.tif
Fig. 13 Optical absorption spectrum from a methane molecule from real-time TDDFT. Comparison of the calculation using a Fourier transform and a propagation time of 50 fs (top, black curve) with compressed sensing and a propagation time of 10 fs (bottom, blue curve). Compressed sensing produces a similar resolution, with a propagation 5 times shorter.

Moreover, the general conclusion that can be obtained from this work is that in the application of compressed sensing to simulations the reduction in the number of samples that compressed sensing produces in an experimental setup is translated into a reduction of the computational time. This concept inspired studies on how to carry the ideas of compressed sensing into the core of electronic-structure simulations. The first result of this effort is a method to use compressed sensing to reconstruct sparse matrices, that has direct application in the calculation of the Hessian matrix and vibrational frequencies from linear response (as discussed in Section 3). For this case, our method results in the reduction of the computational time by a factor of three.187

15 Parallelization, optimizations and graphics processing units

Computational cost has been and still is a fundamental factor in the development of electronic structure methods, as the small spatial dimensions and the fast movement of electrons severely limit the size of systems that can be simulated. In order to study systems of interest as realistically and accurately as possible, electronic-structure codes must execute efficiently in modern computational platforms. This implies support for massively parallel platforms and modern parallel processors, including graphics processing units (GPUs).

Octopus has been shown to perform efficiently on parallel supercomputers, scaling to hundreds of thousands of cores.35,188 The code also has an implementation of GPU acceleration35,189 that has shown to be competitive in performance with Gaussian DFT running on GPUs.190

Performance is not only important for established methods, but also for the implementation of new ideas. The simplicity of real-space grids allows us to provide Octopus developers with building blocks that they can use to produce highly efficient code without needing to know the details of the implementation, isolating them as much as possible from the optimization and parallelization requirements. In most cases, these building blocks allow developers to write code that is automatically parallel, efficient, and that can transparently run on GPUs. The type of operations available run from simple ones, like integration, linear algebra, and differential operators, to more sophisticated ones, like the application of a Hamiltonian or solvers for differential equations.

However, it is critical to expose an interface with the adequate level that hides the performance details, while still giving enough flexibility to the developers. For example, we have found that the traditional picture of a state as the basic object is not adequate for optimal performance, as it does not expose enough data parallelism.189 In Octopus we use a higher-level interface where the basic object is a group of several states.

In the case of functions represented on the grid, the developers work with a linear array that contains the values of the field for each grid point. Additional data structures provide information about the grid structure. This level of abstraction makes it simple for developers to write code that works for different problem dimensionality, and different kinds and shapes of grids.

In terms of performance, by hiding the structure of the grid, we can use sophisticated methods to control how the grid points are stored in memory with the objective of using processor caches more efficiently in finite-difference operators. We have found that by using space-filling curves,191 as shown in Fig. 14, and in particular the Hilbert curve,192,193 we can produce a significant improvement in the performance of semi-local operations. For example, in Fig. 15 shows that a performance gain of around 50% can be obtained for the finite-difference Laplacian operator running on a GPU by using a Hilbert curve to map the grid into memory.


image file: c5cp00351b-f14.tif
Fig. 14 Examples of different mappings from a 2D grid to a linear array: (a) standard map, (b) grid mapped by small parallelepipedic subgrids, and (c) mapping given by a Hilbert space-filling curve. These last two mappings provide a much better memory locality for semi-local operations than the standard approach.

image file: c5cp00351b-f15.tif
Fig. 15 Numerical performance of the Octopus finite-difference Laplacian implementation using different grid mappings. Spherical grid with 500[thin space (1/6-em)]000 points. Computations with a AMD Radeon 7970 GPU. A speed up of around 50% is observed for the subgrid and Hilbert curve mappings.

Parallelization in Octopus is performed on different levels. The most basic one is domain decomposition, were the grid is divided in different regions that are assigned to each processor. For most operations, only the boundaries of the regions need to be communicated among processors. Since the grid can have a complicated shape dictated by the shape of the molecule, it is far from trivial to distribute the grid-points among processors. For this task we use a third-party library called ParMETIS.194 This library provides routines to partition the grid ensuring a balance of points and minimizing the size of the boundary regions, and hence the communication costs. An example of grid partitioning is shown in Fig. 16.


image file: c5cp00351b-f16.tif
Fig. 16 Example of adaptive mesh partitioning for a molecule of chlorophyll a. Simplified mesh with a spacing of 0.5 Å and a radius of 2.5 Å. Each color represents a domain, which will be distributed to a set of processors for parallel computation.

Additional parallelization is provided by other data decomposition approaches that are combined with domain decomposition. This includes parallelization over KS states, and over k-points and spin. The latter parallelization strategy is quite efficient, since for each k-point or spin component the operations are independent. However, it is limited by the size of the system, and often is not available (as in the case of closed-shell molecules, for example).

The efficiency of the parallelization over KS states depends on the type of calculation being performed. For ground state calculations, the orthogonalization and subspace diagonalization routines195 require the communication of states. In Octopus this is handled by parallel dense linear-algebra operations provided by the ScaLAPACK library.196 For real-time propagation, on the other hand, the orthogonalization is preserved by the propagation34 and there is no need to communicate KS states between processors. This makes real-time TDDFT extremely efficient in massively parallel computers.35,197

An operation that needs special care in parallel is the solution of the Poisson equation. Otherwise, it constitutes a bottleneck in parallelization, as a single Poisson solution is required independently of the number of states in the system. A considerable effort has been devoted to the problem of finding efficient parallel Poisson solvers that can keep up with the rest of the code.198 We have found that the most efficient methods are based on FFTs, which require a different domain decomposition to perform efficiently. This introduces the additional problem of transferring the data between the two different data partitions. In Octopus this was overcome by creating a mapping at the initialization stage and using it during execution to efficiently communicate only the data that is strictly necessary between processors.188

16 Conclusions

In this article, we have shown several recent developments in the realm of electronic-structure theory that have been based on the Octopus real-space code and made possible in part by the flexibility and simplicity of working with real-space grids. Most of them go beyond a mere implementation of existing theory and represent new ideas in their respective areas. We expect that many of these approaches will become part of the standard tools of physicists, chemists and material scientists, and in the future will be integrated into other electronic-structure codes.

These advances also illustrate the variety of applications of real-space electronic structure, many of which going beyond the traditional calculation schemes used in electronic structure, and might provide a way forward to tackle current and future challenges in the field.

What we have presented also shows some of the current challenges in real-space electronic structure. One example is the use of pseudo-potentials or other forms of projectors to represent the electron–ion interaction. Non-local potentials introduce additional complications on both the formulation, as shown by the case of magnetic response, and the implementation. Pseudo-potentials also include an additional, and in some cases, not well-controlled approximation. It would be interesting to study the possibility of developing an efficient method to perform full-potential calculations without additional computational cost, for example by using adaptive or radial grids.

Another challenge for real-space approaches is the cost of the calculation of two-body Coulomb integrals that appear in electron–hole linear response, RDMFT or hybrid xc functionals. In real-space these integrals are calculated in linear or quasi-linear time by considering them as a Poisson problem. However, the actual numerical cost can be quite large when compared with other operations. A fast approach to compute these integrals, perhaps by using an auxiliary basis, would certainly make the real-space approach more competitive for some applications.

The scalability of real-space grid methods makes them a good candidate for electronic-structure simulations in the future exaflop supercomputing systems expected for the end of the decade. In this aspect, the challenge is to develop high-performance implementations that can run efficiently on these machines.

Acknowledgements

We would like to thank all the people that have contributed to Octopus and to the development and implementation of the applications presented in this article. In particular we would like to acknowledge Pablo García-Risueño (for his contribution to the development of scalable Poisson solvers), Joaquim Jornet Somoza, Silvana Botti, Jacob Sanders, Johanna Fuks, Arto Sakko, Heiko Appel, Danilo Nitsche, Florian Lorenzen, Daniele Varsano, Carlo A. Rozzi, Roberto Olivares-Amaya, Alain Delgado, Pablo Garcia-González, Javier Muguerza, and Agustin Arruabarrena. XA acknowledges that part of this work was performed under the auspices of the U.S. Department of Energy at Lawrence Livermore National Laboratory under Contract DE-AC52-07A27344. XA and AA-G would like to thank the support received from Nvidia Corporation through the CUDA Center of Excellence program and the US Defense Threat Reduction Agency under contract no. HDTRA1-10-1-0046. DAS acknowledges support from the U.S. National Science Foundation graduate research program and IGERT fellowships, and from ARPA-E under grant DE-AR0000180. MJTO acknowledges financial support from the Belgian FNRS through FRFC project number 2.4545.12 “Control of attosecond dynamics: applications to molecular reactivity”. NH and IT received support from a Emmy-Noether grant from Deutsche Forschungsgemeinschaft. JAR, AV, UDG, AHL and AR ackowledge financial support by the European Research Council Advanced Grant DYNamo (ERC-2010-AdG-267374), European Commission project CRONOS (Grant number 280879-2 CRONOS CP-FP7), Marie Curie ITN POCAONTAS (FP7-PEOPLE-2012-ITN, project number 316633), OST Actions CM1204 (XLIC), and MP1306 (EUSpec), Spanish Grant (FIS2013-46159-C3-1-P) and Grupo Consolidado UPV/EHU del Gobierno Vasco (IT578-13). JAR acknowledges the Department of Education, Universities and Research of the Basque Government (grant IT395-10). AC acknowledges support from the grant FIS2013-46159-C3-2-P of the Spanish government. This article was written using Authorea.

References

  1. P. Hohenberg and W. Kohn, Phys. Rev., 1964, 136, B864–B871 CrossRef .
  2. W. Kohn and L. J. Sham, Phys. Rev., 1965, 140, A1133–A1138 CrossRef .
  3. A. J. Cohen, P. Mori-Sanchez and W. Yang, Science, 2008, 321, 792–794 CrossRef CAS PubMed .
  4. A. Szabo and N. Ostlund, Modern Quantum Chemistry: Introduction to Advanced Electronic Structure Theory, Dover Publications, 1996 Search PubMed .
  5. R. Dovesi, R. Orlando, A. Erba, C. M. Zicovich-Wilson, B. Civalleri, S. Casassa, L. Maschio, M. Ferrabone, M. D. L. Pierre, P. DArco, Y. Noël, M. Causà, M. Rérat and B. Kirtman, Int. J. Quantum Chem., 2014, 114, 1287–1317 CrossRef CAS PubMed .
  6. S. White, J. Wilkins and M. Teter, Phys. Rev. B: Condens. Matter Mater. Phys., 1989, 39, 5819–5833 CrossRef .
  7. E. Tsuchida and M. Tsukada, Phys. Rev. B: Condens. Matter Mater. Phys., 1995, 52, 5573–5578 CrossRef CAS .
  8. R. J. Harrison, G. I. Fann, T. Yanai, Z. Gan and G. Beylkin, J. Chem. Phys., 2004, 121, 11587 CrossRef CAS PubMed .
  9. M. Stener, G. Fronzoni and P. Decleva, J. Chem. Phys., 2005, 122, 234301 CrossRef CAS PubMed .
  10. L. Genovese, B. Videau, M. Ospici, T. Deutsch, S. Goedecker and J.-F. Méhaut, C. R. Mec., 2011, 339, 149–164 CrossRef CAS PubMed .
  11. A. D. Becke, Int. J. Quantum Chem., 1989, 36, 599–609 CrossRef PubMed .
  12. J. Chelikowsky, N. Troullier and Y. Saad, Phys. Rev. Lett., 1994, 72, 1240–1243 CrossRef CAS .
  13. A. Seitsonen, M. Puska and R. Nieminen, Phys. Rev. B: Condens. Matter Mater. Phys., 1995, 51, 14057–14061 CrossRef CAS .
  14. T. Hoshi, M. Arai and T. Fujiwara, Phys. Rev. B: Condens. Matter Mater. Phys., 1995, 52, R5459–R5462 CrossRef CAS .
  15. F. Gygi and G. Galli, Phys. Rev. B: Condens. Matter Mater. Phys., 1995, 52, R2229–R2232 CrossRef CAS .
  16. E. Briggs, D. Sullivan and J. Bernholc, Phys. Rev. B: Condens. Matter Mater. Phys., 1996, 54, 14362–14375 CrossRef CAS .
  17. J.-L. Fattebert, BIT Numer. Math., 1996, 36, 509–522 CrossRef .
  18. T. L. Beck, Int. J. Quantum Chem., 1997, 65, 477–486 CrossRef CAS .
  19. T. Ono and K. Hirose, Phys. Rev. Lett., 1999, 82, 5016–5019 CrossRef CAS .
  20. T. Beck, Rev. Mod. Phys., 2000, 72, 1041–1080 CrossRef CAS .
  21. M. Nardelli, J.-L. Fattebert and J. Bernholc, Phys. Rev. B: Condens. Matter Mater. Phys., 2001, 64, 245423 CrossRef .
  22. M. A. L. Marques, A. Castro, G. F. Bertsch and A. Rubio, Comput. Phys. Commun., 2003, 151, 60–78 CrossRef CAS .
  23. J. Pask and P. Sterne, Phys. Rev. B: Condens. Matter Mater. Phys., 2005, 71, 113101 CrossRef .
  24. L. Kronik, A. Makmal, M. L. Tiago, M. M. G. Alemany, M. Jain, X. Huang, Y. Saadand and J. R. Chelikowsky, Phys. Status Solidi B, 2006, 243, 1063–1079 CrossRef CAS PubMed .
  25. R. Schmid, M. Tafipolsky, P. H. König and H. Köstler, Phys. Status Solidi B, 2006, 243, 1001–1015 CrossRef CAS PubMed .
  26. E. Krotscheck, E. R. Hernández, S. Janecek, M. S. Kaczmarski and R. Wahl, Eur. Phys. J. D, 2007, 43, 173–176 CrossRef CAS PubMed .
  27. J. Bernholc, M. Hodak and W. Lu, J. Phys.: Condens. Matter, 2008, 20, 294205 CrossRef .
  28. F. Shimojo, R. Kalia, A. Nakano and P. Vashishta, Phys. Rev. B: Condens. Matter Mater. Phys., 2008, 77, 085103 CrossRef .
  29. H. Goto and K. Hirose, J. Phys.: Condens. Matter, 2009, 21, 064231 CrossRef PubMed .
  30. J. Enkovaara, C. Rostgaard, J. J. Mortensen, J. Chen, M. Duak, L. Ferrighi, J. Gavnholt, C. Glinsvad, V. Haikola, H. A. Hansen, H. H. Kristoffersen, M. Kuisma, A. H. Larsen, L. Lehtovaara, M. Ljungberg, O. Lopez-Acevedo, P. G. Moses, J. Ojanen, T. Olsen, V. Petzold, N. A. Romero, J. Stausholm-Mller, M. Strange, G. A. Tritsaris, M. Vanin, M. Walter, B. Hammer, H. Häkkinen, G. K. H. Madsen, R. M. Nieminen, J. K. Nrskov, M. Puska, T. T. Rantala, J. Schitz, K. S. Thygesen and K. W. Jacobsen, J. Phys.: Condens. Matter, 2010, 22, 253202 CrossRef CAS PubMed .
  31. J.-I. Iwata, D. Takahashi, A. Oshiyama, T. Boku, K. Shiraishi, S. Okada and K. Yabana, J. Comput. Phys., 2010, 229, 2339–2363 CrossRef CAS PubMed .
  32. A. Sasaki, M. Kojo, K. Hirose and H. Goto, J. Phys.: Condens. Matter, 2011, 23, 434001 CrossRef PubMed .
  33. T. Ono, S. Tsukamoto, Y. Egami and Y. Fujimoto, J. Phys.: Condens. Matter, 2011, 23, 394203 CrossRef PubMed .
  34. A. Castro and M. A. L. Marques, Time-Dependent Density Functional Theory, Springer Science+Business Media, 2006, pp. 197–210 Search PubMed .
  35. X. Andrade, J. N. Sanders and A. Aspuru-Guzik, Proc. Natl. Acad. Sci. U. S. A., 2012, 109, 13928–13933 CrossRef CAS PubMed .
  36. M. A. L. Marques, A. Castro and A. Rubio, J. Chem. Phys., 2001, 115, 3006 CrossRef CAS PubMed .
  37. K. Yabana and G. Bertsch, Phys. Rev. B: Condens. Matter Mater. Phys., 1996, 54, 4484–4487 CrossRef CAS .
  38. G. Bertsch, J.-I. Iwata, A. Rubio and K. Yabana, Phys. Rev. B: Condens. Matter Mater. Phys., 2000, 62, 7998–8002 CrossRef CAS .
  39. R. Aggarwal, L. Farrar, S. Saikin, X. Andrade, A. Aspuru-Guzik and D. Polla, Solid State Commun., 2012, 152, 204–209 CrossRef CAS PubMed .
  40. J. Alonso, X. Andrade, P. Echenique, F. Falceto, D. Prada-Gracia and A. Rubio, Phys. Rev. Lett., 2008, 101, 096403 CrossRef CAS .
  41. X. Andrade, A. Castro, D. Zueco, J. L. Alonso, P. Echenique, F. Falceto and A. Rubio, J. Chem. Theory Comput., 2009, 5, 728–742 CrossRef CAS .
  42. T. Burnus, M. A. L. Marques and E. K. U. Gross, Phys. Rev. A: At., Mol., Opt. Phys., 2005, 71, 010501(R) CrossRef .
  43. J. Deslippe, G. Samsonidze, D. A. Strubbe, M. Jain, M. L. Cohen and S. G. Louie, Comput. Phys. Commun., 2012, 183, 1269–1289 CrossRef CAS PubMed .
  44. M. J. Oliveira and F. Nogueira, Comput. Phys. Commun., 2008, 178, 524–534 CrossRef CAS PubMed .
  45. R. Sternheimer, Phys. Rev., 1951, 84, 244–253 CrossRef CAS .
  46. S. Baroni, S. de Gironcoli and A. Dal Corso, Rev. Mod. Phys., 2001, 73, 515–562 CrossRef CAS .
  47. X. Andrade, S. Botti, M. A. L. Marques and A. Rubio, J. Chem. Phys., 2007, 126, 184106 CrossRef PubMed .
  48. X. Gonze and J.-P. Vigneron, Phys. Rev. B: Condens. Matter Mater. Phys., 1989, 39, 13120–13128 CrossRef .
  49. A. Dal Corso, F. Mauri and A. Rubio, Phys. Rev. B: Condens. Matter Mater. Phys., 1996, 53, 15638–15642 CrossRef CAS .
  50. S. de Gironcoli, Phys. Rev. B: Condens. Matter Mater. Phys., 1995, 51, 6773–6776 CrossRef CAS .
  51. D. A. Strubbe, PhD thesis, University of California, Berkeley, 2012 .
  52. N. Mermin, Phys. Rev., 1965, 137, A1441–A1443 CrossRef .
  53. M. Methfessel and A. Paxton, Phys. Rev. B: Condens. Matter Mater. Phys., 1989, 40, 3616–3621 CrossRef CAS .
  54. J. Holender, M. Gillan, M. Payne and A. Simpson, Phys. Rev. B: Condens. Matter Mater. Phys., 1995, 52, 967–975 CrossRef CAS .
  55. N. Marzari, D. Vanderbilt, A. D. Vita and M. Payne, Phys. Rev. Lett., 1999, 82, 3296–3299 CrossRef CAS .
  56. R. W. Freund and N. M. Nachtigal, Numer. Math., 1991, 60, 315–339 CrossRef .
  57. F. D. Vila, D. A. Strubbe, Y. Takimoto, X. Andrade, A. Rubio, S. G. Louie and J. J. Rehr, J. Chem. Phys., 2010, 133, 034111 CrossRef PubMed .
  58. S. Botti, A. Castro, X. Andrade, A. Rubio and M. A. L. Marques, Phys. Rev. B: Condens. Matter Mater. Phys., 2008, 78, 035333 CrossRef .
  59. E. Kadantsev and M. Stott, Phys. Rev. B: Condens. Matter Mater. Phys., 2005, 71, 045104 CrossRef .
  60. G. Deinzer and D. Strauch, Phys. Rev. B: Condens. Matter Mater. Phys., 2002, 66, 100301 CrossRef .
  61. M. Cardona and F. Pollak, Phys. Rev., 1966, 142, 530–543 CrossRef CAS .
  62. R. Resta and D. Vanderbilt, Topics in Applied Physics, Springer Science+Business Media, 2007, pp. 31–68 Search PubMed .
  63. X. Gonze and C. Lee, Phys. Rev. B: Condens. Matter Mater. Phys., 1997, 55, 10355–10368 CrossRef CAS .
  64. P. Giannozzi, S. Baroni, N. Bonini, M. Calandra, R. Car, C. Cavazzoni, D. Ceresoli, G. L. Chiarotti, M. Cococcioni, I. Dabo, A. Dal Corso, S. de Gironcoli, S. Fabris, G. Fratesi, R. Gebauer, U. Gerstmann, C. Gougoussis, A. Kokalj, M. Lazzeri, L. Martin-Samos, N. Marzari, F. Mauri, R. Mazzarello, S. Paolini, A. Pasquarello, L. Paulatto, C. Sbraccia, S. Scandolo, G. Sclauzero, A. P. Seitsonen, A. Smogunov, P. Umari and R. M. Wentzcovitch, J. Phys.: Condens. Matter, 2009, 21, 395502 CrossRef PubMed .
  65. E. Yaschenko, L. Fu, L. Resca and R. Resta, Phys. Rev. B: Condens. Matter Mater. Phys., 1998, 58, 1222–1229 CrossRef CAS .
  66. K. Wolinski, J. F. Hinton and P. Pulay, J. Am. Chem. Soc., 1990, 112, 8251–8260 CrossRef CAS .
  67. M. Schindler and W. Kutzelnigg, J. Chem. Phys., 1982, 76, 1919–1933 CrossRef CAS PubMed .
  68. T. D. Bouman and A. E. Hansen, J. Chem. Phys., 1977, 66, 3460 CrossRef CAS PubMed .
  69. S. Ismail-Beigi, E. Chang and S. Louie, Phys. Rev. Lett., 2001, 87, 087402 CrossRef CAS .
  70. C. Pickard and F. Mauri, Phys. Rev. Lett., 2003, 91, 196401 CrossRef .
  71. D. Varsano, L. A. Espinosa-Leal, X. Andrade, M. A. L. Marques, R. di Felice and A. Rubio, Phys. Chem. Chem. Phys., 2009, 11, 4481 RSC .
  72. R. C. Haddon, L. F. Schneemeyer, J. V. Waszczak, S. H. Glarum, R. Tycko, G. Dabbagh, A. R. Kortan, A. J. Muller, A. M. Mujsce, M. J. Rosseinsky, S. M. Zahurak, A. V. Makhija, F. A. Thiel, K. Raghavachari, E. Cockayne and V. Elser, Nature, 1991, 350, 46–47 CrossRef CAS PubMed .
  73. R. C. Haddon, Nature, 1995, 378, 249–255 CrossRef CAS PubMed .
  74. S. Botti, A. Castro, N. N. Lathiotakis, X. Andrade and M. A. L. Marques, Phys. Chem. Chem. Phys., 2009, 11, 4523 RSC .
  75. D. A. Strubbe, L. Lehtovaara, A. Rubio, M. A. L. Marques and S. G. Louie, Fundamentals of Time-Dependent Density Functional Theory, Springer Berlin/Heidelberg, 2012, vol. 837, pp. 139–166 Search PubMed .
  76. G. Onida, L. Reining and A. Rubio, Rev. Mod. Phys., 2002, 74, 601–659 CrossRef CAS .
  77. M. Petersilka, U. J. Gossmann and E. K. U. Gross, Phys. Rev. Lett., 1996, 76, 1212–1215 CrossRef CAS .
  78. S. Hirata and M. Head-Gordon, Chem. Phys. Lett., 1999, 314, 291–299 CrossRef CAS .
  79. M. E. Casida, THEOCHEM, 2009, 914, 3–18 CrossRef CAS PubMed .
  80. M. E. Casida, Recent Advances in Density Functional Methods, World Scientific, Singapore, 1995, pp. 155–192 Search PubMed .
  81. C. Jamorski, M. E. Casida and D. R. Salahub, J. Chem. Phys., 1996, 104, 5134–5147 CrossRef CAS PubMed .
  82. T. Ziegler, M. Seth, M. Krykunov, J. Autschbach and F. Wang, J. Chem. Phys., 2009, 130, 154102 CrossRef PubMed .
  83. A. Sakko, A. Rubio, M. Hakala and K. Hämäläinen, J. Chem. Phys., 2010, 133, 174111 CrossRef PubMed .
  84. S. H. Vosko, L. Wilk and M. Nusair, Can. J. Phys., 1980, 58, 1200 CrossRef CAS .
  85. S. B. Ben-Shlomo and U. Kaldor, J. Chem. Phys., 1990, 92, 3680–3682 CrossRef CAS PubMed .
  86. E. Anderson, Z. Bai, C. Bischof, S. Blackford, J. Demmel, J. Dongarra, J. Du Croz, A. Greenbaum, S. Hammarling, A. McKenney and D. Sorensen, LAPACK Users' Guide, Society for Industrial and Applied Mathematics, Philadelphia, PA, 3rd edn, 1999 Search PubMed .
  87. D. A. Strubbe and J. C. Grossman, Photoisomerization dynamics of solar thermal fuels with TDDFT excited-state forces, 2015 Search PubMed  , in preparation.
  88. A. Sitt, L. Kronik, S. Ismail-Beigi and J. R. Chelikowsky, Phys. Rev. A: At., Mol., Opt. Phys., 2007, 76, 054501 CrossRef .
  89. T. Tsukagoshi and O. Sugino, Phys. Rev. A: At., Mol., Opt. Phys., 2012, 86, 064501 CrossRef .
  90. J. Hutter, J. Chem. Phys., 2003, 118, 3928–3934 CrossRef CAS PubMed .
  91. X. Andrade, PhD thesis, University of the Basque Country – UPV/EHU, 2010 .
  92. M. Tafipolsky and R. Schmid, J. Chem. Phys., 2006, 124, 174102 CrossRef PubMed .
  93. K. Hirose, First-principles Calculations in Real-space Formalism: Electronic Configurations and Transport Properties of Nanostructures, World Scientific Publishing Company Pte Limited, 2005 Search PubMed .
  94. E. Bitzek, P. Koskinen, F. Gähler, M. Moseler and P. Gumbsch, Phys. Rev. Lett., 2006, 97, 170201 CrossRef .
  95. D. Asenjo, J. D. Stevenson, D. J. Wales and D. Frenkel, J. Phys. Chem. B, 2013, 117, 12717–12723 CrossRef CAS PubMed .
  96. P. Puschnig, S. Berkebile, A. J. Fleming, G. Koller, K. Emtsev, T. Seyller, J. D. Riley, C. Ambrosch-Draxl, F. P. Netzer and M. G. Ramsey, Science, 2009, 326, 702–706 CrossRef CAS PubMed .
  97. M. Wiener, D. Hauschild, C. Sauer, V. Feyer, A. Schöll and F. Reinert, Nat. Commun., 2014, 5, 4156 Search PubMed .
  98. Y. Huismans, A. Rouzee, A. Gijsbertsen, J. H. Jungmann, A. S. Smolkowska, P. S. W. M. Logman, F. Lepine, C. Cauchy, S. Zamith, T. Marchenko, J. M. Bakker, G. Berden, B. Redlich, A. F. G. van der Meer, H. G. Muller, W. Vermin, K. J. Schafer, M. Spanner, M. Y. Ivanov, O. Smirnova, D. Bauer, S. V. Popruzhenko and M. J. J. Vrakking, Science, 2010, 331, 61–64 CrossRef PubMed .
  99. U. De Giovannini, D. Varsano, M. A. L. Marques, H. Appel, E. K. U. Gross and A. Rubio, Phys. Rev. A: At., Mol., Opt. Phys., 2012, 85, 062515 CrossRef .
  100. S. Kunis, D. Potts and G. Steidl, J. Numer. Math., 2006, 14, 295–303 CrossRef .
  101. J. Keiner, S. Kunis and D. Potts, ACM Trans. Math. Softw., 2009, 36, 1–30 CrossRef .
  102. U. De Giovannini, A. H. Larsen and A. Rubio, Eur. Phys. J. B, 2015 DOI:10.1140/epjb/e2015-50808-0 .
  103. U. De Giovannini, G. Brunetto, A. Castro, J. Walkenhorst and A. Rubio, ChemPhysChem, 2013, 14, 1363–1376 CrossRef CAS PubMed .
  104. A. Crawford-Uranga, U. De Giovannini, D. J. Mowbray, S. Kurth and A. Rubio, J. Phys. B: At., Mol. Opt. Phys., 2014, 47, 124018 CrossRef .
  105. A. J. F. Siegert, Phys. Rev., 1939, 56, 750–752 CrossRef CAS .
  106. N. Hatano, K. Sasada, H. Nakamura and T. Petrosky, Prog. Theor. Phys., 2008, 119, 187–222 CrossRef CAS .
  107. J. Aguilar and J. Combes, Commun. Math. Phys., 1971, 22, 269–279 CrossRef .
  108. E. Balslev and J. M. Combes, Commun. Math. Phys., 1971, 22, 280–294 CrossRef .
  109. B. Simon, Ann. Math., 1973, 247–274 CrossRef .
  110. W. P. Reinhardt, Annu. Rev. Phys. Chem., 1982, 33, 223–255 CrossRef CAS .
  111. Y. Ho, Phys. Rep., 1983, 99, 1–68 CrossRef CAS .
  112. A. H. Larsen, U. De Giovannini, D. L. Whitenack, A. Wasserman and A. Rubio, J. Phys. Chem. Lett., 2013, 4, 2734–2738 CrossRef CAS .
  113. A. Wasserman and N. Moiseyev, Phys. Rev. Lett., 2007, 98, 093003 CrossRef .
  114. D. L. Whitenack and A. Wasserman, J. Phys. Chem. Lett., 2010, 1, 407–411 CrossRef CAS .
  115. D. L. Whitenack and A. Wasserman, Phys. Rev. Lett., 2011, 107, 163002 CrossRef .
  116. M. V. Ammosov, N. B. Delone and V. P. Krainov, Zh. Eksp. Teor. Fiz., 1986, 91, 2008–2013 Search PubMed .
  117. A. Scrinzi, M. Geissler and T. Brabec, Phys. Rev. Lett., 1999, 83, 706–709 CrossRef CAS .
  118. R. van Leeuwen and E. J. Baerends, Phys. Rev. A: At., Mol., Opt. Phys., 1994, 49, 2421–2431 CrossRef CAS .
  119. C. Brif, R. Chakrabarti and H. Rabitz, New J. Phys., 2010, 12, 075008 CrossRef .
  120. J. Werschnik and E. Gross, J. Phys. B: At., Mol. Opt. Phys., 2007, 40, R175–R211 CrossRef CAS .
  121. S. Shi, A. Woody and H. Rabitz, J. Chem. Phys., 1988, 88, 6870 CrossRef CAS PubMed .
  122. A. Peirce, M. Dahleh and H. Rabitz, Phys. Rev. A: At., Mol., Opt. Phys., 1988, 37, 4950 CrossRef .
  123. R. Kosloff, S. A. Rice, P. Gaspard, S. Tersigni and D. J. Tannor, Chem. Phys., 1989, 139, 201–220 CrossRef CAS .
  124. M. Galassi, J. Davies, J. Theiler, B. Gough, G. Jungman, P. Alken, M. Booth and F. Rossi, GNU Scientific Library Reference Manual, Network Theory Ltd, 3rd edn (v1.12), 2009 Search PubMed .
  125. W. Zhu, J. Botina and H. Rabitz, J. Chem. Phys., 1998, 108, 1953–1963 CrossRef CAS PubMed .
  126. W. Zhu and H. Rabitz, J. Chem. Phys., 1998, 109, 385–391 CrossRef CAS PubMed .
  127. Y. Ohtsuki, W. Zhu and H. Rabitz, J. Chem. Phys., 1999, 110, 9825 CrossRef CAS PubMed .
  128. A. Castro, M. A. L. Marques and A. Rubio, J. Chem. Phys., 2004, 121, 3425 CrossRef CAS PubMed .
  129. A. Castro, J. Werschnik and E. Gross, Phys. Rev. Lett., 2012, 109, 153603 CrossRef CAS .
  130. E. Räsänen, A. Castro, J. Werschnik, A. Rubio and E. Gross, Phys. Rev. Lett., 2007, 98, 157404 CrossRef .
  131. E. Räsänen, A. Castro and J. Werschnik, Phys. Rev. B: Condens. Matter Mater. Phys., 2008, 77, 085324 CrossRef .
  132. A. Castro, E. Räsänen, A. Rubio and E. K. U. Gross, Europhys. Lett., 2009, 87, 53001 CrossRef .
  133. D. Kammerlander, A. Castro and M. A. L. Marques, Phys. Rev. A: At., Mol., Opt. Phys., 2011, 83, 043413 CrossRef .
  134. K. Krieger, A. Castro and E. K. U. Gross, Chem. Phys., 2011, 391, 51 CrossRef PubMed .
  135. A. Castro, ChemPhysChem, 2013, 14, 1488–1495 CrossRef CAS PubMed .
  136. A. Castro and E. K. U. Gross, J. Phys. A: Math. Theor., 2014, 47, 025204 CrossRef .
  137. A. Taflove, IEEE Trans. Electromagn. Compat., 1980, EMC–22, 191–202 CrossRef .
  138. R. Benzi, S. Succi and M. Vergassola, Phys. Rep., 1992, 222, 145–197 CrossRef .
  139. K. J. Savage, M. M. Hawkeye, R. Esteban, A. G. Borisov, J. Aizpurua and J. J. Baumberg, Nature, 2012, 491, 574–577 CrossRef CAS PubMed .
  140. K. Kneipp, H. Kneipp, I. Itzkan, R. R. Dasari and M. S. Feld, J. Phys.: Condens. Matter, 2002, 14, R597–R624 CrossRef CAS .
  141. N. Grady, N. Halas and P. Nordlander, Chem. Phys. Lett., 2004, 399, 167–171 CrossRef CAS PubMed .
  142. J. Dobson and H. Le, THEOCHEM, 2000, 501–502, 327–338 CrossRef CAS .
  143. S. Raza, G. Toscano, A.-P. Jauho, M. Wubs and N. A. Mortensen, Phys. Rev. B: Condens. Matter Mater. Phys., 2011, 84, 121412(R) CrossRef .
  144. A. D. Boardman, Electromagnetic Surface Modes, Wiley-Blackwell, 1982 Search PubMed .
  145. J. Zuloaga, E. Prodan and P. Nordlander, ACS Nano, 2010, 4, 5269–5276 CrossRef CAS PubMed .
  146. D. Marinica, A. Kazansky, P. Nordlander, J. Aizpurua and A. G. Borisov, Nano Lett., 2012, 12, 1333–1339 CrossRef CAS PubMed .
  147. E. Townsend and G. W. Bryant, Nano Lett., 2012, 12, 429–434 CrossRef CAS PubMed .
  148. L. Stella, P. Zhang, F. J. Garcá-Vidal, A. Rubio and P. Garcá-González, J. Phys. Chem. C, 2013, 117, 8941–8949 CAS .
  149. T. V. Teperik, P. Nordlander, J. Aizpurua and A. G. Borisov, Phys. Rev. Lett., 2013, 110, 263901 CrossRef CAS .
  150. H. Xiang, X. Zhang, D. Neuhauser and G. Lu, J. Phys. Chem. Lett., 2014, 5, 1163–1169 CrossRef CAS PubMed .
  151. P. Zhang, J. Feist, A. Rubio, P. Garcá-González and F. J. Garcá-Vidal, Phys. Rev. B: Condens. Matter Mater. Phys., 2014, 90, 161407(R) CrossRef .
  152. R. Esteban, A. G. Borisov, P. Nordlander and J. Aizpurua, Nat. Commun., 2012, 3, 825 CrossRef PubMed .
  153. M. S. Tame, K. R. McEnery, S. K. Özdemir, J. Lee, S. A. Maier and M. S. Kim, Nat. Phys., 2013, 9, 329–340 CrossRef CAS PubMed .
  154. A. Rubio and L. Serra, Phys. Rev. B: Condens. Matter Mater. Phys., 1993, 48, 18222–18229 CrossRef CAS .
  155. G. E. Scuseria and V. N. Staroverov, Theory and Applications of Computational Chemistry: The First Forty Years, Elsevier, Amsterdam, 2005, pp. 669–724 Search PubMed .
  156. J. P. Perdew and K. Schmidt, AIP Conf. Proc., 2001, 577, 1–20 CrossRef CAS PubMed .
  157. M. A. L. Marques, M. J. T. Oliveira and T. Burnus, Comput. Phys. Commun., 2012, 183, 2272–2281 CrossRef CAS PubMed .
  158. A. Zunger, J. Perdew and G. Oliver, Solid State Commun., 1980, 34, 933–936 CrossRef CAS .
  159. S. Kümmel and J. Perdew, Phys. Rev. Lett., 2003, 90, 043004 CrossRef .
  160. J. Slater, Phys. Rev., 1951, 81, 385–390 CrossRef CAS .
  161. J. Krieger, Y. Li and G. Iafrate, Phys. Lett. A, 1990, 148, 470–474 CrossRef .
  162. N. Helbig, J. I. Fuks, M. Casula, M. J. Verstraete, M. A. L. Marques, I. V. Tokatly and A. Rubio, Phys. Rev. A: At., Mol., Opt. Phys., 2011, 83, 032503 CrossRef .
  163. M. J. T. Oliveira, E. Räsänen, S. Pittalis and M. A. L. Marques, J. Chem. Theory Comput., 2010, 6, 3664–3670 CrossRef CAS .
  164. X. Andrade and A. Aspuru-Guzik, Phys. Rev. Lett., 2011, 107, 183002 CrossRef .
  165. M. A. Mosquera and A. Wasserman, Mol. Phys., 2014, 112, 2997–3013 CrossRef CAS PubMed .
  166. T. L. Gilbert, Phys. Rev. B: Solid State, 1975, 12, 2111–2120 CrossRef .
  167. O. Gritsenko, K. Pernal and E. J. Baerends, J. Chem. Phys., 2005, 122, 204102 CrossRef PubMed .
  168. M. A. L. Marques and N. N. Lathiotakis, Phys. Rev. A: At., Mol., Opt. Phys., 2008, 77, 032509 CrossRef .
  169. M. Piris, Int. J. Quantum Chem., 2013, 113, 620–630 CrossRef CAS PubMed .
  170. A. Müller, Phys. Lett. A, 1984, 105, 446–452 CrossRef .
  171. A. J. Coleman, Rev. Mod. Phys., 1963, 35, 668–686 CrossRef .
  172. M. Piris and J. M. Ugalde, J. Comput. Chem., 2009, 30, 2078–2086 CrossRef CAS PubMed .
  173. N. N. Lathiotakis and M. A. L. Marques, J. Chem. Phys., 2008, 128, 183103 CrossRef PubMed .
  174. P. Ranitovic, C. W. Hogle, P. Rivière, A. Palacios, X.-M. Tong, N. Toshima, A. González-Castrillo, L. Martin, F. Martín, M. M. Murnane and H. Kapteyn, Proc. Natl. Acad. Sci. U. S. A., 2014, 111, 912–917 CrossRef CAS PubMed .
  175. M. Lein, T. Kreibich, E. K. U. Gross and V. Engel, Phys. Rev. A: At., Mol., Opt. Phys., 2002, 65, 033403 CrossRef .
  176. K. Luo, P. Elliott and N. T. Maitra, Phys. Rev. A: At., Mol., Opt. Phys., 2013, 88, 042508 CrossRef .
  177. J. D. Ramsden and R. W. Godby, Phys. Rev. Lett., 2012, 109, 036402 CrossRef CAS .
  178. R. McWeeny, Methods of molecular quantum mechanics, Academic Press, 1992 Search PubMed .
  179. N. Helbig, J. Fuks, I. Tokatly, H. Appel, E. Gross and A. Rubio, Chem. Phys., 2011, 391, 1–10 CrossRef CAS PubMed .
  180. E. Candes and M. Wakin, IEEE Signal Process. Mag., 2008, 25, 21–30 CrossRef .
  181. T. Blumensath, SPIE Newsroom, 2009 DOI:10.1117/2.1200812.1461 .
  182. L. Zhu, W. Zhang, D. Elnatan and B. Huang, Nat. Methods, 2012, 9, 721–723 CrossRef CAS PubMed .
  183. J. N. Sanders, S. K. Saikin, S. Mostame, X. Andrade, J. R. Widom, A. H. Marcus and A. Aspuru-Guzik, J. Phys. Chem. Lett., 2012, 3, 2697–2702 CrossRef CAS .
  184. P. F. Schewe, Phys. Today, 2006, 59, 27 Search PubMed .
  185. B. J. Harding and M. Milla, Radio Sci., 2013, 48, 582–588 CrossRef PubMed .
  186. E. van den Berg and M. P. Friedlander, SIAM J. Sci. Comput., 2009, 31, 890–912 CrossRef .
  187. J. N. Sanders, X. Andrade and A. Aspuru-Guzik, ACS Cent. Sci., 2015 DOI:10.1021/oc5000404 .
  188. J. Alberdi-Rodriguez, M. Oliveira, P. García-Risueño, F. Nogueira, J. Muguerza, A. Arruabarrena and A. Rubio, Computational Science and Its Applications ICCSA 2014, Springer International Publishing, 2014, vol. 8582, pp. 607–622 Search PubMed .
  189. X. Andrade and L. Genovese, Fundamentals of Time-Dependent Density Functional Theory, Springer Science+Business Media, 2012, pp. 401–413 Search PubMed .
  190. X. Andrade and A. Aspuru-Guzik, J. Chem. Theory Comput., 2013, 9, 4360–4373 CrossRef CAS .
  191. G. Peano, Math. Ann., 1890, 36, 157–160 CrossRef .
  192. D. Hilbert, Math. Ann., 1891, 38, 115–138 CrossRef .
  193. J. Skilling, AIP Conf. Proc., 2004, 707, 381–387 CrossRef PubMed .
  194. G. Karypis and V. Kumar, Proceedings of the 1996 ACM/IEEE conference on Supercomputing (CDROM), Washington, DC, USA, 1996.
  195. G. Kresse, Phys. Rev. B: Condens. Matter Mater. Phys., 1996, 54, 11169–11186 CrossRef CAS .
  196. L. S. Blackford, J. Choi, A. Cleary, E. D'Azevedo, J. Demmel, I. Dhillon, J. Dongarra, S. Hammarling, G. Henry, A. Petitet, K. Stanley, D. Walker and R. C. Whaley, ScaLAPACK Users' Guide, Society for Industrial and Applied Mathematics, Philadelphia, PA, 1997 Search PubMed .
  197. A. Schleife, E. W. Draeger, V. M. Anisimov, A. A. Correa and Y. Kanai, Comput. Sci. Eng., 2014, 16, 54–60 CrossRef .
  198. P. García-Risueño, J. Alberdi-Rodriguez, M. J. T. Oliveira, X. Andrade, M. Pippig, J. Muguerza, A. Arruabarrena and A. Rubio, J. Comput. Chem., 2013, 35, 427–444 CrossRef PubMed .

This journal is © the Owner Societies 2015
Click here to see how this site uses Cookies. View our privacy policy here.