ExcitationSolve: a fast globally-informed gradient-free optimizer for physically-motivated ansätze constructed of excitation operators
Project description
ExcitationSolve 
An optimization algorithm for ansätze consisting of excitation operators in variational quantum eigensolvers (VQEs).
Abstract
We introduce ExcitationSolve, a fast globally-informed gradient-free optimizer for physically-motivated ansätze constructed of excitation operators, a common choice in variational quantum eigensolvers. ExcitationSolve is to be classified as an extension of quantum-aware and hyperparameter-free optimizers such as Rotosolve, from parameterized unitaries with generators $G$ of the form $G^2=I$, e.g., rotations, to the more general class of $G^3=G$ exhibited by the physically-inspired excitation operators such as in the unitary coupled cluster approach. ExcitationSolve is capable of finding the global optimum along each variational parameter using the same quantum resources that gradient-based optimizers require for a single update step. We provide optimization strategies for both fixed- and adaptive variational ansätze, as well as a multi-parameter generalization for the simultaneous selection and optimization of multiple excitation operators. Finally, we demonstrate the utility of ExcitationSolve by conducting electronic ground state energy calculations of molecular systems and thereby outperforming state-of-the-art optimizers commonly employed in variational quantum algorithms. Across all tested molecules in their equilibrium geometry, ExcitationSolve remarkably reaches chemical accuracy in a single sweep over the parameters of a fixed ansatz. This sweep requires only the quantum circuit executions of one gradient descent step. In addition, ExcitationSolve achieves adaptive ansätze consisting of fewer operators than in the gradient-based adaptive approach, hence decreasing the circuit execution time.
Examples
VQE convergence for different molecules and optimizers, including ExcitationSolve in red, using a UCCSD ansatz.
Installation
pip install git+https://github.com/dlr-wf/ExcitationSolve.git
Usage
See the examples folder for usage examples for qiskit and pennylane. The core (1D) algorithm is implemented in excitation_solve.py and can be used independently of any quantum computing SDK like qiskit or pennylane. The 2D ExcitationSolve algorithm is implemented in excitation_solve_2d.py. An implementation for using ExcitationSolve in combination with ADAPT-VQE in PennyLane can be found in excitation_solve_adapt.py.
Qiskit
from excitationsolve.excitation_solve_qiskit import ExcitationSolveQiskit
Then use the ExcitationSolveQiskit optimizer instead of other qiskit optimizers, like COBYLA or L-BFGS, as demonstrated in the qiskit example.
Optimal energies and parameters
The qiskit VQE callback function can only track the energies and parameters of executed circuit. ExcitationSolve does not need to execute the circuit at optimal parameter configurations to perform the optimization. Therefore, the callback function never recieves optimal energies and parameters. Plotting these, would show false optimization progress, although the final optimized energy and paramters are saved in the VQEResult object, returned from the VQE.compute_minimum_eigenvalue function. To better track the optimization progress, the ExcitationSolveQiskit optimizer object internally saves all energies in its energies member variable, corresponding number of energy evaluations nfevs and optionally the parameters params (if save_parameters is set to True). These are saved after each optimization step, i.e. after optimizing each single parameter. For plotting the optimization progress use the data stored in counts and values from the following code snippet:
optimizer = ExcitationSolveQiskit(maxiter=100, save_parameters=True)
# Perfrom optimization here...
counts = optimizer.nfevs
values = optimizer.energies
params = optimizer.params
Pennylane
Use the excitationsolve.excitation_solve_pennylane.excitationsolve_pennylane function in a VQE loop as used in the pennylane (dataset) example or the pennylane (pyscf) example.
Alternatively, one can use the excitationsolve.excitation_solve_step function to optimize a single parameter. The excitationsolve.excitation_solve_pennylane.excitationsolve_pennylane optimizes all parameters, or a subset of them, in the quantum circuit using excitationsolve.excitation_solve_step.
Authors
- Jonas Jäger
- Thierry N. Kaldenbach
- Max Haas
- Erik Schultheis
Contact
Feel free to contact David Melching if you have any questions.
Citation
If you use portions of this code please cite our paper:
@misc{Jaeger2024Fast,
title={Fast gradient-free optimization of excitations in variational quantum eigensolvers},
author={Jonas Jäger and Thierry Nicolas Kaldenbach and Max Haas and Erik Schultheis},
year={2024},
eprint={2409.05939},
archivePrefix={arXiv},
primaryClass={quant-ph},
url={https://arxiv.org/abs/2409.05939},
doi={10.48550/arXiv.2409.05939}
}
Acknowledgment
This project was made possible by the DLR Quantum Computing Initiative and the Federal Ministry for Economic Affairs and Climate Action; https://qci.dlr.de/quanticom.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file excitationsolve-1.1.1.tar.gz.
File metadata
- Download URL: excitationsolve-1.1.1.tar.gz
- Upload date:
- Size: 263.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8ef084cb849738d5920672553b714fcbc00cf0d94969b4fb2322d649abc8c8f9
|
|
| MD5 |
dcdafaba9add6f7e94a624d49196a599
|
|
| BLAKE2b-256 |
cf5db8e15be1778c02f0730e5c6bc9b6be5f9a97fdf3f6ee5cae42d37189a224
|
File details
Details for the file excitationsolve-1.1.1-py3-none-any.whl.
File metadata
- Download URL: excitationsolve-1.1.1-py3-none-any.whl
- Upload date:
- Size: 24.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
feb925713c1986083cf9424cb8e25f29f37f30b989de8840eb44c5db770d36e4
|
|
| MD5 |
5d88c9f5025cbbdd9f4fbce735f95398
|
|
| BLAKE2b-256 |
5722200294474a263f2f908d1472ba1c4999236405eee2ac5d8b307709e1904b
|