mirror of
https://github.com/QuantumPackage/qp2.git
synced 2024-11-09 06:53:38 +01:00
Compare commits
34 Commits
71c186e67a
...
c568f0b943
Author | SHA1 | Date | |
---|---|---|---|
|
c568f0b943 | ||
|
de0802a56d | ||
|
ff4f6d1c98 | ||
|
231b071d78 | ||
22ab996d00 | |||
00375418e5 | |||
cf4f9990bc | |||
c7dedf49ed | |||
4c5759fe6f | |||
c7ef5fc8c7 | |||
3c6b417ae7 | |||
9c028127a0 | |||
ab10efa313 | |||
f36629173d | |||
8a127a9bab | |||
8cdcd08579 | |||
720a63aadf | |||
b71579ab43 | |||
7c285bddf3 | |||
453cfa0b65 | |||
04ca07a540 | |||
f514ba0acd | |||
bd9816d6e3 | |||
6455b281ff | |||
a1c9ec2503 | |||
4a72ca6b12 | |||
ce0a5f4e70 | |||
e53e7585f9 | |||
fedc20dc31 | |||
|
70536970b0 | ||
bdc56d4ee3 | |||
|
5d951efd51 | ||
|
0b3cd3fdef | ||
|
83a9ce67db |
96
CITATION.cff
96
CITATION.cff
@ -1,32 +1,100 @@
|
|||||||
# YAML 1.2
|
# YAML 1.2
|
||||||
# Metadata for citation of this software according to the CFF format (https://citation-file-format.github.io/)
|
# Metadata for citation of this software according to the CFF format (https://citation-file-format.github.io/)
|
||||||
cff-version: 1.0.3
|
cff-version: 1.0.3
|
||||||
message: If you use this software, please cite it using these metadata.
|
message: "If you use this software, please cite it using these metadata."
|
||||||
title: Quantum Package
|
title: Quantum Package
|
||||||
doi: 10.5281/zenodo.825872
|
doi: 10.1021/acs.jctc.9b00176
|
||||||
authors:
|
authors:
|
||||||
- given-names: Anthony
|
|
||||||
family-names: Scemama
|
|
||||||
affiliation: Laboratoire de Chimie et Physique Quantiques / CNRS
|
|
||||||
- given-names: Yann
|
- given-names: Yann
|
||||||
family-names: Garniron
|
family-names: Garniron
|
||||||
affiliation: Laboratoire de Chimie et Physique Quantiques / CNRS
|
affiliation: Laboratoire de Chimie et Physique Quantiques (UMR 5626), Université de Toulouse, CNRS, UPS, Toulouse, France
|
||||||
- given-names: Michel
|
|
||||||
family-names: Caffarel
|
|
||||||
affiliation: Laboratoire de Chimie et Physique Quantiques / CNRS
|
|
||||||
- given-names: Thomas
|
- given-names: Thomas
|
||||||
family-names: Applencourt
|
family-names: Applencourt
|
||||||
affiliation: Argonne National Lab
|
affiliation: Computational Science Division, Argonne National Laboratory, Argonne, Illinois 60439, United States
|
||||||
- given-names: Kevin
|
- given-names: Kevin
|
||||||
family-names: Gasperich
|
family-names: Gasperich
|
||||||
affiliation: Argonne National Lab
|
affiliation: Department of Chemistry, University of Pittsburgh, Pittsburgh, Pennsylvania 15260, United States
|
||||||
- given-names: Anouar
|
- given-names: Anouar
|
||||||
family-names: Benali
|
family-names: Benali
|
||||||
affiliation: Argonne National Lab
|
affiliation: Computational Science Division, Argonne National Laboratory, Argonne, Illinois 60439, United States
|
||||||
|
- given-names: Anthony
|
||||||
|
family-names: Ferté
|
||||||
|
affiliation: Laboratoire de Chimie Théorique, Sorbonne Université, CNRS, Paris, France
|
||||||
|
- given-names: Julien
|
||||||
|
family-names: Paquier
|
||||||
|
affiliation: Laboratoire de Chimie Théorique, Sorbonne Université, CNRS, Paris, France
|
||||||
|
- given-names: Barthélémy
|
||||||
|
family-names: Pradines
|
||||||
|
affiliation: Institut des Sciences du Calcul et des Données, Sorbonne Université, F-75005 Paris, France
|
||||||
|
- given-names: Roland
|
||||||
|
family-names: Assaraf
|
||||||
|
affiliation: Laboratoire de Chimie Théorique, Sorbonne Université, CNRS, Paris, France
|
||||||
|
- given-names: Peter
|
||||||
|
family-names: Reinhardt
|
||||||
|
affiliation: Laboratoire de Chimie Théorique, Sorbonne Université, CNRS, Paris, France
|
||||||
|
- given-names: Julien
|
||||||
|
family-names: Toulouse
|
||||||
|
affiliation: Laboratoire de Chimie Théorique, Sorbonne Université, CNRS, Paris, France
|
||||||
|
- given-names: Pierrette
|
||||||
|
family-names: Barbaresco
|
||||||
|
affiliation: CALMIP, Université de Toulouse, CNRS, INPT, INSA, UPS, UMS 3667, Toulouse, France
|
||||||
|
- given-names: Nicolas
|
||||||
|
family-names: Renon
|
||||||
|
affiliation: CALMIP, Université de Toulouse, CNRS, INPT, INSA, UPS, UMS 3667, Toulouse, France
|
||||||
|
- given-names: Grégoire
|
||||||
|
family-names: David
|
||||||
|
affiliation: Aix-Marseille Univ, CNRS, ICR, Marseille, France
|
||||||
|
- given-names: Jean-Paul
|
||||||
|
family-names: Malrieu
|
||||||
|
affiliation: Laboratoire de Chimie et Physique Quantiques (UMR 5626), Université de Toulouse, CNRS, UPS, Toulouse, France
|
||||||
|
- given-names: Mickaël
|
||||||
|
family-names: Véril
|
||||||
|
affiliation: Laboratoire de Chimie et Physique Quantiques (UMR 5626), Université de Toulouse, CNRS, UPS, Toulouse, France
|
||||||
|
- given-names: Michel
|
||||||
|
family-names: Caffarel
|
||||||
|
affiliation: Laboratoire de Chimie et Physique Quantiques (UMR 5626), Université de Toulouse, CNRS, UPS, Toulouse, France
|
||||||
|
- given-names: Pierre-François
|
||||||
|
family-names: Loos
|
||||||
|
affiliation: Laboratoire de Chimie et Physique Quantiques (UMR 5626), Université de Toulouse, CNRS, UPS, Toulouse, France
|
||||||
- given-names: Emmanuel
|
- given-names: Emmanuel
|
||||||
family-names: Giner
|
family-names: Giner
|
||||||
affiliation: Laboratoire de Chimie Theorique / CNRS
|
affiliation: Laboratoire de Chimie Théorique, Sorbonne Université, CNRS, Paris, France
|
||||||
|
- given-names: Anthony
|
||||||
|
family-names: Scemama
|
||||||
|
affiliation: Laboratoire de Chimie et Physique Quantiques (UMR 5626), Université de Toulouse, CNRS, UPS, Toulouse, France
|
||||||
|
abstract: "Quantum chemistry is a discipline which relies heavily on very
|
||||||
|
expensive numerical computations. The scaling of correlated wave function
|
||||||
|
methods lies, in their standard implementation, between O(N^5) and O(exp(N)),
|
||||||
|
where N is proportional to the system size. Therefore, performing accurate
|
||||||
|
calculations on chemically meaningful systems requires (i) approximations that
|
||||||
|
can lower the computational scaling and (ii) efficient implementations that
|
||||||
|
take advantage of modern massively parallel architectures. Quantum Package is
|
||||||
|
an open-source programming environment for quantum chemistry specially designed
|
||||||
|
for wave function methods. Its main goal is the development of
|
||||||
|
determinant-driven selected configuration interaction (sCI) methods and
|
||||||
|
multireference second-order perturbation theory (PT2). The determinant-driven
|
||||||
|
framework allows the programmer to include any arbitrary set of determinants in
|
||||||
|
the reference space, hence providing greater methodological freedom. The sCI
|
||||||
|
method implemented in Quantum Package is based on the CIPSI (Configuration
|
||||||
|
Interaction using a Perturbative Selection made Iteratively) algorithm which
|
||||||
|
complements the variational sCI energy with a PT2 correction. Additional
|
||||||
|
external plugins have been recently added to perform calculations with
|
||||||
|
multireference coupled cluster theory and range-separated density-functional
|
||||||
|
theory. All the programs are developed with the IRPF90 code generator, which
|
||||||
|
simplifies collaborative work and the development of new features. Quantum
|
||||||
|
Package strives to allow easy implementation and experimentation of new
|
||||||
|
methods, while making parallel computation as simple and efficient as possible
|
||||||
|
on modern supercomputer architectures. Currently, the code enables, routinely,
|
||||||
|
to realize runs on roughly 2 000 CPU cores, with tens of millions of
|
||||||
|
determinants in the reference space. Moreover, we have been able to push up to
|
||||||
|
12 288 cores in order to test its parallel efficiency. In the present
|
||||||
|
manuscript, we also introduce some key new developments: (i) a renormalized
|
||||||
|
second-order perturbative correction for efficient extrapolation to the full CI
|
||||||
|
limit and (ii) a stochastic version of the CIPSI selection performed
|
||||||
|
simultaneously to the PT2 calculation at no extra cost."
|
||||||
version: '2.0'
|
version: '2.0'
|
||||||
date-released: 2019-02-11
|
url: https://quantumpackage.github.io/qp2/
|
||||||
|
date-released: 2019-05-13
|
||||||
repository-code: https://github.com/QuantumPackage/qp2
|
repository-code: https://github.com/QuantumPackage/qp2
|
||||||
|
keywords: [ "computational chemistry", "configuration interaction", "cipsi", "perturbation theory" ]
|
||||||
license: AGPL-3.0-or-later
|
license: AGPL-3.0-or-later
|
||||||
|
53
INSTALL.rst
53
INSTALL.rst
@ -45,6 +45,8 @@ Requirements
|
|||||||
- |ZeroMQ| : networking library
|
- |ZeroMQ| : networking library
|
||||||
- `GMP <https://gmplib.org/>`_ : Gnu Multiple Precision Arithmetic Library
|
- `GMP <https://gmplib.org/>`_ : Gnu Multiple Precision Arithmetic Library
|
||||||
- |OCaml| compiler with |OPAM| package manager
|
- |OCaml| compiler with |OPAM| package manager
|
||||||
|
- `Bubblewrap <https://github.com/projectatomic/bubblewrap>`_ : Sandboxing tool required by Opam
|
||||||
|
- `libcap https://git.kernel.org/pub/scm/linux/kernel/git/morgan/libcap.git`_ : POSIX capabilities required by Bubblewrap
|
||||||
- |Ninja| : a parallel build system
|
- |Ninja| : a parallel build system
|
||||||
|
|
||||||
|
|
||||||
@ -86,6 +88,8 @@ The following packages are supported by the :command:`configure` installer:
|
|||||||
* zeromq
|
* zeromq
|
||||||
* f77zmq
|
* f77zmq
|
||||||
* gmp
|
* gmp
|
||||||
|
* libcap
|
||||||
|
* bwrap
|
||||||
* ocaml ( :math:`\approx` 10 minutes)
|
* ocaml ( :math:`\approx` 10 minutes)
|
||||||
* ezfio
|
* ezfio
|
||||||
* docopt
|
* docopt
|
||||||
@ -243,6 +247,55 @@ With Debian or Ubuntu, you can use
|
|||||||
sudo apt install libgmp-dev
|
sudo apt install libgmp-dev
|
||||||
|
|
||||||
|
|
||||||
|
libcap
|
||||||
|
------
|
||||||
|
|
||||||
|
Libcap is a library for getting and setting POSIX.1e draft 15 capabilities.
|
||||||
|
|
||||||
|
* Download the latest version of libcap here:
|
||||||
|
`<https://git.kernel.org/pub/scm/linux/kernel/git/morgan/libcap.git/snapshot/libcap-2.25.tar.gz>`_
|
||||||
|
and move it in the :file:`${QP_ROOT}/external` directory
|
||||||
|
|
||||||
|
* Extract the archive, go into the :file:`libcap-*/libcap` directory and run
|
||||||
|
the following command
|
||||||
|
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
prefix=$QP_ROOT make install
|
||||||
|
|
||||||
|
With Debian or Ubuntu, you can use
|
||||||
|
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
sudo apt install libcap-dev
|
||||||
|
|
||||||
|
|
||||||
|
Bubblewrap
|
||||||
|
----------
|
||||||
|
|
||||||
|
Bubblewrap is an unprivileged sandboxing tool.
|
||||||
|
|
||||||
|
* Download Bubblewrap here:
|
||||||
|
`<https://github.com/projectatomic/bubblewrap/releases/download/v0.3.3/bubblewrap-0.3.3.tar.xz>`_
|
||||||
|
and move it in the :file:`${QP_ROOT}/external` directory
|
||||||
|
|
||||||
|
* Extract the archive, go into the :file:`bubblewrap-*` directory and run
|
||||||
|
the following commands
|
||||||
|
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
./configure --prefix=$QP_ROOT && make -j 8
|
||||||
|
make install-exec-am
|
||||||
|
|
||||||
|
|
||||||
|
With Debian or Ubuntu, you can use
|
||||||
|
|
||||||
|
.. code:: bash
|
||||||
|
|
||||||
|
sudo apt install bubblewrap
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
OCaml
|
OCaml
|
||||||
-----
|
-----
|
||||||
|
|
||||||
|
@ -1,12 +1,13 @@
|
|||||||
# Quantum Package 2.0
|
# Quantum Package 2.0
|
||||||
|
|
||||||
|
|
||||||
*Quantum package 2.0: an open-source determinant-driven suite of programs*\
|
[*Quantum package 2.0: an open-source determinant-driven suite of programs*](https://pubs.acs.org/doi/10.1021/acs.jctc.9b00176)\
|
||||||
Y. Garniron, K. Gasperich, T. Applencourt, A. Benali, A. Ferté, J. Paquier, B. Pradines, R. Assaraf, P. Reinhardt, J. Toulouse, P. Barbaresco, N. Renon, G. David, J. P. Malrieu, M. Véril, M. Caffarel, P. F. Loos, E. Giner and A. Scemama\
|
Y. Garniron, K. Gasperich, T. Applencourt, A. Benali, A. Ferté, J. Paquier, B. Pradines, R. Assaraf, P. Reinhardt, J. Toulouse, P. Barbaresco, N. Renon, G. David, J. P. Malrieu, M. Véril, M. Caffarel, P. F. Loos, E. Giner and A. Scemama\
|
||||||
|
J. Chem. Theory Comput. (2019)\
|
||||||
https://arxiv.org/abs/1902.08154
|
https://arxiv.org/abs/1902.08154
|
||||||
|
|
||||||
|
|
||||||
![QP](https://raw.githubusercontent.com/QuantumPackage/qp2/master/data/qp2.png)
|
<img src="https://raw.githubusercontent.com/QuantumPackage/qp2/master/data/qp2.png" width="250">
|
||||||
|
|
||||||
# Getting started
|
# Getting started
|
||||||
|
|
||||||
|
44
configure
vendored
44
configure
vendored
@ -175,7 +175,7 @@ if [[ "${PACKAGES}.x" != ".x" ]] ; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if [[ ${PACKAGES} = all ]] ; then
|
if [[ ${PACKAGES} = all ]] ; then
|
||||||
PACKAGES="zlib ninja irpf90 zeromq f77zmq gmp ocaml ezfio docopt resultsFile bats"
|
PACKAGES="zlib ninja irpf90 zeromq f77zmq gmp libcap bwrap ocaml ezfio docopt resultsFile bats"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
@ -206,6 +206,32 @@ EOF
|
|||||||
make install
|
make install
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
elif [[ ${PACKAGE} = libcap ]] ; then
|
||||||
|
|
||||||
|
download \
|
||||||
|
"https://git.kernel.org/pub/scm/linux/kernel/git/morgan/libcap.git/snapshot/libcap-2.25.tar.gz" \
|
||||||
|
"${QP_ROOT}"/external/libcap.tar.gz
|
||||||
|
execute << EOF
|
||||||
|
cd "\${QP_ROOT}"/external
|
||||||
|
tar --gunzip --extract --file libcap.tar.gz
|
||||||
|
rm libcap.tar.gz
|
||||||
|
cd libcap-*/libcap
|
||||||
|
prefix=$QP_ROOT make install
|
||||||
|
EOF
|
||||||
|
|
||||||
|
elif [[ ${PACKAGE} = bwrap ]] ; then
|
||||||
|
|
||||||
|
download \
|
||||||
|
"https://github.com/projectatomic/bubblewrap/releases/download/v0.3.3/bubblewrap-0.3.3.tar.xz" \
|
||||||
|
"${QP_ROOT}"/external/bwrap.tar.xz
|
||||||
|
execute << EOF
|
||||||
|
cd "\${QP_ROOT}"/external
|
||||||
|
tar --xz --extract --file bwrap.tar.xz
|
||||||
|
rm bwrap.tar.xz
|
||||||
|
cd bubblewrap*
|
||||||
|
./configure --prefix=$QP_ROOT && make -j 8
|
||||||
|
make install-exec-am
|
||||||
|
EOF
|
||||||
|
|
||||||
elif [[ ${PACKAGE} = irpf90 ]] ; then
|
elif [[ ${PACKAGE} = irpf90 ]] ; then
|
||||||
|
|
||||||
@ -276,7 +302,7 @@ EOF
|
|||||||
rm ${QP_ROOT}/external/opam_installer.sh
|
rm ${QP_ROOT}/external/opam_installer.sh
|
||||||
source ${OPAMROOT}/opam-init/init.sh > /dev/null 2> /dev/null || true
|
source ${OPAMROOT}/opam-init/init.sh > /dev/null 2> /dev/null || true
|
||||||
|
|
||||||
${QP_ROOT}/bin/opam init --disable-sandboxing --verbose --yes
|
${QP_ROOT}/bin/opam init --verbose --yes
|
||||||
|
|
||||||
eval $(${QP_ROOT}/bin/opam env)
|
eval $(${QP_ROOT}/bin/opam env)
|
||||||
opam install -y ${OCAML_PACKAGES} || exit 1
|
opam install -y ${OCAML_PACKAGES} || exit 1
|
||||||
@ -290,7 +316,7 @@ EOF
|
|||||||
| sh \${QP_ROOT}/external/opam_installer.sh
|
| sh \${QP_ROOT}/external/opam_installer.sh
|
||||||
rm \${QP_ROOT}/external/opam_installer.sh
|
rm \${QP_ROOT}/external/opam_installer.sh
|
||||||
source \${OPAMROOT}/opam-init/init.sh > /dev/null 2> /dev/null || true
|
source \${OPAMROOT}/opam-init/init.sh > /dev/null 2> /dev/null || true
|
||||||
\${QP_ROOT}/bin/opam init --disable-sandboxing --verbose --yes
|
\${QP_ROOT}/bin/opam init --verbose --yes
|
||||||
eval \$(\${QP_ROOT}/bin/opam env)
|
eval \$(\${QP_ROOT}/bin/opam env)
|
||||||
opam install -y \${OCAML_PACKAGES} || exit 1
|
opam install -y \${OCAML_PACKAGES} || exit 1
|
||||||
EOF
|
EOF
|
||||||
@ -399,6 +425,18 @@ if [[ ${ZLIB} = $(not_found) ]] ; then
|
|||||||
fail
|
fail
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
BWRAP=$(find_exe bwrap)
|
||||||
|
if [[ ${BWRAP} = $(not_found) ]] ; then
|
||||||
|
error "Bubblewrap (bwrap) is not installed."
|
||||||
|
fail
|
||||||
|
fi
|
||||||
|
|
||||||
|
LIBCAP=$(find_lib -lcap)
|
||||||
|
if [[ ${LIBCAP} = $(not_found) ]] ; then
|
||||||
|
error "Libcap (libcap) is not installed."
|
||||||
|
fail
|
||||||
|
fi
|
||||||
|
|
||||||
OPAM=$(find_exe opam)
|
OPAM=$(find_exe opam)
|
||||||
if [[ ${OPAM} = $(not_found) ]] ; then
|
if [[ ${OPAM} = $(not_found) ]] ; then
|
||||||
error "OPAM (ocaml) package manager is not installed."
|
error "OPAM (ocaml) package manager is not installed."
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
BORON
|
BORON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 11.76050 -0.0036757
|
1 11.76050 -0.0036757
|
||||||
2 5.150520 0.0250517
|
2 5.150520 0.0250517
|
||||||
3 2.578276 -0.1249228
|
3 2.578276 -0.1249228
|
||||||
@ -9,15 +9,15 @@ BORON
|
|||||||
7 0.161898 0.4308431
|
7 0.161898 0.4308431
|
||||||
8 0.081044 0.2486558
|
8 0.081044 0.2486558
|
||||||
9 0.040569 0.0317295
|
9 0.040569 0.0317295
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.614105 1.000000
|
1 0.614105 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.375720 1.000000
|
1 0.375720 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.170896 1.000000
|
1 0.170896 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.070664 1.000000
|
1 0.070664 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 7.470701 0.0047397
|
1 7.470701 0.0047397
|
||||||
2 3.735743 0.0376009
|
2 3.735743 0.0376009
|
||||||
3 1.868068 0.0510600
|
3 1.868068 0.0510600
|
||||||
@ -27,37 +27,37 @@ P 9 1.00
|
|||||||
7 0.116803 0.2850185
|
7 0.116803 0.2850185
|
||||||
8 0.058408 0.1448808
|
8 0.058408 0.1448808
|
||||||
9 0.029207 0.0176962
|
9 0.029207 0.0176962
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.566611 1.000000
|
1 0.566611 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.436327 1.000000
|
1 0.436327 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.143772 1.000000
|
1 0.143772 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.057917 1.000000
|
1 0.057917 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 1.022256 1.000000
|
1 1.022256 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.808233 1.000000
|
1 0.808233 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.380163 1.000000
|
1 0.380163 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.134838 1.000000
|
1 0.134838 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 1.002171 1.000000
|
1 1.002171 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.799174 1.000000
|
1 0.799174 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.272717 1.000000
|
1 0.272717 1.000000
|
||||||
G 1 1.00
|
G 1
|
||||||
1 0.824366 1.000000
|
1 0.824366 1.000000
|
||||||
G 1 1.00
|
G 1
|
||||||
1 0.486131 1.000000
|
1 0.486131 1.000000
|
||||||
H 1 1.00
|
H 1
|
||||||
1 0.632779 1.000000
|
1 0.632779 1.000000
|
||||||
|
|
||||||
CARBON
|
CARBON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 13.073594 0.0051583
|
1 13.073594 0.0051583
|
||||||
2 6.541187 0.0603424
|
2 6.541187 0.0603424
|
||||||
3 4.573411 -0.1978471
|
3 4.573411 -0.1978471
|
||||||
@ -67,15 +67,15 @@ CARBON
|
|||||||
7 0.231300 0.4336405
|
7 0.231300 0.4336405
|
||||||
8 0.102619 0.2131940
|
8 0.102619 0.2131940
|
||||||
9 0.051344 0.0049848
|
9 0.051344 0.0049848
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.098302 1.000000
|
1 0.098302 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.232034 1.000000
|
1 0.232034 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.744448 1.000000
|
1 0.744448 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 1.009914 1.000000
|
1 1.009914 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 9.934169 0.0209076
|
1 9.934169 0.0209076
|
||||||
2 3.886955 0.0572698
|
2 3.886955 0.0572698
|
||||||
3 1.871016 0.1122682
|
3 1.871016 0.1122682
|
||||||
@ -85,33 +85,33 @@ P 9 1.00
|
|||||||
7 0.117063 0.2016934
|
7 0.117063 0.2016934
|
||||||
8 0.058547 0.0453575
|
8 0.058547 0.0453575
|
||||||
9 0.029281 0.0029775
|
9 0.029281 0.0029775
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.084047 1.000000
|
1 0.084047 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.216618 1.000000
|
1 0.216618 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.576869 1.000000
|
1 0.576869 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 1.006252 1.000000
|
1 1.006252 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.206619 1.000000
|
1 0.206619 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.606933 1.000000
|
1 0.606933 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 1.001526 1.000000
|
1 1.001526 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 1.504882 1.000000
|
1 1.504882 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.400573 1.000000
|
1 0.400573 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 1.099564 1.000000
|
1 1.099564 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 1.501091 1.000000
|
1 1.501091 1.000000
|
||||||
G 1 1.00
|
G 1
|
||||||
1 0.797648 1.000000
|
1 0.797648 1.000000
|
||||||
G 1 1.00
|
G 1
|
||||||
1 1.401343 1.000000
|
1 1.401343 1.000000
|
||||||
H 1 1.00
|
H 1
|
||||||
1 1.001703 1.000000
|
1 1.001703 1.000000
|
||||||
|
|
||||||
NITROGEN
|
NITROGEN
|
||||||
@ -320,7 +320,7 @@ G 1
|
|||||||
H 1
|
H 1
|
||||||
1 0.249975 1.00000000
|
1 0.249975 1.00000000
|
||||||
|
|
||||||
MG
|
MAGNESIUM
|
||||||
S 12
|
S 12
|
||||||
1 63.931893 -0.00079400
|
1 63.931893 -0.00079400
|
||||||
2 31.602596 0.00747900
|
2 31.602596 0.00747900
|
||||||
@ -500,7 +500,7 @@ G 1
|
|||||||
H 1
|
H 1
|
||||||
1 0.441969 1.00000000
|
1 0.441969 1.00000000
|
||||||
|
|
||||||
SI
|
SILICON
|
||||||
S 12
|
S 12
|
||||||
1 96.651837 -0.00044000
|
1 96.651837 -0.00044000
|
||||||
2 48.652547 0.01867100
|
2 48.652547 0.01867100
|
||||||
@ -625,7 +625,7 @@ S 1
|
|||||||
1 0.216983 1.00000000
|
1 0.216983 1.00000000
|
||||||
S 1
|
S 1
|
||||||
1 0.094992 1.00000000
|
1 0.094992 1.00000000
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 0.01288400
|
1 48.154282 0.01288400
|
||||||
2 25.406431 0.09709500
|
2 25.406431 0.09709500
|
||||||
3 13.404555 0.17821500
|
3 13.404555 0.17821500
|
||||||
@ -638,7 +638,7 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 -0.00006600
|
10 0.152550 -0.00006600
|
||||||
11 0.080486 0.00012900
|
11 0.080486 0.00012900
|
||||||
12 0.042465 -0.00002900
|
12 0.042465 -0.00002900
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 -0.00315200
|
1 48.154282 -0.00315200
|
||||||
2 25.406431 -0.02300600
|
2 25.406431 -0.02300600
|
||||||
3 13.404555 -0.04239800
|
3 13.404555 -0.04239800
|
||||||
@ -651,13 +651,13 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 0.34480600
|
10 0.152550 0.34480600
|
||||||
11 0.080486 0.18173100
|
11 0.080486 0.18173100
|
||||||
12 0.042465 0.03664900
|
12 0.042465 0.03664900
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 2.103768 1.00000000
|
1 2.103768 1.00000000
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.988246 1.00000000
|
1 0.988246 1.00000000
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.464229 1.00000000
|
1 0.464229 1.00000000
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.218072 1.00000000
|
1 0.218072 1.00000000
|
||||||
D 1
|
D 1
|
||||||
1 2.461614 1.00000000
|
1 2.461614 1.00000000
|
||||||
@ -681,7 +681,7 @@ H 1
|
|||||||
1 0.737477 1.00000000
|
1 0.737477 1.00000000
|
||||||
|
|
||||||
SULFUR
|
SULFUR
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00006400
|
1 306.317903 0.00006400
|
||||||
2 146.602801 -0.00078500
|
2 146.602801 -0.00078500
|
||||||
3 70.163647 0.02247100
|
3 70.163647 0.02247100
|
||||||
@ -694,7 +694,7 @@ SULFUR
|
|||||||
10 0.403554 0.00443600
|
10 0.403554 0.00443600
|
||||||
11 0.193140 -0.00101500
|
11 0.193140 -0.00101500
|
||||||
12 0.092436 0.00050700
|
12 0.092436 0.00050700
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00002100
|
1 306.317903 0.00002100
|
||||||
2 146.602801 -0.00000400
|
2 146.602801 -0.00000400
|
||||||
3 70.163647 -0.00611900
|
3 70.163647 -0.00611900
|
||||||
@ -707,13 +707,13 @@ SULFUR 12
|
|||||||
10 0.403554 0.52928200
|
10 0.403554 0.52928200
|
||||||
11 0.193140 0.46625400
|
11 0.193140 0.46625400
|
||||||
12 0.092436 0.12580000
|
12 0.092436 0.12580000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 1.476765 1.00000000
|
1 1.476765 1.00000000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.646261 1.00000000
|
1 0.646261 1.00000000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.282816 1.00000000
|
1 0.282816 1.00000000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.123766 1.00000000
|
1 0.123766 1.00000000
|
||||||
P 12
|
P 12
|
||||||
1 55.148271 0.01344700
|
1 55.148271 0.01344700
|
||||||
@ -1206,7 +1206,7 @@ H 1
|
|||||||
I 1
|
I 1
|
||||||
1 2.384691 1.00000000
|
1 2.384691 1.00000000
|
||||||
|
|
||||||
TI
|
TITANIUM
|
||||||
S 13
|
S 13
|
||||||
1 68.910511 0.00061600
|
1 68.910511 0.00061600
|
||||||
2 33.720700 -0.00750100
|
2 33.720700 -0.00750100
|
||||||
@ -2742,7 +2742,7 @@ H 1
|
|||||||
I 1
|
I 1
|
||||||
1 3.729940 1.00000000
|
1 3.729940 1.00000000
|
||||||
|
|
||||||
NI
|
NICKEL
|
||||||
S 13
|
S 13
|
||||||
1 97.161835 0.00070900
|
1 97.161835 0.00070900
|
||||||
2 51.187866 -0.01239900
|
2 51.187866 -0.01239900
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
BORON
|
BORON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 11.76050 -0.0036757
|
1 11.76050 -0.0036757
|
||||||
2 5.150520 0.0250517
|
2 5.150520 0.0250517
|
||||||
3 2.578276 -0.1249228
|
3 2.578276 -0.1249228
|
||||||
@ -9,9 +9,9 @@ BORON
|
|||||||
7 0.161898 0.4308431
|
7 0.161898 0.4308431
|
||||||
8 0.081044 0.2486558
|
8 0.081044 0.2486558
|
||||||
9 0.040569 0.0317295
|
9 0.040569 0.0317295
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.082513 1.000000
|
1 0.082513 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 7.470701 0.0047397
|
1 7.470701 0.0047397
|
||||||
2 3.735743 0.0376009
|
2 3.735743 0.0376009
|
||||||
3 1.868068 0.0510600
|
3 1.868068 0.0510600
|
||||||
@ -21,13 +21,13 @@ P 9 1.00
|
|||||||
7 0.116803 0.2850185
|
7 0.116803 0.2850185
|
||||||
8 0.058408 0.1448808
|
8 0.058408 0.1448808
|
||||||
9 0.029207 0.0176962
|
9 0.029207 0.0176962
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.086803 1.000000
|
1 0.086803 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.349879 1.000000
|
1 0.349879 1.000000
|
||||||
|
|
||||||
CARBON
|
CARBON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 13.073594 0.0051583
|
1 13.073594 0.0051583
|
||||||
2 6.541187 0.0603424
|
2 6.541187 0.0603424
|
||||||
3 4.573411 -0.1978471
|
3 4.573411 -0.1978471
|
||||||
@ -37,9 +37,9 @@ CARBON
|
|||||||
7 0.231300 0.4336405
|
7 0.231300 0.4336405
|
||||||
8 0.102619 0.2131940
|
8 0.102619 0.2131940
|
||||||
9 0.051344 0.0049848
|
9 0.051344 0.0049848
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.127852 1.000000
|
1 0.127852 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 9.934169 0.0209076
|
1 9.934169 0.0209076
|
||||||
2 3.886955 0.0572698
|
2 3.886955 0.0572698
|
||||||
3 1.871016 0.1122682
|
3 1.871016 0.1122682
|
||||||
@ -49,9 +49,9 @@ P 9 1.00
|
|||||||
7 0.117063 0.2016934
|
7 0.117063 0.2016934
|
||||||
8 0.058547 0.0453575
|
8 0.058547 0.0453575
|
||||||
9 0.029281 0.0029775
|
9 0.029281 0.0029775
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.149161 1.000000
|
1 0.149161 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.561160 1.000000
|
1 0.561160 1.000000
|
||||||
|
|
||||||
NITROGEN
|
NITROGEN
|
||||||
@ -170,7 +170,7 @@ P 1
|
|||||||
D 1
|
D 1
|
||||||
1 0.093145 1.00000000
|
1 0.093145 1.00000000
|
||||||
|
|
||||||
MG
|
MAGNESIUM
|
||||||
S 12
|
S 12
|
||||||
1 63.931893 -0.00079400
|
1 63.931893 -0.00079400
|
||||||
2 31.602596 0.00747900
|
2 31.602596 0.00747900
|
||||||
@ -290,7 +290,7 @@ P 1
|
|||||||
D 1
|
D 1
|
||||||
1 0.189387 1.00000000
|
1 0.189387 1.00000000
|
||||||
|
|
||||||
SI
|
SILICON
|
||||||
S 12
|
S 12
|
||||||
1 96.651837 -0.00044000
|
1 96.651837 -0.00044000
|
||||||
2 48.652547 0.01867100
|
2 48.652547 0.01867100
|
||||||
@ -379,7 +379,7 @@ S 12
|
|||||||
12 0.072398 0.12409900
|
12 0.072398 0.12409900
|
||||||
S 1
|
S 1
|
||||||
1 0.111116 1.00000000
|
1 0.111116 1.00000000
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 0.01288400
|
1 48.154282 0.01288400
|
||||||
2 25.406431 0.09709500
|
2 25.406431 0.09709500
|
||||||
3 13.404555 0.17821500
|
3 13.404555 0.17821500
|
||||||
@ -392,7 +392,7 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 -0.00006600
|
10 0.152550 -0.00006600
|
||||||
11 0.080486 0.00012900
|
11 0.080486 0.00012900
|
||||||
12 0.042465 -0.00002900
|
12 0.042465 -0.00002900
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 -0.00315200
|
1 48.154282 -0.00315200
|
||||||
2 25.406431 -0.02300600
|
2 25.406431 -0.02300600
|
||||||
3 13.404555 -0.04239800
|
3 13.404555 -0.04239800
|
||||||
@ -405,13 +405,13 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 0.34480600
|
10 0.152550 0.34480600
|
||||||
11 0.080486 0.18173100
|
11 0.080486 0.18173100
|
||||||
12 0.042465 0.03664900
|
12 0.042465 0.03664900
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.110006 1.00000000
|
1 0.110006 1.00000000
|
||||||
D 1
|
D 1
|
||||||
1 0.373518 1.00000000
|
1 0.373518 1.00000000
|
||||||
|
|
||||||
SULFUR
|
SULFUR
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00006400
|
1 306.317903 0.00006400
|
||||||
2 146.602801 -0.00078500
|
2 146.602801 -0.00078500
|
||||||
3 70.163647 0.02247100
|
3 70.163647 0.02247100
|
||||||
@ -424,7 +424,7 @@ SULFUR
|
|||||||
10 0.403554 0.00443600
|
10 0.403554 0.00443600
|
||||||
11 0.193140 -0.00101500
|
11 0.193140 -0.00101500
|
||||||
12 0.092436 0.00050700
|
12 0.092436 0.00050700
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00002100
|
1 306.317903 0.00002100
|
||||||
2 146.602801 -0.00000400
|
2 146.602801 -0.00000400
|
||||||
3 70.163647 -0.00611900
|
3 70.163647 -0.00611900
|
||||||
@ -437,7 +437,7 @@ SULFUR 12
|
|||||||
10 0.403554 0.52928200
|
10 0.403554 0.52928200
|
||||||
11 0.193140 0.46625400
|
11 0.193140 0.46625400
|
||||||
12 0.092436 0.12580000
|
12 0.092436 0.12580000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.138193 1.00000000
|
1 0.138193 1.00000000
|
||||||
P 12
|
P 12
|
||||||
1 55.148271 0.01344700
|
1 55.148271 0.01344700
|
||||||
@ -708,7 +708,7 @@ D 1
|
|||||||
F 1
|
F 1
|
||||||
1 0.280673 1.00000000
|
1 0.280673 1.00000000
|
||||||
|
|
||||||
TI
|
TITANIUM
|
||||||
S 13
|
S 13
|
||||||
1 68.910511 0.00061600
|
1 68.910511 0.00061600
|
||||||
2 33.720700 -0.00750100
|
2 33.720700 -0.00750100
|
||||||
@ -1770,3 +1770,4 @@ D 1
|
|||||||
F 1
|
F 1
|
||||||
1 3.171936 1.00000000
|
1 3.171936 1.00000000
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
BORON
|
BORON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 11.76050 -0.0036757
|
1 11.76050 -0.0036757
|
||||||
2 5.150520 0.0250517
|
2 5.150520 0.0250517
|
||||||
3 2.578276 -0.1249228
|
3 2.578276 -0.1249228
|
||||||
@ -9,13 +9,13 @@ BORON
|
|||||||
7 0.161898 0.4308431
|
7 0.161898 0.4308431
|
||||||
8 0.081044 0.2486558
|
8 0.081044 0.2486558
|
||||||
9 0.040569 0.0317295
|
9 0.040569 0.0317295
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.422217 1.000000
|
1 0.422217 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.305133 1.000000
|
1 0.305133 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.082968 1.000000
|
1 0.082968 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 7.470701 0.0047397
|
1 7.470701 0.0047397
|
||||||
2 3.735743 0.0376009
|
2 3.735743 0.0376009
|
||||||
3 1.868068 0.0510600
|
3 1.868068 0.0510600
|
||||||
@ -25,27 +25,27 @@ P 9 1.00
|
|||||||
7 0.116803 0.2850185
|
7 0.116803 0.2850185
|
||||||
8 0.058408 0.1448808
|
8 0.058408 0.1448808
|
||||||
9 0.029207 0.0176962
|
9 0.029207 0.0176962
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.447031 1.000000
|
1 0.447031 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.196614 1.000000
|
1 0.196614 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.066445 1.000000
|
1 0.066445 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 1.142614 1.000000
|
1 1.142614 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.410733 1.000000
|
1 0.410733 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.149100 1.000000
|
1 0.149100 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.870011 1.000000
|
1 0.870011 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.315902 1.000000
|
1 0.315902 1.000000
|
||||||
G 1 1.00
|
G 1
|
||||||
1 0.710746 1.000000
|
1 0.710746 1.000000
|
||||||
|
|
||||||
CARBON
|
CARBON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 13.073594 0.0051583
|
1 13.073594 0.0051583
|
||||||
2 6.541187 0.0603424
|
2 6.541187 0.0603424
|
||||||
3 4.573411 -0.1978471
|
3 4.573411 -0.1978471
|
||||||
@ -55,13 +55,13 @@ CARBON
|
|||||||
7 0.231300 0.4336405
|
7 0.231300 0.4336405
|
||||||
8 0.102619 0.2131940
|
8 0.102619 0.2131940
|
||||||
9 0.051344 0.0049848
|
9 0.051344 0.0049848
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.846879 1.000000
|
1 0.846879 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.269659 1.000000
|
1 0.269659 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.109576 1.000000
|
1 0.109576 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 9.934169 0.0209076
|
1 9.934169 0.0209076
|
||||||
2 3.886955 0.0572698
|
2 3.886955 0.0572698
|
||||||
3 1.871016 0.1122682
|
3 1.871016 0.1122682
|
||||||
@ -71,23 +71,23 @@ P 9 1.00
|
|||||||
7 0.117063 0.2016934
|
7 0.117063 0.2016934
|
||||||
8 0.058547 0.0453575
|
8 0.058547 0.0453575
|
||||||
9 0.029281 0.0029775
|
9 0.029281 0.0029775
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.804681 1.000000
|
1 0.804681 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.313254 1.000000
|
1 0.313254 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.105389 1.000000
|
1 0.105389 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 2.013760 1.000000
|
1 2.013760 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.684884 1.000000
|
1 0.684884 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.240171 1.000000
|
1 0.240171 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.457302 1.000000
|
1 0.457302 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 1.324930 1.000000
|
1 1.324930 1.000000
|
||||||
G 1 1.00
|
G 1
|
||||||
1 1.034180 1.000000
|
1 1.034180 1.000000
|
||||||
|
|
||||||
NITROGEN
|
NITROGEN
|
||||||
@ -260,7 +260,7 @@ F 1
|
|||||||
G 1
|
G 1
|
||||||
1 0.169674 1.00000000
|
1 0.169674 1.00000000
|
||||||
|
|
||||||
MG
|
MAGNESIUM
|
||||||
S 12
|
S 12
|
||||||
1 63.931893 -0.00079400
|
1 63.931893 -0.00079400
|
||||||
2 31.602596 0.00747900
|
2 31.602596 0.00747900
|
||||||
@ -416,7 +416,7 @@ F 1
|
|||||||
G 1
|
G 1
|
||||||
1 0.352315 1.00000000
|
1 0.352315 1.00000000
|
||||||
|
|
||||||
SI
|
SILICON
|
||||||
S 12
|
S 12
|
||||||
1 96.651837 -0.00044000
|
1 96.651837 -0.00044000
|
||||||
2 48.652547 0.01867100
|
2 48.652547 0.01867100
|
||||||
@ -527,7 +527,7 @@ S 1
|
|||||||
1 0.276109 1.00000000
|
1 0.276109 1.00000000
|
||||||
S 1
|
S 1
|
||||||
1 0.110986 1.00000000
|
1 0.110986 1.00000000
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 0.01288400
|
1 48.154282 0.01288400
|
||||||
2 25.406431 0.09709500
|
2 25.406431 0.09709500
|
||||||
3 13.404555 0.17821500
|
3 13.404555 0.17821500
|
||||||
@ -540,7 +540,7 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 -0.00006600
|
10 0.152550 -0.00006600
|
||||||
11 0.080486 0.00012900
|
11 0.080486 0.00012900
|
||||||
12 0.042465 -0.00002900
|
12 0.042465 -0.00002900
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 -0.00315200
|
1 48.154282 -0.00315200
|
||||||
2 25.406431 -0.02300600
|
2 25.406431 -0.02300600
|
||||||
3 13.404555 -0.04239800
|
3 13.404555 -0.04239800
|
||||||
@ -553,11 +553,11 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 0.34480600
|
10 0.152550 0.34480600
|
||||||
11 0.080486 0.18173100
|
11 0.080486 0.18173100
|
||||||
12 0.042465 0.03664900
|
12 0.042465 0.03664900
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 1.581855 1.00000000
|
1 1.581855 1.00000000
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.658132 1.00000000
|
1 0.658132 1.00000000
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.273816 1.00000000
|
1 0.273816 1.00000000
|
||||||
D 1
|
D 1
|
||||||
1 0.984476 1.00000000
|
1 0.984476 1.00000000
|
||||||
@ -573,7 +573,7 @@ G 1
|
|||||||
1 0.589583 1.00000000
|
1 0.589583 1.00000000
|
||||||
|
|
||||||
SULFUR
|
SULFUR
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00006400
|
1 306.317903 0.00006400
|
||||||
2 146.602801 -0.00078500
|
2 146.602801 -0.00078500
|
||||||
3 70.163647 0.02247100
|
3 70.163647 0.02247100
|
||||||
@ -586,7 +586,7 @@ SULFUR
|
|||||||
10 0.403554 0.00443600
|
10 0.403554 0.00443600
|
||||||
11 0.193140 -0.00101500
|
11 0.193140 -0.00101500
|
||||||
12 0.092436 0.00050700
|
12 0.092436 0.00050700
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00002100
|
1 306.317903 0.00002100
|
||||||
2 146.602801 -0.00000400
|
2 146.602801 -0.00000400
|
||||||
3 70.163647 -0.00611900
|
3 70.163647 -0.00611900
|
||||||
@ -599,11 +599,11 @@ SULFUR 12
|
|||||||
10 0.403554 0.52928200
|
10 0.403554 0.52928200
|
||||||
11 0.193140 0.46625400
|
11 0.193140 0.46625400
|
||||||
12 0.092436 0.12580000
|
12 0.092436 0.12580000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.893039 1.00000000
|
1 0.893039 1.00000000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.358094 1.00000000
|
1 0.358094 1.00000000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.143590 1.00000000
|
1 0.143590 1.00000000
|
||||||
P 12
|
P 12
|
||||||
1 55.148271 0.01344700
|
1 55.148271 0.01344700
|
||||||
@ -1014,7 +1014,7 @@ G 1
|
|||||||
H 1
|
H 1
|
||||||
1 3.057835 1.00000000
|
1 3.057835 1.00000000
|
||||||
|
|
||||||
TI
|
TITANIUM
|
||||||
S 13
|
S 13
|
||||||
1 68.910511 0.00061600
|
1 68.910511 0.00061600
|
||||||
2 33.720700 -0.00750100
|
2 33.720700 -0.00750100
|
||||||
@ -2262,7 +2262,7 @@ G 1
|
|||||||
H 1
|
H 1
|
||||||
1 2.901601 1.00000000
|
1 2.901601 1.00000000
|
||||||
|
|
||||||
NI
|
NICKEL
|
||||||
S 13
|
S 13
|
||||||
1 97.161835 0.00070900
|
1 97.161835 0.00070900
|
||||||
2 51.187866 -0.01239900
|
2 51.187866 -0.01239900
|
||||||
@ -2886,3 +2886,4 @@ G 1
|
|||||||
H 1
|
H 1
|
||||||
1 4.405055 1.00000000
|
1 4.405055 1.00000000
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
BORON
|
BORON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 11.76050 -0.0036757
|
1 11.76050 -0.0036757
|
||||||
2 5.150520 0.0250517
|
2 5.150520 0.0250517
|
||||||
3 2.578276 -0.1249228
|
3 2.578276 -0.1249228
|
||||||
@ -9,11 +9,11 @@ BORON
|
|||||||
7 0.161898 0.4308431
|
7 0.161898 0.4308431
|
||||||
8 0.081044 0.2486558
|
8 0.081044 0.2486558
|
||||||
9 0.040569 0.0317295
|
9 0.040569 0.0317295
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.626026 1.000000
|
1 0.626026 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.092094 1.000000
|
1 0.092094 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 7.470701 0.0047397
|
1 7.470701 0.0047397
|
||||||
2 3.735743 0.0376009
|
2 3.735743 0.0376009
|
||||||
3 1.868068 0.0510600
|
3 1.868068 0.0510600
|
||||||
@ -23,19 +23,19 @@ P 9 1.00
|
|||||||
7 0.116803 0.2850185
|
7 0.116803 0.2850185
|
||||||
8 0.058408 0.1448808
|
8 0.058408 0.1448808
|
||||||
9 0.029207 0.0176962
|
9 0.029207 0.0176962
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.235016 1.000000
|
1 0.235016 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.082056 1.000000
|
1 0.082056 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.699153 1.000000
|
1 0.699153 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.207316 1.000000
|
1 0.207316 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.478872 1.000000
|
1 0.478872 1.000000
|
||||||
|
|
||||||
CARBON
|
CARBON
|
||||||
S 9 1.00
|
S 9
|
||||||
1 13.073594 0.0051583
|
1 13.073594 0.0051583
|
||||||
2 6.541187 0.0603424
|
2 6.541187 0.0603424
|
||||||
3 4.573411 -0.1978471
|
3 4.573411 -0.1978471
|
||||||
@ -45,11 +45,11 @@ CARBON
|
|||||||
7 0.231300 0.4336405
|
7 0.231300 0.4336405
|
||||||
8 0.102619 0.2131940
|
8 0.102619 0.2131940
|
||||||
9 0.051344 0.0049848
|
9 0.051344 0.0049848
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.921552 1.000000
|
1 0.921552 1.000000
|
||||||
S 1 1.00
|
S 1
|
||||||
1 0.132800 1.000000
|
1 0.132800 1.000000
|
||||||
P 9 1.00
|
P 9
|
||||||
1 9.934169 0.0209076
|
1 9.934169 0.0209076
|
||||||
2 3.886955 0.0572698
|
2 3.886955 0.0572698
|
||||||
3 1.871016 0.1122682
|
3 1.871016 0.1122682
|
||||||
@ -59,15 +59,15 @@ P 9 1.00
|
|||||||
7 0.117063 0.2016934
|
7 0.117063 0.2016934
|
||||||
8 0.058547 0.0453575
|
8 0.058547 0.0453575
|
||||||
9 0.029281 0.0029775
|
9 0.029281 0.0029775
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.376742 1.000000
|
1 0.376742 1.000000
|
||||||
P 1 1.00
|
P 1
|
||||||
1 0.126772 1.000000
|
1 0.126772 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 1.141611 1.000000
|
1 1.141611 1.000000
|
||||||
D 1 1.00
|
D 1
|
||||||
1 0.329486 1.000000
|
1 0.329486 1.000000
|
||||||
F 1 1.00
|
F 1
|
||||||
1 0.773485 1.000000
|
1 0.773485 1.000000
|
||||||
|
|
||||||
NITROGEN
|
NITROGEN
|
||||||
@ -210,7 +210,7 @@ D 1
|
|||||||
F 1
|
F 1
|
||||||
1 0.134692 1.00000000
|
1 0.134692 1.00000000
|
||||||
|
|
||||||
MG
|
MAGNESIUM
|
||||||
S 12
|
S 12
|
||||||
1 63.931893 -0.00079400
|
1 63.931893 -0.00079400
|
||||||
2 31.602596 0.00747900
|
2 31.602596 0.00747900
|
||||||
@ -346,7 +346,7 @@ D 1
|
|||||||
F 1
|
F 1
|
||||||
1 0.254342 1.00000000
|
1 0.254342 1.00000000
|
||||||
|
|
||||||
SI
|
SILICON
|
||||||
S 12
|
S 12
|
||||||
1 96.651837 -0.00044000
|
1 96.651837 -0.00044000
|
||||||
2 48.652547 0.01867100
|
2 48.652547 0.01867100
|
||||||
@ -445,7 +445,7 @@ S 1
|
|||||||
1 0.115599 1.00000000
|
1 0.115599 1.00000000
|
||||||
S 1
|
S 1
|
||||||
1 0.725938 1.00000000
|
1 0.725938 1.00000000
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 0.01288400
|
1 48.154282 0.01288400
|
||||||
2 25.406431 0.09709500
|
2 25.406431 0.09709500
|
||||||
3 13.404555 0.17821500
|
3 13.404555 0.17821500
|
||||||
@ -458,7 +458,7 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 -0.00006600
|
10 0.152550 -0.00006600
|
||||||
11 0.080486 0.00012900
|
11 0.080486 0.00012900
|
||||||
12 0.042465 -0.00002900
|
12 0.042465 -0.00002900
|
||||||
PHOSPHORUS 12
|
P 12
|
||||||
1 48.154282 -0.00315200
|
1 48.154282 -0.00315200
|
||||||
2 25.406431 -0.02300600
|
2 25.406431 -0.02300600
|
||||||
3 13.404555 -0.04239800
|
3 13.404555 -0.04239800
|
||||||
@ -471,9 +471,9 @@ PHOSPHORUS 12
|
|||||||
10 0.152550 0.34480600
|
10 0.152550 0.34480600
|
||||||
11 0.080486 0.18173100
|
11 0.080486 0.18173100
|
||||||
12 0.042465 0.03664900
|
12 0.042465 0.03664900
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.093233 1.00000000
|
1 0.093233 1.00000000
|
||||||
PHOSPHORUS 1
|
P 1
|
||||||
1 0.625438 1.00000000
|
1 0.625438 1.00000000
|
||||||
D 1
|
D 1
|
||||||
1 0.214392 1.00000000
|
1 0.214392 1.00000000
|
||||||
@ -483,7 +483,7 @@ F 1
|
|||||||
1 0.457026 1.00000000
|
1 0.457026 1.00000000
|
||||||
|
|
||||||
SULFUR
|
SULFUR
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00006400
|
1 306.317903 0.00006400
|
||||||
2 146.602801 -0.00078500
|
2 146.602801 -0.00078500
|
||||||
3 70.163647 0.02247100
|
3 70.163647 0.02247100
|
||||||
@ -496,7 +496,7 @@ SULFUR
|
|||||||
10 0.403554 0.00443600
|
10 0.403554 0.00443600
|
||||||
11 0.193140 -0.00101500
|
11 0.193140 -0.00101500
|
||||||
12 0.092436 0.00050700
|
12 0.092436 0.00050700
|
||||||
SULFUR 12
|
S 12
|
||||||
1 306.317903 0.00002100
|
1 306.317903 0.00002100
|
||||||
2 146.602801 -0.00000400
|
2 146.602801 -0.00000400
|
||||||
3 70.163647 -0.00611900
|
3 70.163647 -0.00611900
|
||||||
@ -509,9 +509,9 @@ SULFUR 12
|
|||||||
10 0.403554 0.52928200
|
10 0.403554 0.52928200
|
||||||
11 0.193140 0.46625400
|
11 0.193140 0.46625400
|
||||||
12 0.092436 0.12580000
|
12 0.092436 0.12580000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.898845 1.00000000
|
1 0.898845 1.00000000
|
||||||
SULFUR 1
|
S 1
|
||||||
1 0.146364 1.00000000
|
1 0.146364 1.00000000
|
||||||
P 12
|
P 12
|
||||||
1 55.148271 0.01344700
|
1 55.148271 0.01344700
|
||||||
@ -848,7 +848,7 @@ F 1
|
|||||||
G 1
|
G 1
|
||||||
1 0.413265 1.00000000
|
1 0.413265 1.00000000
|
||||||
|
|
||||||
TI
|
TITANIUM
|
||||||
S 13
|
S 13
|
||||||
1 68.910511 0.00061600
|
1 68.910511 0.00061600
|
||||||
2 33.720700 -0.00750100
|
2 33.720700 -0.00750100
|
||||||
@ -1820,7 +1820,7 @@ F 1
|
|||||||
G 1
|
G 1
|
||||||
1 2.525364 1.00000000
|
1 2.525364 1.00000000
|
||||||
|
|
||||||
NI
|
NICKEL
|
||||||
S 13
|
S 13
|
||||||
1 97.161835 0.00070900
|
1 97.161835 0.00070900
|
||||||
2 51.187866 -0.01239900
|
2 51.187866 -0.01239900
|
||||||
@ -2306,3 +2306,4 @@ F 1
|
|||||||
G 1
|
G 1
|
||||||
1 4.099533 1.00000000
|
1 4.099533 1.00000000
|
||||||
|
|
||||||
|
|
||||||
|
@ -81,9 +81,6 @@ end = struct
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
let write_n_det n =
|
let write_n_det n =
|
||||||
let n_det_old =
|
|
||||||
Ezfio.get_determinants_n_det ()
|
|
||||||
in
|
|
||||||
Det_number.to_int n
|
Det_number.to_int n
|
||||||
|> Ezfio.set_determinants_n_det
|
|> Ezfio.set_determinants_n_det
|
||||||
;;
|
;;
|
||||||
|
@ -5,7 +5,7 @@ subroutine run_cipsi
|
|||||||
! stochastic PT2.
|
! stochastic PT2.
|
||||||
END_DOC
|
END_DOC
|
||||||
integer :: i,j,k
|
integer :: i,j,k
|
||||||
double precision, allocatable :: pt2(:), variance(:), norm(:), rpt2(:)
|
double precision, allocatable :: pt2(:), variance(:), norm(:), rpt2(:), zeros(:)
|
||||||
integer :: n_det_before, to_select
|
integer :: n_det_before, to_select
|
||||||
|
|
||||||
double precision :: rss
|
double precision :: rss
|
||||||
@ -13,7 +13,7 @@ subroutine run_cipsi
|
|||||||
rss = memory_of_double(N_states)*4.d0
|
rss = memory_of_double(N_states)*4.d0
|
||||||
call check_mem(rss,irp_here)
|
call check_mem(rss,irp_here)
|
||||||
|
|
||||||
allocate (pt2(N_states), rpt2(N_states), norm(N_states), variance(N_states))
|
allocate (pt2(N_states), zeros(N_states), rpt2(N_states), norm(N_states), variance(N_states))
|
||||||
|
|
||||||
double precision :: hf_energy_ref
|
double precision :: hf_energy_ref
|
||||||
logical :: has
|
logical :: has
|
||||||
@ -23,10 +23,11 @@ subroutine run_cipsi
|
|||||||
|
|
||||||
relative_error=PT2_relative_error
|
relative_error=PT2_relative_error
|
||||||
|
|
||||||
|
zeros = 0.d0
|
||||||
pt2 = -huge(1.e0)
|
pt2 = -huge(1.e0)
|
||||||
rpt2 = -huge(1.e0)
|
rpt2 = -huge(1.e0)
|
||||||
norm = 0.d0
|
norm = 0.d0
|
||||||
variance = 0.d0
|
variance = huge(1.e0)
|
||||||
|
|
||||||
if (s2_eig) then
|
if (s2_eig) then
|
||||||
call make_s2_eigenfunction
|
call make_s2_eigenfunction
|
||||||
@ -65,7 +66,8 @@ subroutine run_cipsi
|
|||||||
|
|
||||||
do while ( &
|
do while ( &
|
||||||
(N_det < N_det_max) .and. &
|
(N_det < N_det_max) .and. &
|
||||||
(maxval(abs(pt2(1:N_states))) > pt2_max) .and. &
|
(maxval(abs(rpt2(1:N_states))) > pt2_max) .and. &
|
||||||
|
(maxval(variance(1:N_states)) > variance_max) .and. &
|
||||||
(correlation_energy_ratio <= correlation_energy_ratio_max) &
|
(correlation_energy_ratio <= correlation_energy_ratio_max) &
|
||||||
)
|
)
|
||||||
write(*,'(A)') '--------------------------------------------------------------------------------'
|
write(*,'(A)') '--------------------------------------------------------------------------------'
|
||||||
@ -83,17 +85,17 @@ subroutine run_cipsi
|
|||||||
SOFT_TOUCH threshold_generators
|
SOFT_TOUCH threshold_generators
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
do k=1,N_states
|
||||||
|
rpt2(k) = pt2(k)/(1.d0 + norm(k))
|
||||||
|
enddo
|
||||||
|
|
||||||
correlation_energy_ratio = (psi_energy_with_nucl_rep(1) - hf_energy_ref) / &
|
correlation_energy_ratio = (psi_energy_with_nucl_rep(1) - hf_energy_ref) / &
|
||||||
(psi_energy_with_nucl_rep(1) + pt2(1) - hf_energy_ref)
|
(psi_energy_with_nucl_rep(1) + rpt2(1) - hf_energy_ref)
|
||||||
correlation_energy_ratio = min(1.d0,correlation_energy_ratio)
|
correlation_energy_ratio = min(1.d0,correlation_energy_ratio)
|
||||||
|
|
||||||
call write_double(6,correlation_energy_ratio, 'Correlation ratio')
|
call write_double(6,correlation_energy_ratio, 'Correlation ratio')
|
||||||
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
||||||
|
|
||||||
do k=1,N_states
|
|
||||||
rpt2(:) = pt2(:)/(1.d0 + norm(k))
|
|
||||||
enddo
|
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
||||||
|
|
||||||
call save_iterations(psi_energy_with_nucl_rep(1:N_states),rpt2,N_det)
|
call save_iterations(psi_energy_with_nucl_rep(1:N_states),rpt2,N_det)
|
||||||
@ -103,9 +105,8 @@ subroutine run_cipsi
|
|||||||
if (qp_stop()) exit
|
if (qp_stop()) exit
|
||||||
|
|
||||||
n_det_before = N_det
|
n_det_before = N_det
|
||||||
to_select = N_det
|
to_select = int(sqrt(dble(N_states))*dble(N_det)*selection_factor)
|
||||||
to_select = max(N_states_diag, to_select)
|
to_select = max(N_states_diag, to_select)
|
||||||
! to_select = min(to_select, N_det_max-n_det_before)
|
|
||||||
call ZMQ_selection(to_select, pt2, variance, norm)
|
call ZMQ_selection(to_select, pt2, variance, norm)
|
||||||
|
|
||||||
PROVIDE psi_coef
|
PROVIDE psi_coef
|
||||||
@ -114,32 +115,30 @@ subroutine run_cipsi
|
|||||||
|
|
||||||
call diagonalize_CI
|
call diagonalize_CI
|
||||||
call save_wavefunction
|
call save_wavefunction
|
||||||
rpt2(:) = 0.d0
|
call save_energy(psi_energy_with_nucl_rep, zeros)
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
|
||||||
if (qp_stop()) exit
|
if (qp_stop()) exit
|
||||||
|
print *, (N_det < N_det_max)
|
||||||
|
print *, (maxval(abs(rpt2(1:N_states))) > pt2_max)
|
||||||
|
print *, (maxval(variance(1:N_states)) > variance_max)
|
||||||
|
print *, (correlation_energy_ratio <= correlation_energy_ratio_max)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
if (.not.qp_stop()) then
|
if (.not.qp_stop()) then
|
||||||
if (N_det < N_det_max) then
|
if (N_det < N_det_max) then
|
||||||
call diagonalize_CI
|
call diagonalize_CI
|
||||||
call save_wavefunction
|
call save_wavefunction
|
||||||
rpt2(:) = 0.d0
|
call save_energy(psi_energy_with_nucl_rep, zeros)
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if (do_pt2) then
|
if (do_pt2) then
|
||||||
pt2 = 0.d0
|
pt2(:) = 0.d0
|
||||||
variance = 0.d0
|
variance(:) = 0.d0
|
||||||
norm = 0.d0
|
norm(:) = 0.d0
|
||||||
threshold_generators = 1d0
|
threshold_generators = 1d0
|
||||||
SOFT_TOUCH threshold_generators
|
SOFT_TOUCH threshold_generators
|
||||||
call ZMQ_pt2(psi_energy_with_nucl_rep, pt2,relative_error,error,variance, &
|
call ZMQ_pt2(psi_energy_with_nucl_rep, pt2,relative_error,error,variance, &
|
||||||
norm,0) ! Stochastic PT2
|
norm,0) ! Stochastic PT2
|
||||||
SOFT_TOUCH threshold_generators
|
SOFT_TOUCH threshold_generators
|
||||||
do k=1,N_states
|
|
||||||
rpt2(:) = pt2(:)/(1.d0 + norm(k))
|
|
||||||
enddo
|
|
||||||
call save_energy(psi_energy_with_nucl_rep, pt2)
|
|
||||||
endif
|
endif
|
||||||
print *, 'N_det = ', N_det
|
print *, 'N_det = ', N_det
|
||||||
print *, 'N_sop = ', N_occ_pattern
|
print *, 'N_sop = ', N_occ_pattern
|
||||||
@ -148,12 +147,11 @@ subroutine run_cipsi
|
|||||||
|
|
||||||
|
|
||||||
do k=1,N_states
|
do k=1,N_states
|
||||||
rpt2(:) = pt2(:)/(1.d0 + norm(k))
|
rpt2(k) = pt2(k)/(1.d0 + norm(k))
|
||||||
enddo
|
enddo
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
|
||||||
|
|
||||||
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
||||||
call save_energy(psi_energy_with_nucl_rep, pt2)
|
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
||||||
call save_iterations(psi_energy_with_nucl_rep(1:N_states),rpt2,N_det)
|
call save_iterations(psi_energy_with_nucl_rep(1:N_states),rpt2,N_det)
|
||||||
call print_extrapolated_energy()
|
call print_extrapolated_energy()
|
||||||
endif
|
endif
|
||||||
|
@ -129,13 +129,13 @@ subroutine ZMQ_pt2(E, pt2,relative_error, error, variance, norm, N_in)
|
|||||||
PROVIDE psi_bilinear_matrix_rows psi_det_sorted_order psi_bilinear_matrix_order
|
PROVIDE psi_bilinear_matrix_rows psi_det_sorted_order psi_bilinear_matrix_order
|
||||||
PROVIDE psi_bilinear_matrix_transp_rows_loc psi_bilinear_matrix_transp_columns
|
PROVIDE psi_bilinear_matrix_transp_rows_loc psi_bilinear_matrix_transp_columns
|
||||||
PROVIDE psi_bilinear_matrix_transp_order psi_selectors_coef_transp psi_det_sorted
|
PROVIDE psi_bilinear_matrix_transp_order psi_selectors_coef_transp psi_det_sorted
|
||||||
PROVIDE psi_det_hii N_generators_bitmask
|
PROVIDE psi_det_hii N_generators_bitmask selection_weight pseudo_sym
|
||||||
|
|
||||||
if (h0_type == 'SOP') then
|
if (h0_type == 'SOP') then
|
||||||
PROVIDE psi_occ_pattern_hii det_to_occ_pattern
|
PROVIDE psi_occ_pattern_hii det_to_occ_pattern
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if (N_det < max(1000,N_states)) then
|
if (N_det < max(4,N_states)) then
|
||||||
pt2=0.d0
|
pt2=0.d0
|
||||||
variance=0.d0
|
variance=0.d0
|
||||||
norm=0.d0
|
norm=0.d0
|
||||||
@ -182,6 +182,9 @@ subroutine ZMQ_pt2(E, pt2,relative_error, error, variance, norm, N_in)
|
|||||||
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'state_average_weight',state_average_weight,N_states) == -1) then
|
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'state_average_weight',state_average_weight,N_states) == -1) then
|
||||||
stop 'Unable to put state_average_weight on ZMQ server'
|
stop 'Unable to put state_average_weight on ZMQ server'
|
||||||
endif
|
endif
|
||||||
|
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'selection_weight',selection_weight,N_states) == -1) then
|
||||||
|
stop 'Unable to put selection_weight on ZMQ server'
|
||||||
|
endif
|
||||||
if (zmq_put_ivector(zmq_to_qp_run_socket,1,'pt2_stoch_istate',pt2_stoch_istate,1) == -1) then
|
if (zmq_put_ivector(zmq_to_qp_run_socket,1,'pt2_stoch_istate',pt2_stoch_istate,1) == -1) then
|
||||||
stop 'Unable to put pt2_stoch_istate on ZMQ server'
|
stop 'Unable to put pt2_stoch_istate on ZMQ server'
|
||||||
endif
|
endif
|
||||||
@ -333,13 +336,7 @@ subroutine ZMQ_pt2(E, pt2,relative_error, error, variance, norm, N_in)
|
|||||||
pt2(k) = 0.d0
|
pt2(k) = 0.d0
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
! Adjust PT2 weights for next selection
|
call update_pt2_and_variance_weights(pt2, variance, norm, N_states)
|
||||||
double precision :: pt2_avg
|
|
||||||
pt2_avg = sum(pt2) / dble(N_states)
|
|
||||||
do k=1,N_states
|
|
||||||
pt2_match_weight(k) *= (pt2(k)/pt2_avg)**2
|
|
||||||
enddo
|
|
||||||
SOFT_TOUCH pt2_match_weight
|
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
@ -25,8 +25,8 @@ subroutine run_selection_slave(thread,iproc,energy)
|
|||||||
PROVIDE psi_bilinear_matrix_columns_loc psi_det_alpha_unique psi_det_beta_unique
|
PROVIDE psi_bilinear_matrix_columns_loc psi_det_alpha_unique psi_det_beta_unique
|
||||||
PROVIDE psi_bilinear_matrix_rows psi_det_sorted_order psi_bilinear_matrix_order
|
PROVIDE psi_bilinear_matrix_rows psi_det_sorted_order psi_bilinear_matrix_order
|
||||||
PROVIDE psi_bilinear_matrix_transp_rows_loc psi_bilinear_matrix_transp_columns
|
PROVIDE psi_bilinear_matrix_transp_rows_loc psi_bilinear_matrix_transp_columns
|
||||||
PROVIDE psi_bilinear_matrix_transp_order N_int pt2_F
|
PROVIDE psi_bilinear_matrix_transp_order N_int pt2_F pseudo_sym
|
||||||
PROVIDE psi_selectors_coef_transp psi_det_sorted
|
PROVIDE psi_selectors_coef_transp psi_det_sorted weight_selection
|
||||||
|
|
||||||
|
|
||||||
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
|
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
|
||||||
@ -230,6 +230,8 @@ subroutine pull_selection_results(zmq_socket_pull, pt2, variance, norm, val, det
|
|||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
pt2(:) = 0.d0
|
pt2(:) = 0.d0
|
||||||
|
variance(:) = 0.d0
|
||||||
|
norm(:) = 0.d0
|
||||||
endif
|
endif
|
||||||
|
|
||||||
rc = f77_zmq_recv( zmq_socket_pull, ntask, 4, 0)
|
rc = f77_zmq_recv( zmq_socket_pull, ntask, 4, 0)
|
||||||
|
@ -6,15 +6,108 @@ BEGIN_PROVIDER [ double precision, pt2_match_weight, (N_states) ]
|
|||||||
! Weights adjusted along the selection to make the PT2 contributions
|
! Weights adjusted along the selection to make the PT2 contributions
|
||||||
! of each state coincide.
|
! of each state coincide.
|
||||||
END_DOC
|
END_DOC
|
||||||
pt2_match_weight = 1.d0
|
pt2_match_weight(:) = 1.d0
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
BEGIN_PROVIDER [ double precision, variance_match_weight, (N_states) ]
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! Weights adjusted along the selection to make the variances
|
||||||
|
! of each state coincide.
|
||||||
|
END_DOC
|
||||||
|
variance_match_weight(:) = 1.d0
|
||||||
|
END_PROVIDER
|
||||||
|
|
||||||
|
subroutine update_pt2_and_variance_weights(pt2, variance, norm, N_st)
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! Updates the rPT2- and Variance- matching weights.
|
||||||
|
END_DOC
|
||||||
|
integer, intent(in) :: N_st
|
||||||
|
double precision, intent(in) :: pt2(N_st)
|
||||||
|
double precision, intent(in) :: variance(N_st)
|
||||||
|
double precision, intent(in) :: norm(N_st)
|
||||||
|
|
||||||
|
double precision :: avg, rpt2(N_st), element, dt, x
|
||||||
|
integer :: k
|
||||||
|
integer, save :: i_iter=0
|
||||||
|
integer, parameter :: i_itermax = 3
|
||||||
|
double precision, allocatable, save :: memo_variance(:,:), memo_pt2(:,:)
|
||||||
|
|
||||||
|
if (i_iter == 0) then
|
||||||
|
allocate(memo_variance(N_st,i_itermax), memo_pt2(N_st,i_itermax))
|
||||||
|
memo_pt2(:,:) = 1.d0
|
||||||
|
memo_variance(:,:) = 1.d0
|
||||||
|
endif
|
||||||
|
|
||||||
|
i_iter = i_iter+1
|
||||||
|
if (i_iter > i_itermax) then
|
||||||
|
i_iter = 1
|
||||||
|
endif
|
||||||
|
|
||||||
|
dt = 4.d0
|
||||||
|
|
||||||
|
do k=1,N_st
|
||||||
|
rpt2(k) = pt2(k)/(1.d0 + norm(k))
|
||||||
|
enddo
|
||||||
|
|
||||||
|
avg = sum(rpt2(1:N_st)) / dble(N_st)
|
||||||
|
do k=1,N_st
|
||||||
|
element = exp(dt*(rpt2(k)/avg -1.d0))
|
||||||
|
element = min(1.5d0 , element)
|
||||||
|
element = max(0.5d0 , element)
|
||||||
|
memo_pt2(k,i_iter) = element
|
||||||
|
pt2_match_weight(k) = product(memo_pt2(k,:))
|
||||||
|
enddo
|
||||||
|
|
||||||
|
avg = sum(variance(1:N_st)) / dble(N_st)
|
||||||
|
do k=1,N_st
|
||||||
|
element = exp(dt*(variance(k)/avg -1.d0))
|
||||||
|
element = min(1.5d0 , element)
|
||||||
|
element = max(0.5d0 , element)
|
||||||
|
memo_variance(k,i_iter) = element
|
||||||
|
variance_match_weight(k) = product(memo_variance(k,:))
|
||||||
|
enddo
|
||||||
|
|
||||||
|
print *, '# PT2 weight ', real(pt2_match_weight(:),4)
|
||||||
|
print *, '# var weight ', real(variance_match_weight(:),4)
|
||||||
|
SOFT_TOUCH pt2_match_weight variance_match_weight
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
BEGIN_PROVIDER [ double precision, selection_weight, (N_states) ]
|
BEGIN_PROVIDER [ double precision, selection_weight, (N_states) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Weights used in the selection criterion
|
! Weights used in the selection criterion
|
||||||
END_DOC
|
END_DOC
|
||||||
selection_weight(1:N_states) = c0_weight(1:N_states) * pt2_match_weight(1:N_states)
|
select case (weight_selection)
|
||||||
|
|
||||||
|
case (0)
|
||||||
|
print *, 'Using input weights in selection'
|
||||||
|
selection_weight(1:N_states) = state_average_weight(1:N_states)
|
||||||
|
|
||||||
|
case (1)
|
||||||
|
print *, 'Using 1/c_max^2 weight in selection'
|
||||||
|
selection_weight(1:N_states) = c0_weight(1:N_states)
|
||||||
|
|
||||||
|
case (2)
|
||||||
|
print *, 'Using pt2-matching weight in selection'
|
||||||
|
selection_weight(1:N_states) = c0_weight(1:N_states) * pt2_match_weight(1:N_states)
|
||||||
|
|
||||||
|
case (3)
|
||||||
|
print *, 'Using variance-matching weight in selection'
|
||||||
|
selection_weight(1:N_states) = c0_weight(1:N_states) * variance_match_weight(1:N_states)
|
||||||
|
|
||||||
|
case (4)
|
||||||
|
print *, 'Using variance- and pt2-matching weights in selection'
|
||||||
|
selection_weight(1:N_states) = c0_weight(1:N_states) * variance_match_weight(1:N_states) * pt2_match_weight(1:N_states)
|
||||||
|
|
||||||
|
case (5)
|
||||||
|
print *, 'Using variance-matching weight in selection'
|
||||||
|
selection_weight(1:N_states) = c0_weight(1:N_states) * variance_match_weight(1:N_states)
|
||||||
|
|
||||||
|
end select
|
||||||
|
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
@ -621,11 +714,13 @@ subroutine fill_buffer_double(i_generator, sp, h1, h2, bannedOrb, banned, fock_d
|
|||||||
variance(istate) = variance(istate) + alpha_h_psi * alpha_h_psi
|
variance(istate) = variance(istate) + alpha_h_psi * alpha_h_psi
|
||||||
norm(istate) = norm(istate) + coef * coef
|
norm(istate) = norm(istate) + coef * coef
|
||||||
|
|
||||||
! if (h0_type == "Variance") then
|
if (weight_selection /= 5) then
|
||||||
! sum_e_pert = sum_e_pert - alpha_h_psi * alpha_h_psi * selection_weight(istate)
|
! Energy selection
|
||||||
! else
|
|
||||||
sum_e_pert = sum_e_pert + e_pert * selection_weight(istate)
|
sum_e_pert = sum_e_pert + e_pert * selection_weight(istate)
|
||||||
! endif
|
else
|
||||||
|
! Variance selection
|
||||||
|
sum_e_pert = sum_e_pert - alpha_h_psi * alpha_h_psi * selection_weight(istate)
|
||||||
|
endif
|
||||||
end do
|
end do
|
||||||
if(pseudo_sym)then
|
if(pseudo_sym)then
|
||||||
if(dabs(mat(1, p1, p2)).lt.thresh_sym)then
|
if(dabs(mat(1, p1, p2)).lt.thresh_sym)then
|
||||||
|
@ -17,7 +17,7 @@ subroutine provide_everything
|
|||||||
PROVIDE H_apply_buffer_allocated mo_two_e_integrals_in_map psi_det_generators psi_coef_generators psi_det_sorted_bit psi_selectors n_det_generators n_states generators_bitmask zmq_context N_states_diag
|
PROVIDE H_apply_buffer_allocated mo_two_e_integrals_in_map psi_det_generators psi_coef_generators psi_det_sorted_bit psi_selectors n_det_generators n_states generators_bitmask zmq_context N_states_diag
|
||||||
PROVIDE pt2_e0_denominator mo_num N_int ci_energy mpi_master zmq_state zmq_context
|
PROVIDE pt2_e0_denominator mo_num N_int ci_energy mpi_master zmq_state zmq_context
|
||||||
PROVIDE psi_det psi_coef threshold_generators state_average_weight
|
PROVIDE psi_det psi_coef threshold_generators state_average_weight
|
||||||
PROVIDE N_det_selectors pt2_stoch_istate N_det
|
PROVIDE N_det_selectors pt2_stoch_istate N_det selection_weight pseudo_sym
|
||||||
end
|
end
|
||||||
|
|
||||||
subroutine run_slave_main
|
subroutine run_slave_main
|
||||||
@ -220,8 +220,12 @@ subroutine run_slave_main
|
|||||||
call mpi_print('zmq_get_dvector state_average_weight')
|
call mpi_print('zmq_get_dvector state_average_weight')
|
||||||
IRP_ENDIF
|
IRP_ENDIF
|
||||||
if (zmq_get_dvector(zmq_to_qp_run_socket,1,'state_average_weight',state_average_weight,N_states) == -1) cycle
|
if (zmq_get_dvector(zmq_to_qp_run_socket,1,'state_average_weight',state_average_weight,N_states) == -1) cycle
|
||||||
|
IRP_IF MPI_DEBUG
|
||||||
|
call mpi_print('zmq_get_dvector selection_weight')
|
||||||
|
IRP_ENDIF
|
||||||
|
if (zmq_get_dvector(zmq_to_qp_run_socket,1,'selection_weight',selection_weight,N_states) == -1) cycle
|
||||||
pt2_e0_denominator(1:N_states) = energy(1:N_states)
|
pt2_e0_denominator(1:N_states) = energy(1:N_states)
|
||||||
SOFT_TOUCH pt2_e0_denominator state_average_weight pt2_stoch_istate threshold_generators
|
SOFT_TOUCH pt2_e0_denominator state_average_weight pt2_stoch_istate threshold_generators selection_weight
|
||||||
|
|
||||||
call wall_time(t1)
|
call wall_time(t1)
|
||||||
call write_double(6,(t1-t0),'Broadcast time')
|
call write_double(6,(t1-t0),'Broadcast time')
|
||||||
|
@ -4,7 +4,7 @@ subroutine run_stochastic_cipsi
|
|||||||
! Selected Full Configuration Interaction with Stochastic selection and PT2.
|
! Selected Full Configuration Interaction with Stochastic selection and PT2.
|
||||||
END_DOC
|
END_DOC
|
||||||
integer :: i,j,k
|
integer :: i,j,k
|
||||||
double precision, allocatable :: pt2(:), variance(:), norm(:), rpt2(:)
|
double precision, allocatable :: pt2(:), variance(:), norm(:), rpt2(:), zeros(:)
|
||||||
integer :: to_select
|
integer :: to_select
|
||||||
logical, external :: qp_stop
|
logical, external :: qp_stop
|
||||||
|
|
||||||
@ -18,7 +18,7 @@ subroutine run_stochastic_cipsi
|
|||||||
rss = memory_of_double(N_states)*4.d0
|
rss = memory_of_double(N_states)*4.d0
|
||||||
call check_mem(rss,irp_here)
|
call check_mem(rss,irp_here)
|
||||||
|
|
||||||
allocate (pt2(N_states), rpt2(N_states), norm(N_states), variance(N_states))
|
allocate (pt2(N_states), zeros(N_states), rpt2(N_states), norm(N_states), variance(N_states))
|
||||||
|
|
||||||
double precision :: hf_energy_ref
|
double precision :: hf_energy_ref
|
||||||
logical :: has
|
logical :: has
|
||||||
@ -26,6 +26,7 @@ subroutine run_stochastic_cipsi
|
|||||||
|
|
||||||
relative_error=PT2_relative_error
|
relative_error=PT2_relative_error
|
||||||
|
|
||||||
|
zeros = 0.d0
|
||||||
pt2 = -huge(1.e0)
|
pt2 = -huge(1.e0)
|
||||||
rpt2 = -huge(1.e0)
|
rpt2 = -huge(1.e0)
|
||||||
norm = 0.d0
|
norm = 0.d0
|
||||||
@ -63,14 +64,14 @@ subroutine run_stochastic_cipsi
|
|||||||
|
|
||||||
do while ( &
|
do while ( &
|
||||||
(N_det < N_det_max) .and. &
|
(N_det < N_det_max) .and. &
|
||||||
(maxval(abs(pt2(1:N_states))) > pt2_max) .and. &
|
(maxval(abs(rpt2(1:N_states))) > pt2_max) .and. &
|
||||||
(maxval(abs(variance(1:N_states))) > variance_max) .and. &
|
(maxval(abs(variance(1:N_states))) > variance_max) .and. &
|
||||||
(correlation_energy_ratio <= correlation_energy_ratio_max) &
|
(correlation_energy_ratio <= correlation_energy_ratio_max) &
|
||||||
)
|
)
|
||||||
write(*,'(A)') '--------------------------------------------------------------------------------'
|
write(*,'(A)') '--------------------------------------------------------------------------------'
|
||||||
|
|
||||||
|
|
||||||
to_select = N_det*int(sqrt(dble(N_states)))
|
to_select = int(sqrt(dble(N_states))*dble(N_det)*selection_factor)
|
||||||
to_select = max(N_states_diag, to_select)
|
to_select = max(N_states_diag, to_select)
|
||||||
|
|
||||||
pt2 = 0.d0
|
pt2 = 0.d0
|
||||||
@ -79,17 +80,17 @@ subroutine run_stochastic_cipsi
|
|||||||
call ZMQ_pt2(psi_energy_with_nucl_rep,pt2,relative_error,error, variance, &
|
call ZMQ_pt2(psi_energy_with_nucl_rep,pt2,relative_error,error, variance, &
|
||||||
norm, to_select) ! Stochastic PT2 and selection
|
norm, to_select) ! Stochastic PT2 and selection
|
||||||
|
|
||||||
|
do k=1,N_states
|
||||||
|
rpt2(k) = pt2(k)/(1.d0 + norm(k))
|
||||||
|
enddo
|
||||||
|
|
||||||
correlation_energy_ratio = (psi_energy_with_nucl_rep(1) - hf_energy_ref) / &
|
correlation_energy_ratio = (psi_energy_with_nucl_rep(1) - hf_energy_ref) / &
|
||||||
(psi_energy_with_nucl_rep(1) + pt2(1) - hf_energy_ref)
|
(psi_energy_with_nucl_rep(1) + rpt2(1) - hf_energy_ref)
|
||||||
correlation_energy_ratio = min(1.d0,correlation_energy_ratio)
|
correlation_energy_ratio = min(1.d0,correlation_energy_ratio)
|
||||||
|
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
|
||||||
call write_double(6,correlation_energy_ratio, 'Correlation ratio')
|
call write_double(6,correlation_energy_ratio, 'Correlation ratio')
|
||||||
call print_summary(psi_energy_with_nucl_rep,pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
call print_summary(psi_energy_with_nucl_rep,pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
||||||
|
|
||||||
do k=1,N_states
|
|
||||||
rpt2(:) = pt2(:)/(1.d0 + norm(k))
|
|
||||||
enddo
|
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
||||||
|
|
||||||
call save_iterations(psi_energy_with_nucl_rep(1:N_states),rpt2,N_det)
|
call save_iterations(psi_energy_with_nucl_rep(1:N_states),rpt2,N_det)
|
||||||
@ -108,8 +109,7 @@ subroutine run_stochastic_cipsi
|
|||||||
|
|
||||||
call diagonalize_CI
|
call diagonalize_CI
|
||||||
call save_wavefunction
|
call save_wavefunction
|
||||||
rpt2(:) = 0.d0
|
call save_energy(psi_energy_with_nucl_rep, zeros)
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
|
||||||
if (qp_stop()) exit
|
if (qp_stop()) exit
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
@ -117,20 +117,18 @@ subroutine run_stochastic_cipsi
|
|||||||
if (N_det < N_det_max) then
|
if (N_det < N_det_max) then
|
||||||
call diagonalize_CI
|
call diagonalize_CI
|
||||||
call save_wavefunction
|
call save_wavefunction
|
||||||
rpt2(:) = 0.d0
|
call save_energy(psi_energy_with_nucl_rep, zeros)
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
pt2 = 0.d0
|
pt2(:) = 0.d0
|
||||||
variance = 0.d0
|
variance(:) = 0.d0
|
||||||
norm = 0.d0
|
norm(:) = 0.d0
|
||||||
call ZMQ_pt2(psi_energy_with_nucl_rep, pt2,relative_error,error,variance, &
|
call ZMQ_pt2(psi_energy_with_nucl_rep, pt2,relative_error,error,variance, &
|
||||||
norm,0) ! Stochastic PT2
|
norm,0) ! Stochastic PT2
|
||||||
|
|
||||||
do k=1,N_states
|
do k=1,N_states
|
||||||
rpt2(:) = pt2(:)/(1.d0 + norm(k))
|
rpt2(k) = pt2(k)/(1.d0 + norm(k))
|
||||||
enddo
|
enddo
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
|
||||||
|
|
||||||
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
call save_energy(psi_energy_with_nucl_rep, rpt2)
|
||||||
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
||||||
|
@ -21,7 +21,8 @@ subroutine ZMQ_selection(N_in, pt2, variance, norm)
|
|||||||
PROVIDE psi_bilinear_matrix_columns_loc psi_det_alpha_unique psi_det_beta_unique
|
PROVIDE psi_bilinear_matrix_columns_loc psi_det_alpha_unique psi_det_beta_unique
|
||||||
PROVIDE psi_bilinear_matrix_rows psi_det_sorted_order psi_bilinear_matrix_order
|
PROVIDE psi_bilinear_matrix_rows psi_det_sorted_order psi_bilinear_matrix_order
|
||||||
PROVIDE psi_bilinear_matrix_transp_rows_loc psi_bilinear_matrix_transp_columns
|
PROVIDE psi_bilinear_matrix_transp_rows_loc psi_bilinear_matrix_transp_columns
|
||||||
PROVIDE psi_bilinear_matrix_transp_order
|
PROVIDE psi_bilinear_matrix_transp_order selection_weight pseudo_sym
|
||||||
|
|
||||||
|
|
||||||
call new_parallel_job(zmq_to_qp_run_socket,zmq_socket_pull,'selection')
|
call new_parallel_job(zmq_to_qp_run_socket,zmq_socket_pull,'selection')
|
||||||
|
|
||||||
@ -45,6 +46,9 @@ subroutine ZMQ_selection(N_in, pt2, variance, norm)
|
|||||||
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'state_average_weight',state_average_weight,N_states) == -1) then
|
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'state_average_weight',state_average_weight,N_states) == -1) then
|
||||||
stop 'Unable to put state_average_weight on ZMQ server'
|
stop 'Unable to put state_average_weight on ZMQ server'
|
||||||
endif
|
endif
|
||||||
|
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'selection_weight',selection_weight,N_states) == -1) then
|
||||||
|
stop 'Unable to put selection_weight on ZMQ server'
|
||||||
|
endif
|
||||||
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'threshold_generators',threshold_generators,1) == -1) then
|
if (zmq_put_dvector(zmq_to_qp_run_socket,1,'threshold_generators',threshold_generators,1) == -1) then
|
||||||
stop 'Unable to put threshold_generators on ZMQ server'
|
stop 'Unable to put threshold_generators on ZMQ server'
|
||||||
endif
|
endif
|
||||||
@ -85,7 +89,11 @@ subroutine ZMQ_selection(N_in, pt2, variance, norm)
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
integer :: nproc_target
|
integer :: nproc_target
|
||||||
nproc_target = nproc
|
if (N_det < 3*nproc) then
|
||||||
|
nproc_target = N_det/4
|
||||||
|
else
|
||||||
|
nproc_target = nproc
|
||||||
|
endif
|
||||||
double precision :: mem
|
double precision :: mem
|
||||||
mem = 8.d0 * N_det * (N_int * 2.d0 * 3.d0 + 3.d0 + 5.d0) / (1024.d0**3)
|
mem = 8.d0 * N_det * (N_int * 2.d0 * 3.d0 + 3.d0 + 5.d0) / (1024.d0**3)
|
||||||
call write_double(6,mem,'Estimated memory/thread (Gb)')
|
call write_double(6,mem,'Estimated memory/thread (Gb)')
|
||||||
@ -131,13 +139,7 @@ subroutine ZMQ_selection(N_in, pt2, variance, norm)
|
|||||||
norm(k) = norm(k) * f(k)
|
norm(k) = norm(k) * f(k)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
! Adjust PT2 weights for next selection
|
call update_pt2_and_variance_weights(pt2, variance, norm, N_states)
|
||||||
double precision :: pt2_avg
|
|
||||||
pt2_avg = sum(pt2) / dble(N_states)
|
|
||||||
do k=1,N_states
|
|
||||||
pt2_match_weight(k) *= (pt2(k)/pt2_avg)**2
|
|
||||||
enddo
|
|
||||||
SOFT_TOUCH pt2_match_weight
|
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
@ -159,9 +161,9 @@ subroutine selection_collector(zmq_socket_pull, b, N, pt2, variance, norm)
|
|||||||
integer(ZMQ_PTR), intent(in) :: zmq_socket_pull
|
integer(ZMQ_PTR), intent(in) :: zmq_socket_pull
|
||||||
type(selection_buffer), intent(inout) :: b
|
type(selection_buffer), intent(inout) :: b
|
||||||
integer, intent(in) :: N
|
integer, intent(in) :: N
|
||||||
double precision, intent(inout) :: pt2(N_states)
|
double precision, intent(out) :: pt2(N_states)
|
||||||
double precision, intent(inout) :: variance(N_states)
|
double precision, intent(out) :: variance(N_states)
|
||||||
double precision, intent(inout) :: norm(N_states)
|
double precision, intent(out) :: norm(N_states)
|
||||||
double precision :: pt2_mwen(N_states)
|
double precision :: pt2_mwen(N_states)
|
||||||
double precision :: variance_mwen(N_states)
|
double precision :: variance_mwen(N_states)
|
||||||
double precision :: norm_mwen(N_states)
|
double precision :: norm_mwen(N_states)
|
||||||
|
54
src/davidson/print_e_components.irp.f
Normal file
54
src/davidson/print_e_components.irp.f
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
subroutine print_energy_components()
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! Prints the different components of the energy.
|
||||||
|
END_DOC
|
||||||
|
integer, save :: ifirst = 0
|
||||||
|
double precision :: Vee, Ven, Vnn, Vecp, T, f
|
||||||
|
integer :: i,j,k
|
||||||
|
|
||||||
|
Vnn = nuclear_repulsion
|
||||||
|
|
||||||
|
print *, 'Energy components'
|
||||||
|
print *, '================='
|
||||||
|
print *, ''
|
||||||
|
do k=1,N_states
|
||||||
|
|
||||||
|
Ven = 0.d0
|
||||||
|
Vecp = 0.d0
|
||||||
|
T = 0.d0
|
||||||
|
|
||||||
|
do j=1,mo_num
|
||||||
|
do i=1,mo_num
|
||||||
|
f = one_e_dm_mo_alpha(i,j,k) + one_e_dm_mo_beta(i,j,k)
|
||||||
|
Ven = Ven + f * mo_integrals_n_e(i,j)
|
||||||
|
Vecp = Vecp + f * mo_pseudo_integrals(i,j)
|
||||||
|
T = T + f * mo_kinetic_integrals(i,j)
|
||||||
|
enddo
|
||||||
|
enddo
|
||||||
|
Vee = psi_energy(k) - Ven - Vecp - T
|
||||||
|
|
||||||
|
if (ifirst == 0) then
|
||||||
|
ifirst = 1
|
||||||
|
print *, 'Vnn : Nucleus-Nucleus potential energy'
|
||||||
|
print *, 'Ven : Electron-Nucleus potential energy'
|
||||||
|
print *, 'Vee : Electron-Electron potential energy'
|
||||||
|
print *, 'Vecp : Potential energy of the pseudo-potentials'
|
||||||
|
print *, 'T : Electronic kinetic energy'
|
||||||
|
print *, ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
print *, 'State ', k
|
||||||
|
print *, '---------'
|
||||||
|
print *, ''
|
||||||
|
print *, 'Vnn = ', Vnn
|
||||||
|
print *, 'Ven = ', Ven
|
||||||
|
print *, 'Vee = ', Vee
|
||||||
|
print *, 'Vecp = ', Vecp
|
||||||
|
print *, 'T = ', T
|
||||||
|
print *, ''
|
||||||
|
enddo
|
||||||
|
|
||||||
|
print *, ''
|
||||||
|
|
||||||
|
end
|
@ -28,12 +28,18 @@ doc: Force the wave function to be an eigenfunction of |S^2|
|
|||||||
interface: ezfio,provider,ocaml
|
interface: ezfio,provider,ocaml
|
||||||
default: True
|
default: True
|
||||||
|
|
||||||
[used_weight]
|
[weight_one_e_dm]
|
||||||
type: integer
|
type: integer
|
||||||
doc: Weight used in the calculation of the one-electron density matrix. 0: 1./(c_0^2), 1: 1/N_states, 2: input state-average weight, 3: 1/(Norm_L3(Psi))
|
doc: Weight used in the calculation of the one-electron density matrix. 0: 1./(c_0^2), 1: 1/N_states, 2: input state-average weight, 3: 1/(Norm_L3(Psi))
|
||||||
interface: ezfio,provider,ocaml
|
interface: ezfio,provider,ocaml
|
||||||
default: 1
|
default: 1
|
||||||
|
|
||||||
|
[weight_selection]
|
||||||
|
type: integer
|
||||||
|
doc: Weight used in the selection. 0: input state-average weight, 1: 1./(c_0^2), 2: rPT2 matching, 3: variance matching, 4: variance and rPT2 matching, 5: variance minimization and matching
|
||||||
|
interface: ezfio,provider,ocaml
|
||||||
|
default: 2
|
||||||
|
|
||||||
[threshold_generators]
|
[threshold_generators]
|
||||||
type: Threshold
|
type: Threshold
|
||||||
doc: Thresholds on generators (fraction of the square of the norm)
|
doc: Thresholds on generators (fraction of the square of the norm)
|
||||||
@ -89,6 +95,11 @@ doc: Weight of the states in state-average calculations.
|
|||||||
interface: ezfio
|
interface: ezfio
|
||||||
size: (determinants.n_states)
|
size: (determinants.n_states)
|
||||||
|
|
||||||
|
[selection_factor]
|
||||||
|
type: double precision
|
||||||
|
doc: f such that the number of determinants to add is f * N_det * sqrt(N_states)
|
||||||
|
interface: ezfio,provider,ocaml
|
||||||
|
default: 1.
|
||||||
|
|
||||||
[thresh_sym]
|
[thresh_sym]
|
||||||
type: Threshold
|
type: Threshold
|
||||||
|
@ -305,9 +305,9 @@ BEGIN_PROVIDER [ double precision, state_average_weight, (N_states) ]
|
|||||||
logical :: exists
|
logical :: exists
|
||||||
|
|
||||||
state_average_weight(:) = 1.d0
|
state_average_weight(:) = 1.d0
|
||||||
if (used_weight == 0) then
|
if (weight_one_e_dm == 0) then
|
||||||
state_average_weight(:) = c0_weight(:)
|
state_average_weight(:) = c0_weight(:)
|
||||||
else if (used_weight == 1) then
|
else if (weight_one_e_dm == 1) then
|
||||||
state_average_weight(:) = 1./N_states
|
state_average_weight(:) = 1./N_states
|
||||||
else
|
else
|
||||||
call ezfio_has_determinants_state_average_weight(exists)
|
call ezfio_has_determinants_state_average_weight(exists)
|
||||||
|
@ -43,4 +43,3 @@ BEGIN_PROVIDER [ double precision, S2_matrix_all_dets,(N_det,N_det) ]
|
|||||||
!$OMP END PARALLEL DO
|
!$OMP END PARALLEL DO
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ double precision function ec_lyp_88(rho,rho_a,rho_b,grad_rho_a_2,grad_rho_b_2,gr
|
|||||||
|
|
||||||
double precision :: a,b,c,d,c_f,omega,delta
|
double precision :: a,b,c,d,c_f,omega,delta
|
||||||
double precision :: rho_13,rho_inv_13,rho_83,rho_113,rho_inv_113,denom
|
double precision :: rho_13,rho_inv_13,rho_83,rho_113,rho_inv_113,denom
|
||||||
double precision :: thr,huge_num
|
double precision :: thr,huge_num,rho_inv
|
||||||
double precision :: cst_2_113,cst_8_3,rho_2,rho_a_2,rho_b_2
|
double precision :: cst_2_113,cst_8_3,rho_2,rho_a_2,rho_b_2
|
||||||
double precision :: tmp1,tmp2,tmp3,tmp4
|
double precision :: tmp1,tmp2,tmp3,tmp4
|
||||||
double precision :: big1,big2,big3
|
double precision :: big1,big2,big3
|
||||||
@ -57,24 +57,34 @@ double precision function ec_lyp_88(rho,rho_a,rho_b,grad_rho_a_2,grad_rho_b_2,gr
|
|||||||
c = 0.2533d0
|
c = 0.2533d0
|
||||||
d = 0.349d0
|
d = 0.349d0
|
||||||
|
|
||||||
thr = 1d-15
|
thr = 1d-10
|
||||||
huge_num = 1.d0/thr
|
huge_num = 1.d0/thr
|
||||||
|
|
||||||
|
if(rho.lt.0.d0)then
|
||||||
|
print*,'pb !! rho.lt.0.d0'
|
||||||
|
stop
|
||||||
|
endif
|
||||||
rho_13 = rho**(1d0/3d0)
|
rho_13 = rho**(1d0/3d0)
|
||||||
rho_113 = rho**(11d0/3d0)
|
rho_113 = rho**(11d0/3d0)
|
||||||
|
|
||||||
if(abs(rho_13) < thr) then
|
if(dabs(rho_13) < thr) then
|
||||||
rho_inv_13 = huge_num
|
rho_inv_13 = huge_num
|
||||||
else
|
else
|
||||||
rho_inv_13 = 1.d0/rho_13
|
rho_inv_13 = 1.d0/rho_13
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if (abs(rho_113) < thr) then
|
if (dabs(rho_113) < thr) then
|
||||||
rho_inv_113 = huge_num
|
rho_inv_113 = huge_num
|
||||||
else
|
else
|
||||||
rho_inv_113 = 1d0/rho_113
|
rho_inv_113 = 1d0/rho_113
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
if (dabs(rho) < thr) then
|
||||||
|
rho_inv = huge_num
|
||||||
|
else
|
||||||
|
rho_inv = 1d0/rho
|
||||||
|
endif
|
||||||
|
|
||||||
! Useful quantities to predefine
|
! Useful quantities to predefine
|
||||||
|
|
||||||
denom = 1d0/(1d0 + d*rho_inv_13)
|
denom = 1d0/(1d0 + d*rho_inv_13)
|
||||||
@ -91,12 +101,12 @@ double precision function ec_lyp_88(rho,rho_a,rho_b,grad_rho_a_2,grad_rho_b_2,gr
|
|||||||
|
|
||||||
! first term in the equation (2) of Preuss CPL, 1989
|
! first term in the equation (2) of Preuss CPL, 1989
|
||||||
|
|
||||||
big1 = 4d0*denom*rho_a*rho_b/rho
|
big1 = 4d0*denom*rho_a*rho_b*rho_inv
|
||||||
|
|
||||||
tmp1 = cst_2_113*c_f*(rho_a**cst_8_3 + rho_b**cst_8_3)
|
tmp1 = cst_2_113*c_f*(rho_a**cst_8_3 + rho_b**cst_8_3)
|
||||||
tmp2 = (47d0/18d0 - 7d0/18d0*delta)*grad_rho_2
|
tmp2 = (47d0/18d0 - 7d0/18d0*delta)*grad_rho_2
|
||||||
tmp3 = - (5d0/2d0 - 1.d0/18d0*delta)*(grad_rho_a_2 + grad_rho_b_2)
|
tmp3 = - (5d0/2d0 - 1.d0/18d0*delta)*(grad_rho_a_2 + grad_rho_b_2)
|
||||||
tmp4 = - (delta - 11d0)/9d0*(rho_a/rho*grad_rho_a_2 + rho_b/rho*grad_rho_b_2)
|
tmp4 = - (delta - 11d0)/9d0*(rho_a*rho_inv*grad_rho_a_2 + rho_b*rho_inv*grad_rho_b_2)
|
||||||
big2 = rho_a*rho_b*(tmp1 + tmp2 + tmp3 + tmp4)
|
big2 = rho_a*rho_b*(tmp1 + tmp2 + tmp3 + tmp4)
|
||||||
|
|
||||||
tmp1 = -2d0/3d0*rho_2*grad_rho_2
|
tmp1 = -2d0/3d0*rho_2*grad_rho_2
|
||||||
|
@ -46,7 +46,7 @@ subroutine run
|
|||||||
call ZMQ_pt2(psi_energy_with_nucl_rep,pt2,relative_error,error, variance, &
|
call ZMQ_pt2(psi_energy_with_nucl_rep,pt2,relative_error,error, variance, &
|
||||||
norm,0) ! Stochastic PT2
|
norm,0) ! Stochastic PT2
|
||||||
do k=1,N_states
|
do k=1,N_states
|
||||||
rpt2(:) = pt2(:)/(1.d0 + norm(k))
|
rpt2(k) = pt2(k)/(1.d0 + norm(k))
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
call print_summary(psi_energy_with_nucl_rep(1:N_states),pt2,error,variance,norm,N_det,N_occ_pattern,N_states,psi_s2)
|
||||||
|
@ -31,18 +31,19 @@ subroutine print_summary(e_,pt2_,error_,variance_,norm_,n_det_,n_occ_pattern_,n_
|
|||||||
|
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
||||||
write(*,fmt)
|
write(*,fmt)
|
||||||
write(fmt,*) '(12X,', N_states_p, '(6X,A7,1X,I6,10X))'
|
write(fmt,*) '(13X,', N_states_p, '(6X,A7,1X,I6,10X))'
|
||||||
write(*,fmt) ('State',k, k=1,N_states_p)
|
write(*,fmt) ('State',k, k=1,N_states_p)
|
||||||
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
write(fmt,*) '(''# ============'',', N_states_p, '(1X,''=============================''))'
|
||||||
write(*,fmt)
|
write(*,fmt)
|
||||||
write(fmt,*) '(A12,', N_states_p, '(1X,F14.8,15X))'
|
write(fmt,*) '(A13,', N_states_p, '(1X,F14.8,15X))'
|
||||||
write(*,fmt) '# E ', e_(1:N_states_p)
|
write(*,fmt) '# E ', e_(1:N_states_p)
|
||||||
if (N_states_p > 1) then
|
if (N_states_p > 1) then
|
||||||
write(*,fmt) '# Excit. (au)', e_(1:N_states_p)-e_(1)
|
write(*,fmt) '# Excit. (au)', e_(1:N_states_p)-e_(1)
|
||||||
write(*,fmt) '# Excit. (eV)', (e_(1:N_states_p)-e_(1))*27.211396641308d0
|
write(*,fmt) '# Excit. (eV)', (e_(1:N_states_p)-e_(1))*27.211396641308d0
|
||||||
endif
|
endif
|
||||||
write(fmt,*) '(A13,', 2*N_states_p, '(1X,F14.8))'
|
write(fmt,*) '(A13,', 2*N_states_p, '(1X,F14.8))'
|
||||||
write(*,fmt) '# PT2'//pt2_string, (pt2_(k), error_(k), k=1,N_states_p)
|
write(*,fmt) '# PT2 '//pt2_string, (pt2_(k), error_(k), k=1,N_states_p)
|
||||||
|
write(*,fmt) '# rPT2'//pt2_string, (pt2_(k)*f(k), error_(k)*f(k), k=1,N_states_p)
|
||||||
write(*,'(A)') '#'
|
write(*,'(A)') '#'
|
||||||
write(*,fmt) '# E+PT2 ', (e_(k)+pt2_(k),error_(k), k=1,N_states_p)
|
write(*,fmt) '# E+PT2 ', (e_(k)+pt2_(k),error_(k), k=1,N_states_p)
|
||||||
write(*,fmt) '# E+rPT2 ', (e_(k)+pt2_(k)*f(k),error_(k)*f(k), k=1,N_states_p)
|
write(*,fmt) '# E+rPT2 ', (e_(k)+pt2_(k)*f(k),error_(k)*f(k), k=1,N_states_p)
|
||||||
@ -97,5 +98,7 @@ subroutine print_summary(e_,pt2_,error_,variance_,norm_,n_det_,n_occ_pattern_,n_
|
|||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
call print_energy_components()
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user