This repository is a fork of The General-purpose Relativistic Atomic Structure Package (GRASP) - a set of Fortran 90 programs for performing fully relativistic electron structure calculations of atoms.
This fork is intended for incorporating the continuum electron calculations in elastic (single channel) and inelastic (multi-channel) processes into GRASP.
Please note: Currently, only elastic processes are implemented.
The main idea is to use as many computational processes as they are implemented in GRASP, by adapting them to calculate continuum orbitals wave functions.
This fork is completely transparent for usual calculations in GRASP (bound states and their properties).
Only when calculations involving continuum orbital are requested (during the execution of the rmcdhf
program),
the default flow is changed and different output is produced.
The only differences are listed below:
- the default number of points in the radial (NNNP) is increased to 5000 in the
src/lib/libmod/parameter_def_M.f90
file, since continuum orbitals have to be calculated on the far-reaching computational grid; for larger systems, it is recommended to magnify the grid size even several times -
rmcdhf
: in addition to the other properties,$\langle r^3\rangle$ and$\langle r^5\rangle$ are calculated for each orbital, since they are part of the model polarization potential -
rwfnplot
: generation of the input file for thegnuplot
plotting program has been added -
CMakeList.txt
: The file has been reorganized so that the additional user settings in theCMakeList.user
file are correctly taken into account -
CMakeList.user
: file with-fallow-argument-mismatch
flag, required for recent versions of thegfortran
compiler; this file is not part of the original GRASP repository
All modifications in the original source files are clearly marked in the following way:
! PS (or # PS in CMakeList.* )
... code modified/added
! PS END (or # PS END in CMakeList.* )
The basics of the relativistic multiconfiguration Dirac-Hartree-Fock method (RMCDHF)
applied to scattering are described in [1].
In short, the scattering system is constructed as
To obtain the large
are solved using the outward integration method implemented in GRASP. In the above equations,
Please note: From the perspective of the GRASP source code, bound orbital energies are positive. Thus, the continuum electron energy is considered negative. This does not affect the user's actions, for him the continuum electron energy is always positive (or zero in a special case).
If the calculated wave function is to be coupled with some other function (e.g. the bound state), it should be normalized first. The currently implemented per energy continuum wave function normalization is described in [3].
Please note: For calculations of phase shifts and scattering lengths, normalization is usually not required.
The polarization potential coincides with dipole polarization at greater distances but is limited near the nucleus. It is currently modeled and implemented in the following form:
where
For atoms, one possible source for static dipole polarizabilities is [4] (except for Livermorium atom, atomic number 116). There is no single aggregate source for static quadrupole polarizabilities.
For atoms, cut-offs
Polarization potential can be also provided
in numerical form.
It has to be provided in a text file named vpol
located in the working directory, containing space-separated pairs
1.00000E-05 -4.10660E-07
1.05127E-05 -4.31715E-07
1.10517E-05 -4.76698E-07
(...)
Relativistic phase shift
where
Please note: To correctly determine the phase shift, the continuum orbital has to be calculated far enough from the origin, to ensure that all of the potentials can be neglected.
Scattering length is one of the most useful parameters for describing low-energy electron-atom collisions. It is defined as the radius of a rigid sphere in the zero-energy total cross-section. The sign of a scattering length represents the type of interaction: positive for repulsion and negative for attraction.
The common method for determining the scattering length
where
In addition to the above method
(which is subject to the inaccuracy associated with the non-zero energy),
the calculation of the scattering length is implemented as the intersection
of the asymptote of the zero-energy (
Please note: Zero energy wave function, used for accurate scattering lengths calculations is not a typical, oscillating wave function.
- P. Syty and J.E. Sienkiewicz, Relativistic Multiconfiguration Dirac-Hartree-Fock in scattering of electrons from argon atoms, J. Phys. B: At. Mol. Opt. Phys. 38 2859 (2005), https://doi.org/10.1088/0953-4075/38/16/001
- I.P. Grant, B.J. McKenzie, P.H. Norrington, D.F. Mayers, and N.C. Pyper. An atomic multiconfigurational Dirac-Fock package. Comput. Phys. Commun., 21:207–231, (1980), https://doi.org/10.1016/0010-4655(80)90041-7
- R.D. Cowan, The Theory of Atomic Structure and Spectra, University of California Press, Oakland pp. 522–524 (1981), https://www.ucpress.edu/book/9780520038219/the-theory-of-atomic-structure-and-spectra
- P. Schwerdtfeger and J.K. Nagle, 2018 Table of static dipole polarizabilities of the neutral elements in the periodic table, Molecular Physics 117 9-12 (2019), https://doi.org/10.1080/00268976.2018.1535143
- P. Syty, M.P. Piłat, J.E. Sienkiewicz, Calculation of electron scattering lengths on Ar, Kr, Xe, Rn and Og atoms, J. Phys. B: At. Mol. Opt. Phys. (accepted manuscript), https://doi.org/10.1088/1361-6455/ad4fd1
- Calculations of the continuum wave function of electron elastically scattered from atoms and ions, with the model or numerical polarization term
- Phase shift calculations (with grid control, to ensure correct results)
- Calculations of electronic scattering lengths using the zero energy wave function
- Normalization of the calculated continuum orbital
-
2024-07-18
rmcdhf
Added: phase shift calculationrwfnestimate
Added: Dedicated method for initial estimation of the radial wave function for continuum electrongrasptest/continuum
Added: new example for electron-argon scattering (d-wave calculation)README
Updated: most sections, the most important updates for User guide and Theoretical backgroundrmcdhf
Now, the energy of the continuum electron should be entered as a positive value (or zero)- Several minor code and test-case improvements
-
2024-06-25 (Initial release)
- Continuum orbitals generator with scattering length calculations, together with examples for e-Ar and e-Sr scattering
- Positron scattering (work in progress)
- Validation of user-input parameters (work in progress)
- Inelastic scattering (work at the final concept phase)
-
Bound states
Optimize bound states of the selected target (atom / ion) in a usual way (
rnucleus
=>rcsfgenerate
=>rwfnestimate
=>rangular
=>rmcdhf
=>rsave
in the simplest case), or just take nuclear data (isodata
) and radial wave functions (rwfn.out
/.w
) files from any previous calculations.This fork may also be used for that calculation, since it works exactly as the original GRASP for bound states.
Please note: Since only radial orbitals are used (and not the expansion coefficients), calling the
rci
code does not give any improvement. -
CSF list
By invoking
rcsfgenerate
, create a specialrcsf.inp
file with only one CSF, where 'core' is the configuration of the target atom or ion, and 'peel' consists of one additional inactive electron. This electron will be treated as a continuum one; its principal quantum number will be ignored, and its quantum number$\kappa$ will be determined from the subshell designation and final$J$ value, resulting from coupling with the core.Examples for argon-electron scattering:
-
Core subshells:
1s 2s 2p- 2p 3s 3p- 3p
, -
Additional subshell:
-
4s(1,i)
, coupled to$J=1/2$ means s-wave electron of$\kappa=-1$ -
4p(1,i)
, coupled to$J=1/2$ means p-wave electron of$\kappa=1$ -
4p(1,i)
, coupled to$J=3/2$ means p-wave electron of$\kappa=-2$ -
4d(1,i)
, coupled to$J=3/2$ means d-wave electron of$\kappa=2$ -
4d(1,i)
, coupled to$J=5/2$ means d-wave electron of$\kappa=-3$ , etc.
-
Remember to provide the
$J$ value as$2J, 2J$ range (e.g. 1,1 for$J=1/2$ ), and to provide 0 as the number of excitations.Example
rcsf.inp
file for electron-argon scattering (s-wave): -
Core subshells:
Core subshells:
1s 2s 2p- 2p 3s 3p- 3p
Peel subshells:
4s
CSF(s):
4s ( 1)
1/2
1/2+
-
Angular coefficients
Run
rangular
as usual (with Full interaction option enabled). -
Initial estimations of the radialal wave funcitons
Run
rwfnestimate
, using the previously calculated radial wave functions as initial estimation for the 'core' orbitals (option 1 -- GRASP92 File). For estimation of the additional electron which is designed to be a continuum one, use the new option 5 -- Continuum orbital. Any other method (options 2 - 4) should also work (try them, if you encounter convergence problems during the actual calculations in the next step). -
SCF procedure
Invoke
rmcdhf
, then- answer n when asked about Default settings
- answer y when asked about Perform continuum wave function calculations?
- provide continuum electron energy in hartree (should be positive or zero for accurate scattering length calculation)
- decide if polarization potential should be included.
- 0 - do not include polarization potential
-
1 - include the dipole term of the model potential with default parameters:
$\alpha_d$ taken from [2], and cut-off$\langle r_0^3\rangle$ taken from bound state calculations as the size of the outermost orbital; here, the quadrupole term is omitted -
2 - include model potential with all parameters provided manually by the user; in turn:
$\alpha_d$ ,$\langle r_0^3\rangle$ ,$\alpha_q$ and$\langle r_0^5\rangle$ -
3 - include numerical potential from the file named
vpol
- decide (y/n) if the calculated continuum wave function should be normalized
- answer y when asked Change default speed of light or radial grid parameters?
- answer y when asked Revise default radial grid parameters?
- enter new RNT and H values (firstly, the defaults might be kept)
- enter new HP; use non-zero value to force the linearly-logarithmic grid, which ensures adequate grid density far from the scattering centre; 1.0 or less is the good choice for a first try
- enter new N; in general, use as a big number as possible to ensure as long grid as possible;
5000 is the default, but even tens of thousands of points might be required in some cases, which would require code modification (NNNP value in
src/lib/libmod/parameter_def_M.f90
) and recompilation
Please note: If calculations do not converge (Maximal iterations exceeded), experiment with the other grid parameters, and/or try the other method for initial estimation of the radial wave function for the continuum electron.
Please note: Only the
rmcdhf
code has been adapted for continuum orbital calculations, notrmcdhf_mem
,rmcdhf_mem_mpi
orrmcdhf_mpi
. -
Output
The calculated continuum orbital wave function will be stored in the
rwfn.out
file (together with the bound orbitals), and also in a text-formatted filecontinuum.csp
.If the grid is long enough and electron energy is not zero, calculated phase shift and scattering length are written to the screen and to the
rmcdhf.sum
summary file. The accuracy of the scattering length strongly depends on the electron energy (smaller energy means better accuracy, since it should be calculated in the$k\to0$ limit).If the electron energy is set to zero, only the scattering length is calculated in a more accurate approach, as the intersection of the asymptote of the zero-energy wave function with the r-axis. In that case, the additional parameter 'diff' is calculated and shown, specifying the percentage difference between the scattering length calculated from the last two points on the grid, and from the penultimate and the one before the penultimate point (a lower value means better accuracy).
Bound states estimation, continuum orbital wave functions generation (for two different partial waves), phase shift calculations, scattering length calculations using the zero energy approach; calculations with default and manually entered parameters of polarization potential.
Files in /grasptest/continuum/argon-electron_scattering
directory:
-
1_Ar_bound
- script creating the nuclear data and calculating the bound states of argon atom (very simple case without correlations) -
2a_Ar_continuum_electron_s-wave_function
- script calculating continuum orbital of$\kappa = -1$ (s-wave) and electron energy$\epsilon=0.1$ hartree -
2b_Ar_continuum_electron_d-wave_function
- script calculating normalized continuum orbital of$\kappa = 2$ (d-wave) and electron energy$\epsilon=1.0$ hartree -
3_Ar_electronic_scattering_length
- script calculating electronic scattering length using the zero-energy wave function
After running the first script that creates the isodata
and Ar.w
files, the other scripts can be run independently and in any order.
Calculation of scattering length with default parameters of polarization potential,
for a given .w
file with optimized bound states.
Files in /grasptest/continuum/strontium_electronic_scattering_length
directory:
Sr_scattering_length
- script calculating electronic scattering length using the zero-energy wave functionisodata, Sr.w
- nuclear data and previously calculated bound states of strontium
Code development and testing; preparing of the documentation; preparing and scripting the test cases; maintaining the repository
- Paweł Syty, Gdańsk University of Technology, [email protected]
Giving the ideas and theoretical background; proposing and improving the test cases; improving the documentation
- Józef E. Sienkiewicz, Gdańsk University of Technology
- Michał Piłat, Gdańsk University of Technology
The GRASPC modification of GRASP has not yet been published in a scientific journal. Until then, if you find it useful, please consider offering us co-authorship, or cite as:
P. Syty, M.P. Piłat, J.E. Sienkiewicz, GRASPC - GRASP package adapted for the generation of continuum orbitals wave functions, https://github.com/sylaspg/grasp-continuum.git
Please note: All the installation instructions for original GRASP are also valid for that fork, with the repository address changed to:
https://github.com/sylaspg/grasp-continuum.git
. Further in this section there are original instructions, adapted for the GRASPC repository. All the credits goes to the GRASP contributors, who prepared the original installation procedure.
To compile and install GRASPC, first clone this Git repository:
git clone https://github.com/sylaspg/grasp-continuum.git
There are two ways to build GRASPC: either via CMake or via the
Makefile
s in the source tree. Either works and you end up with the GRASPC binaries in the
bin/
directory.
CMake is the recommended way to build GRASPC. The Makefile
-based workflow is still there to
make smoother to transition from Makefile
s to a modern build system.
The first step with CMake is to create a separate out-of-source build directory. The
configure.sh
script can do that for you:
cd grasp-continuum/ && ./configure.sh
This will create a build/
directory with the default Release build
configuration. However, configure.sh
is just a simple wrapper around a cmake
call and if you need more control over the build, you can always invoke cmake
yourself (see CMake documentation for more
information).
To then compile GRASPC, you need to go into the out-of-source build directory and
simply call make
:
cd build/ && make install
Remarks:
-
Running
make install
instructs CMake to actually install the resulting binaries into the conventionalbin/
directory at the root of the repository.When you run just
make
, the resulting binaries will end up under thebuild/
directory (specifically inbuild/bin/
). This is useful when developing and debugging, as it allows you to compile many versions of the binaries from the same source tree with different compilation options (e.g. build with debug symbols enabled) by using several out of source build directories. -
With CMake, GRASPC also supports parallel builds, which can be enabled by passing the
-j
option tomake
(e.g.make -j4 install
to build with four processes). -
The CMake-based build allows running the (non-comprehensive) test suite by calling
ctest
in thebuild/
directory. The configuration and source files for the tests are undertest/
/
The legacy Makefile
-based build can be performed by simply calling the make
in the top
level directory:
make
In this case, the compilation of each of the libraries and programs happens in their
respective directory under src/
and the build artifacts are stored in the source tree.
The resulting binaries and libraries will directly get installed under the bin/
and lib/
directories.
To build a specific library or binary you can pass the path to the source directory as the Make target:
# build libmod
make src/lib/libmod
# build the rci_mpi binary
make src/appl/rci90_mpi
Note that any necessary library dependencies will also get built automatically.
WARNING: the Makefile
s do not know about the dependencies between the source files, so
parallel builds (i.e. calling make
with the -j
option) does not work.
By default the Makefile
is designed to use gfortran
. The variables affecting GRASPC
builds are defined and documented at the beginning of the Makefile
.
For the user it should never be necessary to modify the Makefile
itself. Rather, a
Make.user
file can be create next to the main Makefile
where the build variables can be
overridden. E.g. to use the Intel Fortran compiler instead, you may want to create the
following Make.user
file:
export FC = ifort
export FC_FLAGS = -O3 -save -mkl=sequential
export FC_LD =
export FC_MPI = mpiifort
export OMPI_FC=${FC}
where -mkl=sequential
should be set depending on what version of ifort you have access to.
Alternatively, to customize the GNU gfortran build to e.g. use a specific version of the compiler, you can create a Make.user
file such as
export FC = gfortran-9
export FC_FLAGS = -O3 -fno-automatic
export FC_LD =
export FC_MPI= mpifort
export OMPI_FC=${FC}
To set up a linker search path for the BLAS or LAPACK libraries you can
set FC_LD
as follows:
export FC_LD = -L /path/to/blas
The repository also contains the Make.user.gfortran
and Make.user.ifort
files, which can be used as templates for your own Make.user
file.