mirror of https://github.com/QMCPACK/qmcpack.git
1085 lines
68 KiB
Markdown
1085 lines
68 KiB
Markdown
# Change Log
|
|
|
|
Notable changes to QMCPACK are documented in this file.
|
|
|
|
## [Unreleased]
|
|
|
|
* Support for backflow optimization has been removed as part of refactoring and cleaning the codebase. QMC runs using backflow
|
|
wavefunctions are still supported. This feature is expected to eventually be reimplemented in v4. Users needing
|
|
backflow optimization can use previously released versions of QMCPACK or work towards its reimplementation in the modern code.
|
|
[#4688](https://github.com/QMCPACK/qmcpack/pull/4688)
|
|
|
|
## [3.17.1] - 2023-08-25
|
|
|
|
This minor release is recommended for all users and includes a couple of build fixes and a NEXUS improvement.
|
|
|
|
* Improved HDF5 detection. Fixes cases where HDF5 was not identified by CMake, including on FreeBSD (thanks @yurivict for the report). [#4708](https://github.com/QMCPACK/qmcpack/pull/4708)
|
|
* Fix for building with BUILD_UNIT_TESTS=OFF. [#4709](https://github.com/QMCPACK/qmcpack/pull/4709)
|
|
* Add timer for orbital rotations. [#4706](https://github.com/QMCPACK/qmcpack/pull/4706)
|
|
|
|
### NEXUS
|
|
|
|
* NEXUS: Support for spinor inputs. [#4707](https://github.com/QMCPACK/qmcpack/pull/4707)
|
|
## [3.17.0] - 2023-08-18
|
|
|
|
This is a recommended release for all users. Thanks to everyone who contributed directly, reported an issue, or suggested an
|
|
improvement. There are many quality of life improvements, bug fixes throughout the application, and updates to the associated
|
|
testing. As previously announced, the legacy CUDA support (QMC_CUDA=1) is removed in this version. For GPU support, users should
|
|
transition to the offload code which is more capable and fully usable in production on NVIDIA GPUs.
|
|
|
|
This version is intended for long-term support of v3 of QMCPACK. Development effort is now focused towards v4. Contributions of
|
|
tests, fixes, and features from users and developers are still welcome to v3 for a potential future release. However, these will not
|
|
be ported towards v4 by the core QMCPACK developers without prior arrangement. Please discuss options with QMCPACK developers.
|
|
|
|
* Simplified checkpointing and enabled it in the batched drivers. Users now only need specify checkpoint={-1,0,N} to checkpoint
|
|
between blocks. [#4646](https://github.com/QMCPACK/qmcpack/pull/4646)
|
|
* NERSC Perlmutter build recipe. [#4698](https://github.com/QMCPACK/qmcpack/pull/4698)
|
|
* qmc-fit: Now supports parameter fitting with jackknife for e.g. DFT+U, EXX scans
|
|
[#4475](https://github.com/QMCPACK/qmcpack/pull/4475) and for equation of states and morse fits
|
|
[#4518](https://github.com/QMCPACK/qmcpack/pull/4518)
|
|
* Improved error checking including NaN checks to protect against potentially unreliable compilers and libraries,
|
|
[#4697](https://github.com/QMCPACK/qmcpack/pull/4697), and checks on GPU matrix inversion
|
|
[#4693](https://github.com/QMCPACK/qmcpack/pull/4693)
|
|
* Significant advances in orbital optimization capability, focusing on LCAO wavefunctions. Development is ongoing for
|
|
multideterminant support and for spline wavefunctions. See e.g. the Be atom orbital optimization test
|
|
[#4626](https://github.com/QMCPACK/qmcpack/pull/4626), [#4619](https://github.com/QMCPACK/qmcpack/pull/4619), reading and writing
|
|
of orbital rotation parameters [#4580](https://github.com/QMCPACK/qmcpack/pull/4580), support for disabled/frozen parameters
|
|
[#4581](https://github.com/QMCPACK/qmcpack/pull/4581).
|
|
* Magnetization Density Estimator for non-collinear wavefunctions [#4531](https://github.com/QMCPACK/qmcpack/pull/4531)
|
|
* Pathak-Wagner regularizer for forces [#4477](https://github.com/QMCPACK/qmcpack/pull/4477)
|
|
* The legacy CUDA implementation, the version built with QMC_CUDA=1, has been removed from the codebase,
|
|
[#4431](https://github.com/QMCPACK/qmcpack/pull/4431),
|
|
[#4632](https://github.com/QMCPACK/qmcpack/pull/4632),[#4499](https://github.com/QMCPACK/qmcpack/pull/4499),
|
|
[#4442](https://github.com/QMCPACK/qmcpack/pull/4442).
|
|
* For increased performance with current AMD GPU support, new QMC_DISABLE_HIP_HOST_REGISTER option is enabled by default for
|
|
ROCm/HIP builds. [#4674](https://github.com/QMCPACK/qmcpack/pull/4674)
|
|
* Bugfix: J1Spin indexing was wrong [#4612](https://github.com/QMCPACK/qmcpack/pull/4612)
|
|
* Bugfix: 1RDM estimator data written to stat.h5 was incorrect [#4568](https://github.com/QMCPACK/qmcpack/pull/4568)
|
|
* Introduced ENABLE_PPCONVERT option and skip ppconvert compilation when cross compiling. [#4601](https://github.com/QMCPACK/qmcpack/pull/4601)
|
|
* Faster builds compared to v3.16.0 due to code refactoring [#4682](https://github.com/QMCPACK/qmcpack/pull/4682)
|
|
* Many refinements throughout the codebase, cleanup, improved testing.
|
|
|
|
### NEXUS
|
|
|
|
* Nexus: Equilibration detection algorithm is now deterministic [#4557](https://github.com/QMCPACK/qmcpack/pull/4557)
|
|
* Nexus: Support for Kagayaki cluster at JAIST [#4598](https://github.com/QMCPACK/qmcpack/pull/4598)
|
|
* Nexus: GPU support fix for NERSC/Perlmutter [#4699](https://github.com/QMCPACK/qmcpack/pull/4699)
|
|
* Nexus: Use simplices in convex_hull to support newer scipy versions [#4671](https://github.com/QMCPACK/qmcpack/pull/4671)
|
|
* Nexus: Add pdos flag for Projwfc [#4655](https://github.com/QMCPACK/qmcpack/pull/4655)
|
|
* Nexus: Adding crowds_serialize_walkers tag to dmc input list [#4651](https://github.com/QMCPACK/qmcpack/pull/4651)
|
|
* Nexus: Qdens handles batched driver input/output [#4645](https://github.com/QMCPACK/qmcpack/pull/4645)
|
|
* Nexus: Fix namelist read for Projwfc input [#4644](https://github.com/QMCPACK/qmcpack/pull/4644)
|
|
|
|
### Known problems
|
|
|
|
* When offload builds are compiled with CUDA toolkit versions above 11.2 using LLVM, multideterminant tests and functionality will
|
|
fail, seemingly due to an issue with the toolkit. This is discussed in https://github.com/llvm/llvm-project/issues/54633 . All
|
|
other functionality appears to work as expected. As a workaround, the CUDA toolkit 11.2 can be used. The actual NVIDIA drivers can
|
|
be more recent.
|
|
|
|
## [3.16.0] - 2023-01-31
|
|
|
|
This release contains important bug fixes as well as feature improvements. It is a recommended release for all users. Thanks to
|
|
everyone who reported an issue or suggested an improvement. See GitHub for the full list of merged pull requests and closed issues.
|
|
|
|
This release is expected to be the last including the legacy CUDA implementation, the version built with QMC_CUDA=1. Users should
|
|
transition to the batched drivers which support greater functionality as well as both CPU and GPU execution. Users should adopt
|
|
these drivers now and report any issues. The new drivers can be requested with the driver_version input parameter, see
|
|
https://qmcpack.readthedocs.io/en/develop/performance_portable.html . In a subsequent release, the non-batched CPU drivers will also
|
|
be removed leaving only the performance portable batched drivers. This will result in a single implementation of most functionality,
|
|
improving overall usability and maintainability.
|
|
|
|
* Important bugfix to NLPP integration grid rotations and update to all relevant deterministic test values. See issue
|
|
[\#4362](https://github.com/QMCPACK/qmcpack/issues/4362) for full discussion and visualization. Found and corrected by
|
|
@markdewing, this bug has existed since the earliest days of QMCPACK. The stochastic rotations used to randomly reorient the
|
|
integration grids for the non-local pseudopoptentials would not cover the full sphere unless they had many points and sufficient
|
|
symmetry, as was the case for the QMCPACK default. However, calculations with custom integration grids with only a few points
|
|
(small `nrule`) could show error or excess statistical noise in the non-local part of the pseudopotential energy. Standard
|
|
calculations and tests on carbon diamond, lithium hydride, and hydrocarbon molecules were not affected due to QMCPACK's
|
|
conservative defaults. Tests updated in [\#4383](https://github.com/QMCPACK/qmcpack/pull/4383)
|
|
* NLPP grid randomization can be disabled for debugging and greater reproducibility [\#4394](https://github.com/QMCPACK/qmcpack/pull/4394)
|
|
* Two-body Jastrow support for true 2D calculations [\#4289](https://github.com/QMCPACK/qmcpack/pull/4289) (contributed by @Paul-St-Young)
|
|
* Fix for very large calculations requesting too large grids in CUDA spline implementation [\#4421](https://github.com/QMCPACK/qmcpack/pull/4421) (contributed by @pwang234)
|
|
* Bugfix in the batched OpenMP offload implementation memory errors [\#4408](https://github.com/QMCPACK/qmcpack/pull/4408) when the
|
|
number of splines is not a perfectly aligned size (multiple of 8 single precision or 4 double precision).
|
|
* Updates to test tolerances for many build types and platforms to improve reliability of deterministic tests. Goal: `ctest -L
|
|
deterministic` should pass on all platforms. Please report any failures.
|
|
* Improved CMake configuration including detecting use of parallel HDF5 in non-MPI builds
|
|
[\#4420](https://github.com/QMCPACK/qmcpack/pull/4420) and detection of missing OpenMP support
|
|
[\#4422](https://github.com/QMCPACK/qmcpack/pull/4422)
|
|
* Optimization of spinor wavefunctions with spin-orbit and pseudopotentials re-enabled
|
|
[\#4418](https://github.com/QMCPACK/qmcpack/pull/4418)
|
|
* QMCPACK output now indicates status of QMC_COMPLEX [\#4412](https://github.com/QMCPACK/qmcpack/pull/4412)
|
|
* Initial work for eventual GPU offloading of Gaussian basis wavefunctions for molecules and solids
|
|
[\#4407](https://github.com/QMCPACK/qmcpack/pull/4407)
|
|
* Bugfix to support one-body Jastrow functions where only a subset of elements is given
|
|
[\#4405](https://github.com/QMCPACK/qmcpack/pull/4405)
|
|
* Electron coordinates are printed in case a NaN is detected [\#4401](https://github.com/QMCPACK/qmcpack/pull/4401)
|
|
* To evade support problems for complex reductions in OpenMP offload compilers, real builds no longer reference any complex
|
|
reductions [\#4379](https://github.com/QMCPACK/qmcpack/pull/4379)
|
|
* Enabled HIP as language in CMake (requires >= 3.21) [\#3646](https://github.com/QMCPACK/qmcpack/pull/3646). When using HIP
|
|
targeting AMD GPUs, replace HIP_ARCH with CMAKE_HIP_ARCHITECTURES if HIP_ARCH was used to specify the GPU architectures.
|
|
* Refinements to SYCL usage, e.g., [\#4384](https://github.com/QMCPACK/qmcpack/pull/4384),
|
|
[\#4382](https://github.com/QMCPACK/qmcpack/pull/4382), [\#4380](https://github.com/QMCPACK/qmcpack/pull/4380)
|
|
* Many expanded tests including for NLPP parameter derivatives [\#4394](https://github.com/QMCPACK/qmcpack/pull/4394), more boundary
|
|
conditions in distance tables [\#4374](https://github.com/QMCPACK/qmcpack/pull/4374), for reptation Monte Carlo observables
|
|
[\#4327](https://github.com/QMCPACK/qmcpack/pull/4327), and orbital rotations
|
|
[\#4304](https://github.com/QMCPACK/qmcpack/pull/4304)
|
|
* Many updates to HDF5 usage including adoption of HDF5 1.10 API [\#4352](https://github.com/QMCPACK/qmcpack/pull/4352) and
|
|
related cleanup, e.g. [\#4300](https://github.com/QMCPACK/qmcpack/pull/4300)
|
|
* Initial Perlmutter CPU build recipe [\#4398](https://github.com/QMCPACK/qmcpack/pull/4398)
|
|
* Initial ALCF Sunspot build recipe including offloading to Intel Ponte Vecchio/Xe HPC GPU
|
|
[\#4391](https://github.com/QMCPACK/qmcpack/pull/4391)
|
|
* Better support for FreeBSD [\#4416](https://github.com/QMCPACK/qmcpack/pull/4416)
|
|
* Minimum supported Intel classic compiler version is 2021.1. [\#4389](https://github.com/QMCPACK/qmcpack/pull/4389)
|
|
* Ongoing improvement to orbital optimization and rotation, e.g. [\#4288](https://github.com/QMCPACK/qmcpack/pull/4288), [\#4402](https://github.com/QMCPACK/qmcpack/pull/4402)
|
|
* Ongoing code cleanup, e.g. [\#4276](https://github.com/QMCPACK/qmcpack/pull/4276),
|
|
[\#4275](https://github.com/QMCPACK/qmcpack/pull/4275), [\#4273](https://github.com/QMCPACK/qmcpack/pull/4273)
|
|
* Updated bmpi3 MPI "wrapper"
|
|
* Various other small bug fixes and quality of life improvements. See the full list of merged PRs on GitHub for details.
|
|
|
|
### Known problems
|
|
|
|
* When offload builds are compiled with CUDA toolkit versions above 11.2 (tested 11.3-11.8) using LLVM15, multideterminant tests and
|
|
functionality will fail, seemingly due to an issue with the toolkit. This is discussed in
|
|
https://github.com/llvm/llvm-project/issues/54633 . All other functionality appears to work as expected. As a workaround, the CUDA
|
|
toolkit 11.2 can be used. The actual NVIDIA drivers can be more recent.
|
|
* CUDA toolkit version 12.0 is not compatible with LLVM OpenMP offload https://github.com/llvm/llvm-project/issues/60296
|
|
|
|
### NEXUS
|
|
|
|
* Nexus: Support for use of templates for job submission scripts [\#4344](https://github.com/QMCPACK/qmcpack/pull/4344)
|
|
* Nexus: twist_info.dat files now added to results directory for easier analysis of twist average quantities
|
|
[\#4302](https://github.com/QMCPACK/qmcpack/pull/4302)
|
|
* Nexus: Initial support for Polaris at ALCF [\#4354](https://github.com/QMCPACK/qmcpack/pull/4354)
|
|
* Nexus: Initial support for Perlmutter at NERSC [\#4356](https://github.com/QMCPACK/qmcpack/pull/4356)
|
|
* Nexus: Support for gpusharing keyword for legacy CUDA [\#4403](https://github.com/QMCPACK/qmcpack/pull/4403)
|
|
* Nexus: Support for handling multiple pickle protocols [\#4385](https://github.com/QMCPACK/qmcpack/pull/4385)
|
|
* Nexus: CPU/GPU flags for batched code [\#4341](https://github.com/QMCPACK/qmcpack/pull/4341)
|
|
* Nexus: Jastrow factors can be read from existing files [\#4339](https://github.com/QMCPACK/qmcpack/pull/4339)
|
|
* Nexus: Fix VASP POSCAR write [\#4331](https://github.com/QMCPACK/qmcpack/pull/4331)
|
|
* Nexus: Better handling of VASP pseudopotentials [\#4330](https://github.com/QMCPACK/qmcpack/pull/4330)
|
|
|
|
### Known problems
|
|
|
|
* The new QE7.1 DFT+U input style is not yet supported [\#4100](https://github.com/QMCPACK/qmcpack/issues/4100)
|
|
|
|
## [3.15.0] - 2022-09-29
|
|
|
|
This is a recommended release for all users. There are many quality of life
|
|
improvements, bugfixes throughout the application, and updates to the associated
|
|
testing. Thanks to everyone who reported an issue or suggested an improvement.
|
|
|
|
We are working to make the performance portable "batched drivers" the default in
|
|
an upcoming version. These support execution on CPUs and multiple GPU
|
|
architectures with high performance. Most standard QMC calculations and many
|
|
observables are already supported. Because some changes to the input files will
|
|
be required, we recommend trying these drivers now and reporting any issues.
|
|
|
|
* Important bug fix to excited states in splines when spin-up/down sets are
|
|
built from the same spin species and occupation is specified on the first sposet
|
|
[\#4158](https://github.com/QMCPACK/qmcpack/pull/4158)
|
|
* The Quantum ESPRESSO converter, pw2qmcpack is now supported via a plugin
|
|
activated via -DQE_ENABLE_PLUGINS=pw2qmcpack on the QE CMake configure line,
|
|
see
|
|
https://qmcpack.readthedocs.io/en/develop/installation.html#quantum-espresso-7-0
|
|
. The latest QE 7.1 and earlier 7.0 are supported, and new versions should be
|
|
automatically compatible.
|
|
* Substantial improvements to the performance portable / batched implementation.
|
|
Using LLVM 15.0, high performance production calculations can be performed on
|
|
NVIDIA GPUs for several wavefunction types, in addition to running on all CPU
|
|
systems.
|
|
* As introduced in v3.14.0, the optional project data input parameter
|
|
`driver_version` specifies whether legacy or batched drivers are used. In
|
|
future versions of QMCPACK this tag will be required to avoid ambiguity and
|
|
allow e.g. the batched VMC driver to be obtained via `vmc` in addition to
|
|
`vmc_batch`. See
|
|
https://qmcpack.readthedocs.io/en/develop/methods.html#transition-from-classic-drivers
|
|
* Non-local pseudopotential energy contributions are consistently included in the
|
|
objective function used for optimization, improving convergence and achievable wavefunction quality
|
|
e.g. [\#4177](https://github.com/QMCPACK/qmcpack/pull/4177)
|
|
* Support for multistep wavefunction optimization, specifying different
|
|
parameter sets to be frozen at each step.
|
|
[\#4169](https://github.com/QMCPACK/qmcpack/pull/4169)
|
|
* Parameter filtration during optimization based on statistical uncertainties
|
|
[\#4126](https://github.com/QMCPACK/qmcpack/pull/4126)
|
|
* Support for 2D HEG calculations (e.g. [\#4084](https://github.com/QMCPACK/qmcpack/pull/4084) )
|
|
* Pseudopotential non-local channel can be specified in input [\#4032](https://github.com/QMCPACK/qmcpack/pull/4032)
|
|
* Use of deprecated CUDA texture API removed for greater compatibility [\#4022](https://github.com/QMCPACK/qmcpack/pull/4022)
|
|
* Optimization has been removed from the legacy CUDA code. New calculations
|
|
needing GPU support should use the batched drivers and their GPU capabilities
|
|
for optimization. [\#4138](https://github.com/QMCPACK/qmcpack/pull/4138)
|
|
* Initial version of determinant update in SYCL for Intel architectures (e.g.
|
|
[\#4118](https://github.com/QMCPACK/qmcpack/pull/4118) )
|
|
* Updated walker counts in several of the performance tests. Due to the changed
|
|
but more representative workloads, new performance timings should not be
|
|
compared with older runs (e.g. [\#4112](https://github.com/QMCPACK/qmcpack/pull/4112) )
|
|
* Maximum system sizes run in the performance tests can be specified in CMake
|
|
via QMC_PERFORMANCE_NIO_MAX_ATOMS, QMC_PERFORMANCE_C_GRAPHITE_MAX_ATOMS, and
|
|
QMC_PERFORMANCE_C_MOLECULE_MAX_ATOMS (e.g. [\#4134](https://github.com/QMCPACK/qmcpack/pull/4134) )
|
|
* Readability refinements in the output, e.g. [\#4149](https://github.com/QMCPACK/qmcpack/pull/4149)
|
|
* UHF/UKS support in PySCF converter [\#4089](https://github.com/QMCPACK/qmcpack/pull/4089)
|
|
* Example installation scripts for more machines placed in config directory, including Archer2, and Polaris.
|
|
* Many improvements in testing including additional tests, better reliability, and bug fixes.
|
|
* Minimum version of CMake is now v3.17.0 for CPU builds. For GPU builds, more
|
|
recent versions may be required. Use of the latest CMake version is generally
|
|
recommended.
|
|
* Minimum CUDA version is 11.0 [\#3957](https://github.com/QMCPACK/qmcpack/pull/3957)
|
|
* Minimum version of GCC is now v9.
|
|
|
|
### NEXUS
|
|
|
|
* Nexus: support to current batched driver style. Example inputs for batched
|
|
runs using trial wavefunctions from QE are included in
|
|
examples/qmcpack/rsqmc_quantum_espresso
|
|
[\#4246](https://github.com/QMCPACK/qmcpack/pull/4246)
|
|
* Nexus: add override_vp_parameters element
|
|
[\#4245](https://github.com/QMCPACK/qmcpack/pull/4245)
|
|
* Nexus: fix convert4qmc hdf5 issue
|
|
[\#4243](https://github.com/QMCPACK/qmcpack/pull/4243)
|
|
* Nexus: extend angular channels for pseudopotentials up to l_max=21
|
|
[\#4148](https://github.com/QMCPACK/qmcpack/pull/4148)
|
|
* Nexus: Pass PYTHONPATH recorded at cmake step to nxs-test to ensure tests run
|
|
[\#3935](https://github.com/QMCPACK/qmcpack/pull/3935)
|
|
* Nexus: Support for VASP keywords to version 6.3
|
|
[\#4056](https://github.com/QMCPACK/qmcpack/pull/4056)
|
|
* Nexus: Adding docs for limiting the number of simultaneously submitted jobs to
|
|
a queue [\#4133](https://github.com/QMCPACK/qmcpack/pull/4133)
|
|
|
|
## [3.14.0] - 2022-04-06
|
|
|
|
This release focuses on performance improvements to the OpenMP target offload version for GPUs as well as ongoing minor
|
|
improvements. The new GPU implementation rivals the legacy CUDA version for performance for broad range of problems
|
|
while offering more functionality, such as three body Jastrow functions. Developers are very interested in feedback from
|
|
users about the new version and will prioritize developments based on comments received. A new driver\_version switch is
|
|
introduced, currently optional, to disambiguate between the versions and their inputs.
|
|
|
|
* New global driver\_version switch to select between batched and legacy codes. This will become a required input tag in the next major release series of QMCPACK, but remains optional in 3.x versions [\#3897](https://github.com/QMCPACK/qmcpack/pull/3897)
|
|
* Optimization of block sizes in GPU offload kernels [\#3910](https://github.com/QMCPACK/qmcpack/pull/3910)
|
|
* GPU Offload of one-body Jastrow ratio calculation in pseudopotential evaluation [\#3905](https://github.com/QMCPACK/qmcpack/pull/3905)
|
|
* GPU Offload of some Coulomb potential evaluations [\#3842](https://github.com/QMCPACK/qmcpack/pull/3842)
|
|
* Partial GPU offload of multideterminant evaluation e.g. [\#3892](https://github.com/QMCPACK/qmcpack/pull/3892)
|
|
* Increased performance via more selective distance table computation [\#3846](https://github.com/QMCPACK/qmcpack/pull/3846)
|
|
* Improved performance on AMD GPUs via rocSOLVER integration [\#3756](https://github.com/QMCPACK/qmcpack/issues/3756)
|
|
* HIP build options shown in output [\#3919](https://github.com/QMCPACK/qmcpack/pull/3919)
|
|
* Documentation improvements, particularly relating to installation.
|
|
* Various bug fixes and ongoing cleanup.
|
|
|
|
### NEXUS
|
|
|
|
* Nexus: proper use of max\_seconds in legacy drivers [\#3877](https://github.com/QMCPACK/qmcpack/pull/3877)
|
|
|
|
## [3.13.0] - 2022-02-16
|
|
|
|
### Notes
|
|
|
|
This release incorporates support for trial wavefunctions from Quantum ESPRESSO 7.0 and adds GPAW support for the first
|
|
time. Non-local pseudopotential derivatives are fully supported in the optimizer and recommended in standard calculations.
|
|
Numerous minor bug fixes, test and installation improvements have been made. Behind the scenes updates include
|
|
maturation of the OpenMP target offload implementation and the batched drivers, a partial implementation of fast force
|
|
calculations, and ongoing modernization of the code. This is a recommended release for all users.
|
|
|
|
* Support for Quantum ESPRESSO (QE) 7.0 [\#3683](https://github.com/QMCPACK/qmcpack/pull/3683)
|
|
* Support for GPAW and GPAW to QMCPACK converter [\#3490](https://github.com/QMCPACK/qmcpack/issues/3490)
|
|
* use_nonlocalpp_deriv is fully supported and preferred in optimization [\#3785](https://github.com/QMCPACK/qmcpack/pull/3785) and others.
|
|
* Save and restore of variational parameters during optimization [\#3640](https://github.com/QMCPACK/qmcpack/pull/3640)
|
|
* Twist attribute takes precedence over twistnum. Twist is preferred specification. [\#3799](https://github.com/QMCPACK/qmcpack/pull/3799)
|
|
* Fixed inconsistent twist directions between electron gas and spline wavefunctions [\#1386](https://github.com/QMCPACK/qmcpack/issues/1386)
|
|
* Fixed reported Madelung constant in CoulombPBCAA [\#3806](https://github.com/QMCPACK/qmcpack/pull/3806)
|
|
* More robust computation of reference ion-ion Coulomb energy [\#3763](https://github.com/QMCPACK/qmcpack/pull/3763)
|
|
* Expanded test set, including more coverage of plane-wave basis sets and complex molecules [\#3105](https://github.com/QMCPACK/qmcpack/issues/3105), [\#3822](https://github.com/QMCPACK/qmcpack/issues/3822)
|
|
* More consistent python invocations [\#3680](https://github.com/QMCPACK/qmcpack/issues/3680)
|
|
* Builds with OpenMP disabled (QMC\_OMP=0) again supported [\#3723](https://github.com/QMCPACK/qmcpack/pull/3723)
|
|
* Modernization of HDF5 usage e.g. [\#3705](https://github.com/QMCPACK/qmcpack/pull/3705)
|
|
* Minimum supported Intel classic compiler version is 19.1. [\#3747](https://github.com/QMCPACK/qmcpack/pull/3747)
|
|
* Various minor bug fixes and ongoing code cleanup.
|
|
|
|
### NEXUS
|
|
|
|
* Nexus: Add --user $USER to squeue command [\#3796](https://github.com/QMCPACK/qmcpack/pull/3796)
|
|
* Nexus: Add Example and tests for qdens-radial tool [\#3676](https://github.com/QMCPACK/qmcpack/pull/3676)
|
|
* Nexus: Add Lowdin example [\#3666](https://github.com/QMCPACK/qmcpack/pull/3666)
|
|
* Nexus: Fixed Nexus 'install' target [\#3720](https://github.com/QMCPACK/qmcpack/issues/3720)
|
|
* Nexus: Harden Nexus excitation checks [\#3729](https://github.com/QMCPACK/qmcpack/pull/3729)
|
|
* Nexus: Small fix to excitation checks [\#3701](https://github.com/QMCPACK/qmcpack/pull/3701)
|
|
* Nexus: Faster configuration time [\#3706](https://github.com/QMCPACK/qmcpack/pull/3706)
|
|
|
|
## [3.12.0] - 2021-12-08
|
|
|
|
### Notes
|
|
|
|
This release incorporates several hundred changes to QMCPACK and the supporting
|
|
ecosystem. It is a recommended release for all users. Note that compilers
|
|
supporting C++17 and CMake version 3.15 or newer are now required. Changes
|
|
include newly added support for the DIRAC quantum chemistry code, the RMG-DFT
|
|
code, and updates for the latest version of Quantum ESPRESSO. Through DIRAC it
|
|
is now possible to perform highly accurate molecular calculations incorporating
|
|
spin-orbit with multideterminant trial wavefunctions. Behind the scenes updates
|
|
include increased checking of inputs, fixes to many edge case bugs, and removal
|
|
of memory leaks in both QMCPACK and the various converters. In readiness for
|
|
transition to the new batched drivers that support both CPU and GPU execution,
|
|
more features are supported and performance improved. Test coverage and
|
|
robustness is improved in all areas. For developers, tests, sanitizers, and code
|
|
coverage are now run on Pull Requests using GitHub Actions.
|
|
|
|
* To aid coexistence of real and complex builds, the qmcpack executable is now named qmcpack_complex for builds with QMC_COMPLEX=1
|
|
* Added DIRAC converter and support for MSD wave functions [\#3510](https://github.com/QMCPACK/qmcpack/pull/3510)
|
|
* Spin-Orbit implementation completed [\#1770](https://github.com/QMCPACK/qmcpack/issues/1770)
|
|
* Quantum ESPRESSO (QE) v6.8 support [\#3301](https://github.com/QMCPACK/qmcpack/pull/3301)
|
|
* Support for RMG DFT code [\#3351](https://github.com/QMCPACK/qmcpack/pull/3351)
|
|
* CMake 3.15 minimum required [\#3492](https://github.com/QMCPACK/qmcpack/pull/3492)
|
|
* C++17 is required [\#3348](https://github.com/QMCPACK/qmcpack/pull/3348)
|
|
* CMake CUDA support uses modern FindCUDAToolkit [\#3460](https://github.com/QMCPACK/qmcpack/issues/3460)
|
|
* Support latest Sphinx-contrib BibTeX 2.x [\#3176](https://github.com/QMCPACK/qmcpack/issues/3176)
|
|
* One Body Density Matrices supported in batched drivers [\#3622](https://github.com/QMCPACK/qmcpack/pull/3622)
|
|
* Batched performant Slater matrix inverses [\#3470](https://github.com/QMCPACK/qmcpack/pull/3470)
|
|
* Safeguards for requesting more orbitals than the input h5 provide [\#2341](https://github.com/QMCPACK/qmcpack/issues/2341)
|
|
* Implemented One-body spin-dependent Jastrow [\#3257](https://github.com/QMCPACK/qmcpack/pull/3257)
|
|
* Fixes for low particle counts, such as using a two body Jastrow with more than 2 particle types but only one particle of each type [\#3137](https://github.com/QMCPACK/qmcpack/issues/3137)
|
|
* ppconvert is built by default [\#3143](https://github.com/QMCPACK/qmcpack/pull/3143)
|
|
* Documentation on revised input format where SPO sets are created outside the determinant [\#3456](https://github.com/QMCPACK/qmcpack/issues/3456)
|
|
|
|
### NEXUS
|
|
|
|
* Add Density functionality to qdens tool [\#3541](https://github.com/QMCPACK/qmcpack/pull/3541)
|
|
* Add new qdens-radial tool for radial analysis of densities [\#3587](https://github.com/QMCPACK/qmcpack/pull/3587)
|
|
* Radial density of requested species only [\#3099](https://github.com/QMCPACK/qmcpack/pull/3099)
|
|
* Extend structure plotting capabilities for 2D materials [\#3220](https://github.com/QMCPACK/qmcpack/pull/3220)
|
|
* Support grand-canonical twist averaging [\#3153](https://github.com/QMCPACK/qmcpack/pull/3153)
|
|
* Extend excitations to allow 'lowest' gap [\#3628](https://github.com/QMCPACK/qmcpack/pull/3628)
|
|
* Allow singlet/triplet excitation types [\#2290](https://github.com/QMCPACK/qmcpack/pull/2290)
|
|
* Allow bandstructure plotting with custom k-path [\#3293](https://github.com/QMCPACK/qmcpack/pull/3293)
|
|
* Generate PySCF inputs without a template [\#3550](https://github.com/QMCPACK/qmcpack/pull/3550)
|
|
* Add punch extension for GAMESS analysis [\#3433](https://github.com/QMCPACK/qmcpack/pull/3433)
|
|
* Read pseduopotentials in numhf format (Eric Shirley's numerical HF code) [\#3097](https://github.com/QMCPACK/qmcpack/pull/3097)
|
|
* Add L2 generation functionality [\#3079](https://github.com/QMCPACK/qmcpack/pull/3079)
|
|
* Support QMCPACK batched drivers [\#2901](https://github.com/QMCPACK/qmcpack/pull/2901)
|
|
* Make qdens test more informative [\#3593](https://github.com/QMCPACK/qmcpack/pull/3593)
|
|
* Resource lock Nexus examples for reliable parallel execution [\#3585](https://github.com/QMCPACK/qmcpack/pull/3585)
|
|
* Support running tests without mpirun available [\#3584](https://github.com/QMCPACK/qmcpack/pull/3584)
|
|
* Small fix for custom band plotting [\#3566](https://github.com/QMCPACK/qmcpack/pull/3566)
|
|
* Improve error handling for bad Jastrow requests [\#3554](https://github.com/QMCPACK/qmcpack/pull/3554)
|
|
* Fix sizing problem in some single atom workflows [\#3553](https://github.com/QMCPACK/qmcpack/pull/3553)
|
|
* Fix syntax warnings [\#3497](https://github.com/QMCPACK/qmcpack/pull/3497)
|
|
* Fix convert4qmc usage [\#3495](https://github.com/QMCPACK/qmcpack/pull/3495)
|
|
* Verify cif2cell is available before running ntest\_nexus\_structure [\#3511](https://github.com/QMCPACK/qmcpack/pull/3511)
|
|
* Fix to add\_L2 function in pseudopotential.py [\#3386](https://github.com/QMCPACK/qmcpack/pull/3386)
|
|
* Expand eshdf features [\#3334](https://github.com/QMCPACK/qmcpack/pull/3334)
|
|
* Add delay\_rank input [\#3218](https://github.com/QMCPACK/qmcpack/pull/3218)
|
|
* Add max\_seconds input [\#3159](https://github.com/QMCPACK/qmcpack/pull/3159)
|
|
* Add Tref \(initial tilematrix\) argument to optimal\_tilematrix [\#3141](https://github.com/QMCPACK/qmcpack/pull/3141)
|
|
* Use OS environment by default [\#3108](https://github.com/QMCPACK/qmcpack/pull/3108)
|
|
|
|
## [3.11.0] - 2021-04-09
|
|
|
|
### Notes
|
|
|
|
This release includes a large number of refinements to QMCPACK and the supporting ecosystem. These include support for the latest version of
|
|
Quantum ESPRESSO, new capabilities in AFQMC, space-warp transformation for forces, numerous bug fixes, user-requested feature improvements,
|
|
and further upgrades to the test system.
|
|
|
|
* Quantum ESPRESSO (QE) v6.7 support. [\#2927](https://github.com/QMCPACK/qmcpack/pull/2927).
|
|
* Detect and automatically use patched version of QE found on the PATH. [\#2974](https://github.com/QMCPACK/qmcpack/pull/2974).
|
|
* Support for global max\_seconds and STOP file to cleanly halt QMCPACK during a run. [\#3028](https://github.com/QMCPACK/qmcpack/pull/3028).
|
|
* Freezing of two-body Jastrow parameters in optimization works. [\#2814](https://github.com/QMCPACK/qmcpack/issues/2814).
|
|
* Multideterminant code now works with only alpha determinants \(no down electrons\). [\#2698](https://github.com/QMCPACK/qmcpack/issues/2698).
|
|
* High l-momentum channels as local channels in ECPs work. [\#2920](https://github.com/QMCPACK/qmcpack/pull/2920).
|
|
* Space Warp Transformation for ZVZB Forces. [\#2828](https://github.com/QMCPACK/qmcpack/pull/2828).
|
|
* Important bug fixes in legacy CUDA implementation causing incorrect energies. [\#2883](https://github.com/QMCPACK/qmcpack/pull/2883).
|
|
* Implemented DLA in legacy CUDA. [\#2887](https://github.com/QMCPACK/qmcpack/pull/2887).
|
|
* Updates to support CUDA 11.2.1 e.g. [\#2950](https://github.com/QMCPACK/qmcpack/pull/2950).
|
|
* AFQMC supports energy estimator with different Hamiltonian \(from propagation\). [\#2795](https://github.com/QMCPACK/qmcpack/pull/2795).
|
|
* Trial wavefunction optimization with spin-orbit supported. [\#3034](https://github.com/QMCPACK/qmcpack/pull/3034).
|
|
* ppconvert executable automatically built when configured. [\#2904](https://github.com/QMCPACK/qmcpack/pull/2904).
|
|
* Tests added for ppconvert. [\#2929](https://github.com/QMCPACK/qmcpack/issues/2929).
|
|
* Fixed SIMD alignment for AVX512 on some systems. [\#2981](https://github.com/QMCPACK/qmcpack/pull/2981).
|
|
* Improved wavefunction restart logic in AFQMC. [\#2942](https://github.com/QMCPACK/qmcpack/pull/2942).
|
|
* Spin-density supported in batched code. [\#2840](https://github.com/QMCPACK/qmcpack/pull/2840).
|
|
* Reduced I/O operations during cmake. [\#2808](https://github.com/QMCPACK/qmcpack/pull/2808).
|
|
* Improved detection of unsupported-by-Intel combinations of Intel compilers and libstdc++. [\#2794](https://github.com/QMCPACK/qmcpack/pull/2794).
|
|
* Initial support for Andes at OLCF. [\#3073](https://github.com/QMCPACK/qmcpack/pull/3073).
|
|
* Deterministic tests expanded in scope and made reliable for more build types and compilers.
|
|
* Various minor bug fixes and feature improvements based on user requests for both real-space and AFQMC.
|
|
* Improved error handling throughout.
|
|
* Numerous performance improvements, expansion of tests, and bug fixes to the batched VMC and DMC codes. Reasonable but not optimal GPU acceleration can now be achieved for spline-based wavefunctions.
|
|
|
|
### NEXUS
|
|
|
|
* Support AMD nodes on Cori. [\#2809](https://github.com/QMCPACK/qmcpack/pull/2809).
|
|
* Interface for RMG code. [\#2932](https://github.com/QMCPACK/qmcpack/pull/2932).
|
|
* Added h-channel to list of possible local channels in pseudopotential. [\#2915](https://github.com/QMCPACK/qmcpack/pull/2915).
|
|
* Allow non spin-specific occupations in case of noncollinear. [\#2957](https://github.com/QMCPACK/qmcpack/pull/2957).
|
|
* More robust handling of QE output when printed eigenvalues touch. [\#3042](https://github.com/QMCPACK/qmcpack/pull/3042).
|
|
* Fixed type check for reblock\_factors in qmc-fit. [\#2830](https://github.com/QMCPACK/qmcpack/pull/2830).
|
|
* Fixed a Jastrow read error/warning, add several QE inputs. [\#2819](https://github.com/QMCPACK/qmcpack/pull/2819).
|
|
* Fixed tests on Summit. [\#2983](https://github.com/QMCPACK/qmcpack/pull/2983).
|
|
* Fixed module overwrite bug in qmca. [\#2802](https://github.com/QMCPACK/qmcpack/pull/2802).
|
|
|
|
## [3.10.0] - 2020-11-10
|
|
|
|
### Notes
|
|
|
|
This release contains multiple feature improvements and bug fixes. The AFQMC implementation has been significantly enhanced, and
|
|
an important wavefunction optimization bug fixed in real space QMC.
|
|
|
|
* The QMCPACK manual is now available at https://qmcpack.readthedocs.io, having been converted to use reStructuredText and the sphinx
|
|
documentation system.
|
|
* Significant improvements to the AFQMC code including HIP support for AMD GPUs, updated documentation, and support for non-collinear calculations and spin-orbit k-point Hamiltonians
|
|
[\#2734](https://github.com/QMCPACK/qmcpack/pull/2734).
|
|
* Improved support for spin-orbit in real-space QMC including documentation [\#2733](https://github.com/QMCPACK/qmcpack/pull/2733).
|
|
* Important bug fix for wavefunction optimization in few electron systems such as isolated atoms. The bug would result in slow or no
|
|
convergence. Thanks to Jaron Krogel and Matus Dubecky for reports and reproducers.
|
|
[\#2496](https://github.com/QMCPACK/qmcpack/issues/2496).
|
|
* Implementation of L2 potentials and evaluation in DMC [\#1948](https://github.com/QMCPACK/qmcpack/pull/1948).
|
|
* Consistent with our two year support policy for open source compilers, libraries, and tooling, several version minimums have
|
|
been increased to either avoid bugs or to utilize new features.
|
|
* Clang 7 is the earliest supported Clang compiler. The latest release is recommended.
|
|
* Intel 2019 is the earliest supported Intel compiler. The latest release is recommended.
|
|
* Future releases of QMCPACK will require C++17. The current minimum is C++14.
|
|
* AoS builds are no longer supported. The code has been removed now that the default structures-of-arrays (SoA) build has
|
|
sufficiently broad capability.
|
|
* The default CUDA architecture is set to sm_70 (Volta).
|
|
* QMCPACK is built with ENABLE_TIMERS=ON by default [\#2663](https://github.com/QMCPACK/qmcpack/issues/2663)
|
|
* Various bug fixes to complete the transition to Python 3.
|
|
* Ongoing improvements to the OpenMP offload implementation.
|
|
|
|
### NEXUS
|
|
|
|
* NEXUS manual is now available at https://nexus-workflows.readthedocs.io, having been converted to use the reStructuredText and sphinx
|
|
documentation system.
|
|
* Various small fixes and improvements.
|
|
|
|
## [3.9.2] - 2020-04-29
|
|
|
|
### Notes
|
|
|
|
This is an important bug fix release. As described in [\#2330](https://github.com/QMCPACK/qmcpack/issues/2330), since v3.8.0 the
|
|
timestep was not correctly changed between different DMC blocks if the time step was changed in the input, biasing the results.
|
|
Runs using a single time step were not affected. Thanks to Chandler Bennett for identifying the problem.
|
|
|
|
* Bug fix: timestep was not correctly changed between DMC blocks if it was changed in the input [\#2330](https://github.com/QMCPACK/qmcpack/issues/2330).
|
|
* qmcfinitesize tool added [\#2329](https://github.com/QMCPACK/qmcpack/pull/2329).
|
|
* QMCPACK spack package now supports AFQMC [\#2237](https://github.com/QMCPACK/qmcpack/issues/2237).
|
|
* Improvements to deterministic tests: these are now fully reliable other than for some CUDA builds and some mixed precision CPU configurations.
|
|
* Many improvements to cmake configuration for faster builds, e.g. [\#2389](https://github.com/QMCPACK/qmcpack/pull/2389).
|
|
* Ongoing source cleanup and fewer compile-time warnings, e.g. [\#2375](https://github.com/QMCPACK/qmcpack/pull/2375).
|
|
|
|
## [3.9.1] - 2020-02-11
|
|
|
|
### Notes
|
|
|
|
This release is the same as v3.9.0 except that the version number of QMCPACK is reported correctly. See the v3.9.0 part of the CHANGELOG for important changes compared to v3.8.0.
|
|
|
|
## [3.9.0] - 2020-02-11
|
|
|
|
### Notes
|
|
|
|
This release includes a large number of refinements to improve or extend the functionality of QMCPACK and NEXUS. Importantly, this
|
|
release supports and requires Python 3. After this release we plan to remove the array-of-structures build configuration and also
|
|
the legacy CUDA implementation for GPUs. If any needed functionality is not supported by the now-default structures-of-arrays
|
|
configuration, users should contact the developers via the QMCPACK Google Groups or via an issue on the QMCPACK GitHub repository.
|
|
Work is ongoing to support dynamical spin variables, implement spin-orbit, and to develop new support for accelerators via a new
|
|
framework that will consistently support CPUs and GPUs from the same codebase.
|
|
|
|
* All uses of Python updated to Python 3, which is now required. Python 2 was retired at the end of 2019, and many packages
|
|
already only support Python 3.
|
|
* A greatly expanded selection of effective core potentials is available at
|
|
[https://pseudopotentiallibrary.org/](https://pseudopotentiallibrary.org/) in formats suitable for QMCPACK and common DFT and
|
|
quantum chemistry codes.
|
|
* All major functionality is now supported by the default structures-of-arrays (SoA) build. This release is the last to support the legacy array-of-structures (AoS)
|
|
build. See [\#861](https://github.com/QMCPACK/qmcpack/issues/861).
|
|
* Major bug identified and fixed in the periodic Coulomb evaluation (Optimized breakup method of Natoli-Ceperley). Many thanks to Jan Brndiar
|
|
and coworkers for reporting this. For large anisotropic supercells such as a graphene layer with substantial vacuum, the ion-ion potential was
|
|
incorrectly computed. Results in all bulk-like supercells tested so far have been accurate. An independent Ewald check of the ion-ion potential evaluation has been added. See
|
|
[\#2137](https://github.com/QMCPACK/qmcpack/pull/2137). The Coulomb potential evaluation has also been found to converge very slowly for certain
|
|
anisotropic supercells, particularly for quasi-2D cells where huge errors can result. The new independent Coulomb check will
|
|
abort if a tolerance is not reached and provide guidance. Research is ongoing to develop an improved methodology
|
|
[\#2185](https://github.com/QMCPACK/qmcpack/issues/2185).
|
|
* Support for periodic gaussian-based trial wavefunctions at complex k-points
|
|
[\#1988](https://github.com/QMCPACK/qmcpack/issues/1988).
|
|
* Determinant-localization approximation (DLA) of Zen et al. [J. Chem. Phys. 151, 134105
|
|
(2019)](https://doi.org/10.1063/1.5119729) for DMC non-local pseudopotential evaluation implemented.
|
|
* Improved force implementation [\#1769](https://github.com/QMCPACK/qmcpack/issues/1769), [\#1768](https://github.com/QMCPACK/qmcpack/issues/1768).
|
|
* Non-local pseudopotential derivatives are supported in the SoA build and recommended for all optimizations
|
|
[\#2083](https://github.com/QMCPACK/qmcpack/issues/2083).
|
|
* Above 192 electrons in a spin determinant, delayed updating with delay 32 is enabled by default for higher performance,
|
|
[\#2027](https://github.com/QMCPACK/qmcpack/pull/2027). Rank-1 updating is used by default for smaller determinants.
|
|
* Improved configuration and detection of Intel MKL and vector MKL when used with non-Intel compilers.
|
|
* QMCPACK will now run with wavefunctions where only electrons of a single spin are specified.
|
|
[\#2148](https://github.com/QMCPACK/qmcpack/pull/2148).
|
|
* AFQMC estimators now include 1 and 2 body reduced density matrices (1RRM, 2RDM) and on-top pair density.
|
|
[\#2097](https://github.com/QMCPACK/qmcpack/pull/2097).
|
|
* Dense real hamiltonian added for AFQMC allowing for GPU acceleration for chemistry applications. [\#2131](https://github.com/QMCPACK/qmcpack/pull/2131).
|
|
* [QMCPACK spack package](https://spack.readthedocs.io/en/latest/package_list.html#qmcpack) supports the latest release as well
|
|
as the development version. This package can also install and patch
|
|
Quantum Espresso.
|
|
* Support for Blue Gene removed due to retirement of this architecture.
|
|
* Many minor bug fixes, expanded testing, and small feature improvements.
|
|
|
|
### Known bugs
|
|
|
|
See [list of open bugs](https://github.com/QMCPACK/qmcpack/issues?q=is%3Aissue+is%3Aopen+label%3Abug).
|
|
|
|
* Use of reconfiguration in DMC is disabled since it is incorrect. [\#2254](https://github.com/QMCPACK/qmcpack/pull/2254)
|
|
|
|
### NEXUS
|
|
|
|
* NEXUS version is increased to 2.0.0 due to major updates in this release.
|
|
* NEXUS has been transitioned to Python 3 and now requires it.
|
|
* Significantly expanded test system to cover all major functionality.
|
|
* Full support for PySCF to QMCPACK and AFQMC workflows [\#1970](https://github.com/QMCPACK/qmcpack/pull/1970).
|
|
* Support for DLA [\#2061](https://github.com/QMCPACK/qmcpack/pull/2061).
|
|
* VMC optimization performed with NLPP derivatives by default [\#2128](https://github.com/QMCPACK/qmcpack/pull/2128).
|
|
* Many minor bugfixes and feature improvements.
|
|
|
|
## [3.8.0] - 2019-07-23
|
|
|
|
### Notes
|
|
|
|
This release includes Quantum Espresso v6.4.1 support, new examples
|
|
for adding wavefunctions and Jastrow functions, and many updates to the
|
|
AFQMC code functionality. Additionally, all the updated scripts and
|
|
functionality utilized during the [2019 QMCPACK
|
|
workshop](https://github.com/QMCPACK/qmcpack_workshop_2019) are
|
|
provided; this link also includes several new tutorials. A large
|
|
number of feature refinements, bugfixes, testing improvements and
|
|
source code cleanup have also been performed.
|
|
|
|
* Quantum Espresso v6.4.1 support [\#1732](https://github.com/QMCPACK/qmcpack/pull/1732).
|
|
* New tutorial for adding a simple wavefunction (He) [\#1621](https://github.com/QMCPACK/qmcpack/pull/1621).
|
|
* New tutorial and capability for adding Jastrow functors from symbolic expressions written in Python [\#1557](https://github.com/QMCPACK/qmcpack/pull/1557).
|
|
* [Updated compiler and library support policy](https://github.com/QMCPACK/qmcpack#prerequisites), and matching testing. We aim to support open source compilers and
|
|
libraries within two years of release. Use of older software is discouraged and untested. Support for closed source compilers over the same period may require use of an exact version.
|
|
* Many updates to AFQMC code to support more compilers and libraries.
|
|
* Newly expanded deterministic test set should now pass on all platforms and be usable as an.
|
|
installation check. Recommend to run "ctest -L deterministic" after building QMCPACK.
|
|
* AFQMC code now only reads HDF5 format data to improve I/O performance and storage utilization.
|
|
* K-point AFQMC code usable in production (e.g. bug fix [\#1524](https://github.com/QMCPACK/qmcpack/pull/1524)).
|
|
* Updated AFQMC workflow scripts for interfacing with PySCF.
|
|
* Faster initial cusp correction calculation for all-electron calculations, e.g. [\#1643](https://github.com/QMCPACK/qmcpack/pull/1643).
|
|
* Improved stability of cusp correction calculation [\#1594](https://github.com/QMCPACK/qmcpack/pull/1594).
|
|
* New short-ranged e-n Jastrow [\#1680](https://github.com/QMCPACK/qmcpack/pull/1680).
|
|
* Substantially faster 1-body reduced density matrix (1DRDM) estimator [\#1672](https://github.com/QMCPACK/qmcpack/pull/1672).
|
|
* Performance tests added for LCAO code and Gaussian basis sets [\#1639](https://github.com/QMCPACK/qmcpack/pull/1639).
|
|
* Reduced configuration output by default. Use -DQMC_VERBOSE_CONFIGURATION=1 on CMake line for greater detail.
|
|
* Partial support for forces in LCAO basis e.g. [\#1559](https://github.com/QMCPACK/qmcpack/pull/1559). See details given at
|
|
2019 QMCPACK Workshop and in manual.
|
|
* Improved human-readable Jastrow output [\#1525](https://github.com/QMCPACK/qmcpack/pull/1525).
|
|
* Improved MPI implementation. QMCPACK is now compatible with OpenMPI v4.
|
|
* Majority of the manual has been professionally edited.
|
|
|
|
### Known bugs
|
|
|
|
See [list of open bugs](https://github.com/QMCPACK/qmcpack/issues?q=is%3Aissue+is%3Aopen+label%3Abug).
|
|
|
|
* There is a general problem with MVAPICH2 involving aligned memory allocations that will cause
|
|
QMCPACK to crash if MVAPICH is compiled using defaults. See [\#1703](https://github.com/QMCPACK/qmcpack/issues/1703) for details and workaround.
|
|
|
|
### NEXUS
|
|
|
|
* Examples added of PySCF molecular and solid-state workflows [\#1552](https://github.com/QMCPACK/qmcpack/pull/1552).
|
|
* Update support for Quantum Package 2.0 [\#1538](https://github.com/QMCPACK/qmcpack/pull/1538).
|
|
* Support for additional machines including SuperMUC-NG [\#1665](https://github.com/QMCPACK/qmcpack/pull/1665).
|
|
* Support for ghost atoms [\#1653](https://github.com/QMCPACK/qmcpack/pull/1653).
|
|
* Update outdated cubic specifier to alat for QE [\#1642](https://github.com/QMCPACK/qmcpack/pull/1642).
|
|
* K-point grids are symmetrized with spglib [\#1544](https://github.com/QMCPACK/qmcpack/pull/1544).
|
|
* Bundling of jobs at NERSC [\#1748](https://github.com/QMCPACK/qmcpack/pull/1748).
|
|
|
|
## [3.7.0] - 2019-03-29
|
|
|
|
### Notes
|
|
|
|
This release includes GPU support for the AFQMC implementation,
|
|
Quantum Espresso v6.4 support, and in the real-space code makes the
|
|
structure-of-arrays (SoA) code path the default. A large number of
|
|
feature refinements, bugfixes, testing improvements and source code
|
|
cleanup have been performed.
|
|
|
|
* The improved structures of arrays (SoA) build is now the
|
|
default. This is generally significantly faster and uses less memory
|
|
than the AoS build due to better algorithms, but does not yet have
|
|
the full range of functionality. The older AoS build can be selected
|
|
with -DENABLE_SOA=0.
|
|
* AFQMC code fully supports GPU acceleration via NVIDIA CUDA. Use -DENABLE_CUDA=1.
|
|
* Quantum Espresso v6.4 is supported. [\#1457](https://github.com/QMCPACK/qmcpack/pull/1457)
|
|
* Better error handling e.g. [\#1423](https://github.com/QMCPACK/qmcpack/issues/1423)
|
|
* Workarounds for MPI support on Summit. [\#1479](https://github.com/QMCPACK/qmcpack/pull/1479)
|
|
* ppconvert should be more reliable. [\#891](https://github.com/QMCPACK/qmcpack/issues/891)
|
|
* Delayed update implementation on GPUs. [\#1279](https://github.com/QMCPACK/qmcpack/pull/1279)
|
|
* Continued improvements to the testing system and test coverage. While still under
|
|
development, a new set of deterministic tests is intended to rapidly
|
|
and reliably test the code, with good coverage. Tests pass for real
|
|
and complex, but not yet mixed-precision or GPU builds.
|
|
* Source code has been formatted with clang-format for consistency throughout.
|
|
|
|
### Known Bugs
|
|
|
|
See [list of open bugs](https://github.com/QMCPACK/qmcpack/issues?q=is%3Aissue+is%3Aopen+label%3Abug).
|
|
|
|
* Theres is a bug that could result in an incorrect local
|
|
electron-ion pseudopotential energy with CUDA v9.1 and Kepler GPUs. This is still being
|
|
investigated. [\#1440](https://github.com/QMCPACK/qmcpack/issues/1440)
|
|
|
|
* QMCPACK will not build with OpenMPI v4 due to use of deprecated
|
|
functions. This will be addressed when the new MPI wrappers are
|
|
fully adopted. Older OpenMPI libraries are fully capable.
|
|
|
|
### NEXUS
|
|
|
|
* A collection of training material is at https://github.com/QMCPACK/nexus_training
|
|
* Improved generation of QMCPACK inputs. [\#1471](https://github.com/QMCPACK/qmcpack/pull/1471)
|
|
* Improved Gaussian Process optimization. [\#1498](https://github.com/QMCPACK/qmcpack/pull/1498)
|
|
* Updated Cori support. [\#1463](https://github.com/QMCPACK/qmcpack/pull/1463)
|
|
* Supercell tiling is more robust. [\#1432](https://github.com/QMCPACK/qmcpack/pull/1432)
|
|
* Summit support. [\#1394](https://github.com/QMCPACK/qmcpack/pull/1394)
|
|
* Improved handling of excited state calculations. [\#1365](https://github.com/QMCPACK/qmcpack/pull/1365)
|
|
* Fixed CHGCAR conversion. [\#1351](https://github.com/QMCPACK/qmcpack/pull/1351)
|
|
|
|
## [3.6.0] - 2018-12-19
|
|
|
|
### Notes
|
|
|
|
This release includes a completely new AFQMC implementation,
|
|
significant performance improvements for large runs, greater
|
|
functionality in the structure-of-arrays (SoA) code path, support for
|
|
larger spline data on multiple GPUs, and support for new machines and
|
|
compilers. The manual has been improved, bugs have been fixed, and
|
|
source code cleanup continued.
|
|
|
|
A C++14 and C99 capable compiler, Boost 1.61.0, and CMake 3.6 or
|
|
greater are now required.
|
|
|
|
* Completely updated AFQMC implementation including reduced scaling separable density
|
|
fitting https://arxiv.org/abs/1810.00284 Documentation and examples
|
|
will be added in v3.7.0. Contact the developers for use instructions
|
|
in the interim. [\#1245](https://github.com/QMCPACK/qmcpack/pull/1245)
|
|
|
|
* Implementation of delayed updates for CPU. Substantial speedups for
|
|
runs with 100s of electrons, with increasing gains at larger
|
|
electron counts. See manual for details. [\#1170](https://github.com/QMCPACK/qmcpack/pull/1170)
|
|
|
|
* Initial support for nested OpenMP to further reduce time-to-solution for large problems. [\#1082](https://github.com/QMCPACK/qmcpack/pull/1082)
|
|
|
|
* Support for splitting/distributing spline orbital data across multiple GPUs on a
|
|
single node. [\#1101](https://github.com/QMCPACK/qmcpack/pull/1101)
|
|
|
|
* Cusp correction for all electron calculations is implemented in the
|
|
SoA version. [\#1172](https://github.com/QMCPACK/qmcpack/pull/1172)
|
|
|
|
* Backflow is implemented in the SoA version. [\#1225](https://github.com/QMCPACK/qmcpack/pull/1225)
|
|
|
|
* K-points with real coefficients are supported in periodic LCAO. [\#1006](https://github.com/QMCPACK/qmcpack/pull/1006)
|
|
|
|
* Initial support for Summit at OLCF. Revisions may be needed in
|
|
January 2019 as the software stack is updated. This will be
|
|
addressed in a new version as required.
|
|
|
|
* Initial support for PGI compiler.
|
|
|
|
* Build instructions for ARM-based systems. [\#1148](https://github.com/QMCPACK/qmcpack/pull/1148)
|
|
|
|
* Setup scripts are python 2 and 3 compatible. [\#1261](https://github.com/QMCPACK/qmcpack/pull/1261)
|
|
|
|
* QMCPACK and NEXUS can now be installed by "make install" after
|
|
configuring CMake with CMAKE_PREFIX_PATH. [\#1020](https://github.com/QMCPACK/qmcpack/issues/1020)
|
|
|
|
* Significantly reworked test labeling and categorization system. [\#1155](https://github.com/QMCPACK/qmcpack/pull/1155)
|
|
|
|
* Partial transition to a new MPI wrapper implementation for greater compatibility.
|
|
|
|
* Utilities have been renamed for clarity and to avoid name collisions
|
|
with other applications. getSupercell is renamed
|
|
qmc-get-supercell. extract-eshdf-kvectors is renamed
|
|
qmc-extract-eshdf-kvectors.
|
|
|
|
### Known bugs
|
|
|
|
Several potentially significant bugs are outstanding and will be addressed in the
|
|
next release. See [list of open bugs](https://github.com/QMCPACK/qmcpack/issues?q=is%3Aissue+is%3Aopen+label%3Abug).
|
|
|
|
* LCAO (Gaussian basis) molecular calculations are incorrect with
|
|
certain diffusion functions. The reason for this bug is currently
|
|
unclear. [\#1145](https://github.com/QMCPACK/qmcpack/issues/1145)
|
|
|
|
* On NVIDIA Volta GPUs some runs show inconsistencies with the CPU
|
|
version. Standard carbon diamond and LiH tests pass with good agreement
|
|
with the CPU implementation. [\#1054](https://github.com/QMCPACK/qmcpack/issues/1054)
|
|
|
|
* QMCPACK will not build with OpenMPI v4.0.0 due to use of deprecated
|
|
functions. This will be addressed in the next version as the new MPI
|
|
wrappers are fully adopted. Older OpenMPI libraries are fully capable.
|
|
|
|
|
|
### NEXUS
|
|
|
|
* Interface to and support for PySCF. [\#1220](https://github.com/QMCPACK/qmcpack/pull/1220)
|
|
* Interface to and support for Quantum Package (QP). [\#1093](https://github.com/QMCPACK/qmcpack/pull/1093)
|
|
* Support for excited state calculations. [\#1200](https://github.com/QMCPACK/qmcpack/pull/1200)
|
|
* qfit is renamed qmc-fit.
|
|
* ntest, sim, redo are renamed nxs-test, nxs-sim, nxs-redo.
|
|
* Many smaller improvements.
|
|
|
|
## [3.5.0] - 2018-08-02
|
|
|
|
### Notes
|
|
|
|
This release includes support for the latest Quantum Espresso version 6.3,
|
|
an initial implementation of periodic Gaussian support via PySCF, and a new
|
|
version of the hybrid or "APW" representation of orbitals. Many minor
|
|
bugs have been fixed, configuration and documentation improved.
|
|
|
|
Note that the PDF manuals are no longer included with the source. Versions
|
|
are available online via https://qmcpack.org . The PDFs can be built
|
|
using manual/build_manual.sh and
|
|
nexus/documentation/user_guide_source/build_nexus_user_guide.sh
|
|
|
|
Attention developers: This version contains substantially fewer source
|
|
lines than previous versions due to clean out of old code and unused
|
|
execution paths. Refactoring to improve the internal structure of
|
|
QMCPACK is ongoing. Track the develop branch and follow discussion on
|
|
GitHub closely to avoid difficult merges.
|
|
|
|
* Support for Quantum Espresso 6.3 and 6.2.1. Check documentation to
|
|
ensure compiled with required HDF5 support.
|
|
* Support for periodic gaussians and PySCF generated
|
|
wavefunctions. Initial version is limited to Gamma-point.
|
|
* Improved hybrid representation of single particle orbitals
|
|
(APW-like) for significantly reduced memory usage and possible
|
|
accuracy increase compared to conventional spline representation. https://arxiv.org/abs/1805.07406
|
|
* Norms of orbitals are checked inside QMCPACK to catch conversion errors.
|
|
* Added verbosity setting to QMCPACK output.
|
|
* CUDA can now be enabled with SoA builds.
|
|
* Many improvements to QMCPACK manual, including all new features, CIPSI, 3-body
|
|
jastrow factor description, spack package, and enabling HTML generation.
|
|
* CMake configuration improvements, particularly around MKL handling.
|
|
* Extensive cleanup of unused source files and unused code paths
|
|
removed, reducing the number of source lines by over 30 percent.
|
|
|
|
### Known bugs
|
|
|
|
* Weight of first block of DMC density is incorrect in CPU
|
|
code. DMC densities in CUDA GPU code are incorrect for all
|
|
blocks. [\#934](https://github.com/QMCPACK/qmcpack/issues/934) and [\#925](https://github.com/QMCPACK/qmcpack/issues/925)
|
|
* Runs with only a single electron may crash. [\#945](https://github.com/QMCPACK/qmcpack/issues/945)
|
|
|
|
### NEXUS
|
|
|
|
* Support for GAMESS HDF5 workflows.
|
|
* Nexus accepts command line inputs.
|
|
* Nexus testing via ntest executable.
|
|
* Added GAMESS-NEXUS examples for RHF, CISD, and CASSCF wavefunction.
|
|
* Added support for -nojastrow workflows.
|
|
* Added support for Stampede supercomputer.
|
|
* Added script to build NEXUS user guide.
|
|
* Various bugfixes including to GAMESS input parsing.
|
|
|
|
## [3.4.0] - 2018-01-29
|
|
|
|
### Notes
|
|
|
|
This release includes size-consistent t-moves, and improvements to
|
|
load balancing and memory usage that will be visible in large
|
|
runs. Significant revisions have been made to the gaussian
|
|
wavefunction reader and a PySCF interface is in progress. A bug
|
|
affecting non-git installs (from release tarballs) is fixed. Feedback
|
|
is particularly welcome on the new features.
|
|
|
|
* Size consistent t-moves implemented (Casula 2010 algorithm).
|
|
Enabled via nonlocalmoves parameter, see manual.
|
|
* Bugfix: For non-git builds, build process failed on some systems
|
|
due to git-rev.h handling.
|
|
* Optimized load balancing in DMC. Command line option async_swap
|
|
removed. Parameter use_nonblocking now disables non-blocking MPI
|
|
load balancing. Non-blocking MPI is now enabled by default.
|
|
* Improved memory handling and usage in SoA code, increases
|
|
performance.
|
|
* Improved stability of GPU matrix inversion for large runs.
|
|
* Ongoing improvements to output to improve readability.
|
|
* Initial interface to PySCF for real space QMC trial wavefunctions.
|
|
* Enabled use of HDF5 files for Gaussian based wavefunctions
|
|
with SoA implementation.
|
|
* Added Appendix to manual listing all known QMCPACK publications.
|
|
This will be updated on an ongoing basis. Please advise of any
|
|
missing publications.
|
|
* Optimized momentum distribution estimator. Supported by SoA and
|
|
1,2,3-body Jastrow functions.
|
|
* Support for labeled timers in Intel VTune based profiling.
|
|
|
|
### NEXUS
|
|
|
|
* Minor bugfixes and improvements.
|
|
|
|
### Known limitations
|
|
|
|
* PySCF interface is preliminary. convert4qmc is updated, but manual
|
|
entries are not yet provided. This will be improved in later
|
|
versions. The interface is currently only for isolated molecular
|
|
systems. A full periodic implementation is in progress.
|
|
|
|
* Documentation, examples and tutorials are not yet consistent with
|
|
the updated converter convert4qmc.
|
|
|
|
## [3.3.0] - 2017-12-18
|
|
|
|
### Notes
|
|
|
|
This release includes new methods, converter updates, and many
|
|
optimizations, feature improvements, and bug fixes. It is a
|
|
recommended update for all users.
|
|
|
|
### QMCPACK updates
|
|
|
|
* Support for finite difference linear response (FDLR) method and
|
|
wavefunctions, developed and contributed by Nick Blunt and Eric
|
|
Neuscamman, see Journal of Chemical Physics 147, 194101 (2017),
|
|
https://doi.org/10.1063/1.4998197 and
|
|
https://arxiv.org/abs/1707.09439 .
|
|
* Major update to convert4qmc, conversion from GAMESS and other
|
|
gaussian basis set codes. HDF5 output is now supported for large
|
|
wavefunctions with -hdf5 option. Significantly improved example
|
|
inputs \*.qmc.in.xml.
|
|
* Gaussian based trial wavefunctions now supported by structure of
|
|
arrays implementation (ENABLE_SOA=1). A full reimplementation that
|
|
will also support gaussians in periodic boundary conditions, e.g.
|
|
from pyscf, is in progress.
|
|
* Initialization of multideterminant wavefunctions improved for faster
|
|
startup and lower memory usage. In practice this significantly
|
|
raises the usable maximum number of determinants.
|
|
* Maximum CPU time setting (maxcpusecs): QMC drivers will not
|
|
start a new block if there is not enough estimated time remaining to
|
|
complete the next block and gracefully shut down.
|
|
* Homogeneous electron gas wavefunction support and tests.
|
|
* New command line verbosity command line flag -verbosity. Output of
|
|
QMCPACK will be overhauled over the next few releases to
|
|
support low, high, and debug options, and also to significantly improve
|
|
readability and utility.
|
|
* Bugfix: Umrigar drift diffusion term is now consistent with the
|
|
Umrigar small time step error algorithm with complex wavefunctions.
|
|
* Bugfix: Momentum distribution is now correctly weighted and also
|
|
correctly signed for twist averaging.
|
|
* Renamed performance tests with atom and electron count.
|
|
* Removed support for "buffering" of non-local pseudopotential
|
|
wavefunction components during optimization (useBuffer setting) to
|
|
reduce memory usage and for simplicity.
|
|
* doxygen documentation for developer-level documentation of the code
|
|
and file structure. Produced via make in qmcpack/doxygen. HTML
|
|
currently published at http://docs.qmcpack.org/doxygen/doxy/
|
|
* Many minor bug fixes and improved tests.
|
|
|
|
### NEXUS
|
|
|
|
* Improved postprocessing support for Quantum Espresso.
|
|
* Various minor bug fixes.
|
|
|
|
### Known issues and limitations
|
|
|
|
* Documentation, examples and tutorials are not yet consistent with
|
|
the updated converter convert4qmc.
|
|
* Core functionality is largely compatible with ENABLE_SOA but
|
|
some specialized wavefunctions and observables are not.
|
|
* Use of GNU compilers with glibc 2.23 builds will crash due to a bug
|
|
in libmvec of glibc. The glibc version can be verified by
|
|
"ldd --version".
|
|
|
|
## [3.2.0] - 2017-09-21
|
|
|
|
### Notes
|
|
|
|
This release provides a significant speed increase for
|
|
many calculations. A C++11 compiler is now required. It is a
|
|
recommended update.
|
|
|
|
### QMCPACK updates
|
|
|
|
* Major speedup for calculations using spline wavefunctions via
|
|
initial implementation of "Structure of Arrays" data layout and
|
|
improved algorithms. Enabled via -DENABLE_SOA=1. Benefits all CPU
|
|
architectures. Many runs are doubled in speed. Not yet available for
|
|
Gaussian-basis sets or for all observables and QMC methods. See
|
|
writeup in manual for guidance.
|
|
* A compiler supporting C++11 is now required.
|
|
* DMC respects MaxCPUSecs parameter and will gracefully shut down and
|
|
not start a new block if there is not sufficient estimated time to
|
|
complete it.
|
|
* Checkpointing code rewritten for robustness and performance at scale.
|
|
Parallel as well as serial HDF5 supported and autodetected.
|
|
* Improved beta-release of AFQMC code and documentation.
|
|
* Backflow documentation and optimization tips added.
|
|
* Correlated sampling VMC drivers reactivated.
|
|
* Added carbon graphite performance test similar to CORAL benchmark.
|
|
* Improvements to CMake and CTest usage.
|
|
* Build instructions for NERSC, ALCF, and OLCF machines updated.
|
|
* Latest manual PDF now available at http://docs.qmcpack.org
|
|
|
|
### NEXUS
|
|
|
|
* Significantly improved manual entry for "qmca" analysis tool, the
|
|
main recommended tool for statistical analysis of QMCPACK data.
|
|
* Added time step fitting tool "qfit" for timestep extrapolation. Uses
|
|
jack-knife statistical technique.
|
|
* Improved density file postprocessing.
|
|
* Support for Makov-Payne corrections.
|
|
|
|
## [3.1.1] - 2017-08-01
|
|
|
|
### Notes
|
|
|
|
This is a bugfix release and recommended update.
|
|
|
|
### QMCPACK updates
|
|
|
|
* Added numerical tolerance to check of jastrow cutoff and Wigner Seitz
|
|
radius.
|
|
* CMake correctly configures when MPI is not present.
|
|
* Improved support for test coverage measurements.
|
|
* Added unit tests for some estimators.
|
|
|
|
### NEXUS
|
|
|
|
* IPython compatible exit handling (from Duy Le)
|
|
|
|
|
|
## [3.1.0] - 2017-06-21
|
|
|
|
### Notes
|
|
|
|
This release incorporates an improved DMC equilibration scheme,
|
|
numerous bugfixes, small improvements, and significantly improved
|
|
testing. It is a recommended update.
|
|
|
|
### QMCPACK updates
|
|
|
|
* Improved population control during DMC equilibration. Reduces variance on larger runs.
|
|
* Bugfix: Real valued wavefunction GPU code gave incorrect result for some non-gamma twists that could be made real, e.g. X point. Complex code (QMC_COMPLEX=1) was always correct.
|
|
* All particle move VMC and DMC algorithms enabled, tests added.
|
|
* Reptation Monte Carlo (RMC) enabled, tests added.
|
|
* Significantly improved AFQMC implementation.
|
|
* Added NiO based VMC and DMC performance tests and description in manual. Wavefunction files accessed via QMC_DATA.
|
|
* Added DMC tests with locality and t-moves approximations.
|
|
* Added AFQMC tests.
|
|
* Added test of real space QMC restart capabilities.
|
|
* Added tests for several estimators.
|
|
* Added unit test for DMC walker propagation, effective core potentials, and OhmmsPETE.
|
|
* To avoid filesystem limitations, QMC_SYMLINK_TEST_FILES can be set to symlink (1) or copy test files (0).
|
|
* Fixed mixed precision Ceperley force evaluation.
|
|
* Many updated tests to improve statistical reliability. Removed flux estimator from short tests because they were not reliable enough.
|
|
* Tests that rely on non-standard python modules that are not available are skipped.
|
|
* Error trap jastrow factors with cutoff radii larger than Wigner Seitz radius.
|
|
* Bugfix: Prevent users from adding correlation terms on non-existing electron pairs, e.g. up-down correlation terms when only up-spin particles are present.
|
|
* Support for measuring test coverage and performing coverage runs with cmake and ctest.
|
|
* Support for GCC7 and IBM XL (non Blue Gene) compiler.
|
|
* Support selecting GPU microarchitecture via -DCUDA_ARCH=sm_35(default).
|
|
* SummitDev IBM Minsky build recipe (Power8 + NVIDIA Pascal P100 GPUs).
|
|
* Significantly updated optimizer description in manual, including excited state optimization.
|
|
* Added description of using Intel MKL with non-Intel compilers in manual.
|
|
* Added description of MPIEXEC and MPIEXEC_NUMPROCS_FLAG to manual for systems where MPI runner is non-standard.
|
|
* Updated labs with correct pseudopotentials, basis set files.
|
|
* Many updated error messages and warnings.
|
|
|
|
### Known problems
|
|
|
|
* AFQMC without MKL will fail, e.g. short-afqmc-N2_vdz-4-1 test fails.
|
|
|
|
### NEXUS updates
|
|
|
|
* Improved selection algorithm to obtain optimally tiled supercells.
|
|
* Support for parallel pw2qmcpack workflows.
|
|
* Support for HPC resources at the Leibniz Supercomputing Center.
|
|
* Better consistency checks for the Structure class.
|
|
* Bugfix: forbid job bundling for simulations that depend on each other.
|
|
* Bugfix: correctly select low spin polarization in primitive and tiled (net_spin="low" option).
|
|
|
|
|
|
## [3.0.0] - 2017-01-30
|
|
|
|
### Notes
|
|
|
|
We are adopting [Semantic Versioning](http://semver.org) with this
|
|
release. It is the first to be made from the git repository on GitHub,
|
|
and the first named release since 2016-06-02 and subversion
|
|
revision 6964.
|
|
|
|
A potentially severe bug is fixed for periodic wavefunctions in this version,
|
|
in addition to many usability improvements and bugfixes. All users are
|
|
strongly recommended to upgrade.
|
|
|
|
NEXUS updates are listed after QMCPACK updates.
|
|
|
|
### QMCPACK updates
|
|
|
|
* IMPORTANT BUGFIX: Real-valued wavefunction code would occasionally make a numerically
|
|
unstable choice for constructing real-valued periodic wavefunctions, leading to
|
|
large variances and poor energies. Algorithm for constructing
|
|
wavefunctions improved.
|
|
* Fully parallel pw2qmcpack.x for QE 5.3, enables conversion of large
|
|
wavefunctions and use of same parallel setup as pw.x runs.
|
|
* Full testing of Quantum Espresso workflows (pw.x -> pw2qmcpack.x ->
|
|
qmcpack). Specify directory containing QE binaries via QE_BIN during configuration.
|
|
* Added open boundary conditions tests using QE wavefunctions,
|
|
as might be used for molecular work. Requires QE_BIN and computes
|
|
trial wavefunction on the fly.
|
|
* Added DMC, optimizer and additional system tests.
|
|
* Added unit tests using the Catch framework.
|
|
* Plane wave wavefunctions can be evaluated in plane waves, use "pw"
|
|
as determinantset type. Slow, but useful for checking spline accuracy. Tests added.
|
|
* Complex implementation on GPUs, supports arbitrary twists and
|
|
complex phase wavefunctions as per CPU code.
|
|
* Flux estimator correct for complex wavefunctions.
|
|
* Mixed precision CPU implementation, activated via -DQMC_MIXED_PRECISION=1.
|
|
* Double precision GPU implementation, complementing existing
|
|
mixed precision implementation, activated via -DQMC_MIXED_PRECISION=0.
|
|
* GAMESS CI converter improved.
|
|
* C++11 detection and support.
|
|
* Initial release of new optimizer, requires C++11 (contact Eric Neuscamman).
|
|
* Initial release of orbital-based AFQMC code, requires C+11 and MKL (contact Miguel Morales).
|
|
* Fine grained timers implemented, activated via -DENABLE_TIMERS=1.
|
|
* Improved Intel math and vector math library support. MKL and MKL VML more easily
|
|
supported with GCC as well as Intel compilers.
|
|
* Many code updates to eliminate CLANG warnings.
|
|
* Configure scripts, printed headers, manual updated for git. Git
|
|
version printed during configure and on standard output.
|
|
* Source files headers updated to consistently show UIUC/NCSA open source
|
|
license and list development history.
|
|
* Numerous manual updates.
|
|
* Updated QMCPACK tutorial laboratories.
|
|
* Many small bug fixes, improvements and optimizations.
|
|
|
|
### NEXUS updates
|
|
|
|
* General
|
|
* Nexus output now tracks time instead of poll number.
|
|
* Reported memory use now includes child processes.
|
|
* Workflow generator
|
|
* Major new capability to generate simple to complex workflows involving QE, VASP, and QMCPACK.
|
|
* Aim is to allow single notebook/worksheet describing all simulation workflows needed in a project.
|
|
* Users can succinctly create any subchain of the workflow: relax->scf->nscf->orbital_conv->qmc.
|
|
* Additional elements can be added to workflow chains over time as needed.
|
|
* Scans of structural parameters and input parameters at any level of the chain are possible.
|
|
* No programming constructs are required (for/if, etc).
|
|
* Directory substructure is automatically generated in the case of scans.
|
|
* Native support for visualizing workflows via pydot is provided.
|
|
* Documentation for this feature is pending.
|
|
* Quantum Espresso workflows
|
|
* Support for vdW functional input.
|
|
* Fixes to SCF->NSCF workflows for QE 5.3.0+.
|
|
* Support for automatic restarts of SCF runs.
|
|
* Native support for workflows involving post-processing tools
|
|
* pp.x, dos.x, bands.x, projwfc.x, cppp.x, pw_export.x supported.
|
|
* Postprocessing and summary of Lowdin charge data from projwfc.x.
|
|
* QMCPACK workflows
|
|
* Fixes for QE/VASP structural relaxation -> QMCPACK workflows.
|
|
* Fixed job bundling of twist averaged runs.
|
|
* Support for partitioned sposet input.
|
|
* Supercomputing environments
|
|
* Native support for several supercomputing environments located at Sandia Nat. Labs.
|
|
* Atomic structure manipulation
|
|
* Ability to find optimal supercells, similar to getSupercell tool.
|
|
* Robustness fixes to tiling operations.
|
|
* Tools
|
|
* qmca
|
|
* Fix for twist averaging with user-provided weights.
|
|
* qmcfit
|
|
* New command line tool for jack-knife fitting of QMCPACK data.
|
|
* Timestep extrapolation currently supported.
|
|
* General binding/equation of state fitting pending.
|