Qiskit Aqua Chemistry is a set of tools, algorithms and software for use with quantum computers to carry out research and investigate how to take advantage of quantum computing power to solve chemistry problems.
If you need introductory material see the main readme which has installation instructions and information on how to use Qiskit Aqua Chemistry for running a chemistry experiment.
This readme contains the following sections:
An input file is used to define your chemistry problem. It contains at a minimum a definition of the molecule and associated configuration, such as a basis set, in order to compute the electronic structure using an external ab-initio chemistry program or chemistry library via a chemistry driver. Further configuration can also be supplied to explicitly control the processing and the quantum algorithm, used for the computation, instead of using defaulted values when none are supplied.
Several sample input files can be found in the chemistry folder of aqua-tutorials
An input file comprises the following main sections, although not all are mandatory:
NAME is an optional free format text section. Here you can name and describe the problem solved by the input file. For example:
&NAME
H2 molecule experiment
Ground state energy computed via Variational Quantum Eigensolver
&END
DRIVER is a mandatory section. This section defines the molecule and associated configuration for the electronic structure computation by the chosen driver via its external chemistry program or library. The exact form on the configuration depends on the specific driver being used. See the chemistry drivers readme for more information about the drivers and their configuration.
You will need to look at the readme of the driver you are using to find out about its specific configuration. Here are a couple of examples. Note that the DRIVER section names which specific chemistry driver will be used and that a subsequent section, in the name of the driver, then supplies the driver specific configuration.
Here is an example using the PYSCF driver. The DRIVER section names PYSCF as the driver and then a PYSCF section, corresponding to the name, provides the molecule and basis set that will be used by the PYSCF driver and hence the PySCF library to compute the electronic structure.
&DRIVER
name=PYSCF
&END
&PYSCF
atom=H .0 .0 .0; H .0 .0 0.74
basis=sto3g
&END
Here is another example using the PSI4 driver. Here PSI4 is named as the driver to be used and the PSI4 section contains the molecule and basis set directly in a form that PSI4 understands. This is the Psithon input file language for PSI4, and thus should be familiar to existing users of PSI4.
&DRIVER
name=PSI4
&END
&PSI4
molecule h2 {
0 1
H .0000000000 0.0 0.0
H .0000000000 0.0 .2
}
set {
basis sto-3g
scf_type pk
}
&END
OPERATOR is an optional section. This section can be configured to control the specific way the electronic structure information, from the driver, is converted to QuBit operator form in order to be processed by the ALGORITHM. The following parameters may be set:
-
name
=hamiltonianCurrently 'hamiltonian' should be used as the name since there only one operator entity at present
-
transformation
=full | particle_holeDo full transformation or use particle_hole
The 'standard' second quantized Hamiltonian can be transformed using the particle-hole (p/h) option, which makes the expansion of the trial wavefunction from the HartreeFock reference state more natural. For trial wavefunctions in Qiskit Aqua, such as UCCSD, the p/h Hamiltonian can improve the speed of convergence of the VQE algorithm for the calculation of the electronic ground state properties. For more information on the p/h formalism see: P. Barkoutsos, arXiv:1805.04340.
-
qubit_mapping
=jordan_wigner | parity | bravyi_kitaevDesired mapping from fermion to qubit. Note: bravyi_kitaev is also known as the binary-tree-based qubit mapping.
-
two_qubit_reduction
=true | falseWith parity mapping the operator can be reduced by two qubits
-
max_workers
=integer, default 4Processing of the hamiltonian from fermionic to qubit can take advantage of multiple cpu cores to run parallel processes to carry out the transformation. The number of such worker processes used will not exceed the actual number of cup cores or this max_workers number, whichever is the smaller.
-
freeze_core
=true | falseWhether to freeze core orbitals in the computation or not. Frozen core orbitals are removed from the subsequent computation by the ALGORITHM and a corresponding offset from this removal is added back into the final computed result. This may be combined with orbital_reduction below.
-
orbital_reduction
=array of integersThe orbitals from the electronic structure can be simplified for the subsequent computation.
With this parameter you can specify a list of orbitals, the default being an empty list, to be removed from the subsequent computation. The list should be indices of the orbitals from 0 to n-1, where the electronic structure has n orbitals. Note: for ease of referring to the higher orbitals the list also supports negative values with -1 being the highest unoccupied orbital, -2 the next one down and so on. Also note, that while orbitals may be listed to reduce the overall size of the problem, the result can be less accurate as a result of using this simplification.
Any orbitals in the list that are occupied are frozen and an offset is computed from their removal. This is the same procedure as happens when freeze_core is specified except here you can specify exactly the orbitals you want.
Any orbitals in the list that are unoccupied virtual orbitals are simply eliminated entirely from the subsequent computation.
When a list is specified along with freeze_core of true the effective orbitals being acted up is the set from freeze_core combined with those specified here.
Here is an example below where in addition to freezing the core orbitals a couple of other orbitals are listed. In this example it assumes there were 10 orbitals so the highest two, unoccupied virtual orbitals, will be eliminated from the subsequent computation in addition to the frozen core treatment:
&OPERATOR
name=hamiltonian
qubit_mapping=jordan_wigner
freeze_core=true
orbital_reduction=[8,9]
&END
Note the above could be specified the following way, which simplifies expressing the higher orbitals since the numbering is relative to the highest orbital and will always refer to the highest two orbitals.
&OPERATOR
name=hamiltonian
qubit_mapping=jordan_wigner
freeze_core=true
orbital_reduction=[-2,-1]
&END
ALGORITHM is an optional section that allows you to define which quantum algorithm will be used by the computation. Algorithms are provided by QISKIt Aqua The algorithm defaults to VQE (Variational Quantum Eigensolver), with a set of default parameters.
According to each ALGORITHM you may add further sections to optionally configure the algorithm further. These sections correspond to the pluggable entities that developers may choose to create and add more to the set currently provided.
Here is an example showing the VQE algorithm along with OPTIMIZER and VARIATIONAL_FORM sections for the optimizer and variational forms that are used by VQE.
&ALGORITHM
name=VQE
shots=1
operator_mode=matrix
&END
&OPTIMIZER
name=L_BFGS_B
factr=10
&END
&VARIATIONAL_FORM
name=RYRZ
entangler_map={0: [1]}
&END
For more information on algorithms, and any pluggable entities it may use, see Qiskit Aqua for more specifics about them and their configuration options.
BACKEND is an optional section that includes naming the Qiskit quantum computational backend to be used for the quantum algorithm computation. This defaults to a local quantum simulator backend. See Qiskit Aqua for more information.
PROBLEM is an optional section that includes the overall problem being solved and overall problem level configuration See Qiskit Aqua for more information.
This is the same PROBLEM specification but
-
name
=energy | excited_statesSpecifies the problem being solved. Ensures that algorithms that can handle this class of problem are used. Restricted to
energy
andexcited_states
computations for the chemistry stack and therefore algorithms that can handle these problems. -
auto_substitutions
=true | falseThis field is only support by Qiskit Aqua Chemistry.
During configuration some items may require matching their settings e.g. UCCSD variation form and HartreeFock initial state configuration need qubit_mapping and two_qubit_reduction to match what is set in OPERATOR section hamiltonian. Also some objects, like the aforementioned, may require the user to know number of particles, number of orbitals etc. for their configuration. To assist the user in this regard configuration substitutions are enabled by default.
Substitutions use a predefined set of intra-section and computed values that are used to substitute (overwrite) any values in the targeted fields appropriately. If auto_substitutions is set false then the end user has the full responsibility for the entire configuration.
-
random_seed
=An integer, default NoneSee Qiskit Aqua
random_seed
for more information.
The UI and Command line tools use aqua_chemistry.py when solving the chemistry problem given by the supplied input file. A programmatic interface is also available that can be called using a dictionary in the same formula as the input file. Like the input file its parameters take on the same values and same defaults.
The dictionary can be manipulated programmatically, if desired, to vary the problem e.g. changing the interatomic distance of the molecule, changing basis set, algorithm etc. You can find notebooks in the aqua-tutorials chemistry folder demonstrating this usage.
The code fragment below also shows such a dictionary and a simple usage.
aqua_chemistry_dict = {
'driver': {'name': 'PYSCF'},
'PYSCF': {'atom': '', 'basis': 'sto3g'},
'algorithm': {'name': 'VQE'}
}
molecule = 'H .0 .0 -{0}; H .0 .0 {0}'
d = 0.74
aqua_chemistry_dict['PYSCF']['atom'] = molecule.format(d/2)
solver = AquaChemistry()
result = solver.run(aqua_chemistry_dict)
print('Ground state energy {}'.format(result['energy']))
Note: the GUI tool can export a dictionary from an input file. You can load an existing input file or create a new one and then simply export it as a dictionary for use in a program.
As can be seen in the programming interface example above the AquaChemistry run() method returns a result dictionary.
Energies are in units of Hartree
and dipole moment in units of a.u.
.
The dictionary contains the following fields of note:
-
energy
The ground state energy
-
energies
An array of energies comprising the ground state energy and any excited states if they were computed
-
nuclear_repulsion_energy
The nuclear repulsion energy
-
hf_energy
The Hartree-Fock ground state energy as computed by the driver
-
nuclear_dipole_moment, electronic_dipole_moment, dipole_moment
Nuclear, electronic and combined dipole moments for x, y and z
-
total_dipole_moment
Total dipole moment
-
algorithm_retvals
The result dictionary of the algorithm that ran for the above values. See the algorithm for any further information.
Qiskit Aqua is the library of cross-domain algorithms and pluggable utilities. Please refer to the documentation there for more information on how to write and contribute such objects to Qiskit Aqua. Such objects are then available to be used by Qiskit Aqua Chemistry.
Unit tests should go under "test" folder and be classes derived from QiskitAquaChemistryTestCase class.
They should not have print statements, instead use self.log.debug. If they use assert, they should be from the unittest package like self.AssertTrue, self.assertRaises etc.
For guidance look at the tests cases implemented at https://github.com/Qiskit/qiskit-sdk-py/tree/master/test/python
To run all unit tests: python -m unittest discover
To run a particular unit test module: python -m unittest test/test_end2end.py
For help: python -m unittest -h
There are other running options at: https://docs.python.org/3/library/unittest.html#command-line-options
In order to see unit test log messages you need to set environment variable:
LOG_LEVEL=DEBUG
export LOG_LEVEL
The example above will save all results from "self.log.debug()" to a ".log" file with same name as the module used to run. For instance "test_end2end.log" in the test folder.
Here are some references to other useful materials that may be helpful