qml.qchem.molecular_hamiltonian

molecular_hamiltonian(molecule, method='dhf', active_electrons=None, active_orbitals=None, mapping='jordan_wigner', outpath='.', wires=None, args=None, convert_tol=1e12)[source]

Generate the qubit Hamiltonian of a molecule.

This function drives the construction of the second-quantized electronic Hamiltonian of a molecule and its transformation to the basis of Pauli matrices.

The net charge of the molecule can be given to simulate cationic/anionic systems. Also, the spin multiplicity can be input to determine the number of unpaired electrons occupying the HF orbitals as illustrated in the left panel of the figure below.

The basis of Gaussian-type atomic orbitals used to represent the molecular orbitals can be specified to go beyond the minimum basis approximation.

An active space can be defined for a given number of active electrons occupying a reduced set of active orbitals as sketched in the right panel of the figure below.


../../_images/fig_mult_active_space.png

Parameters
  • molecule (Molecule) – the molecule object

  • method (str) – Quantum chemistry method used to solve the mean field electronic structure problem. Available options are method="dhf" to specify the built-in differentiable Hartree-Fock solver, method="pyscf" to use the PySCF package (requires pyscf to be installed), or method="openfermion" to use the OpenFermion-PySCF plugin (this requires openfermionpyscf to be installed).

  • active_electrons (int) – Number of active electrons. If not specified, all electrons are considered to be active.

  • active_orbitals (int) – Number of active orbitals. If not specified, all orbitals are considered to be active.

  • mapping (str) – transformation used to map the fermionic Hamiltonian to the qubit Hamiltonian

  • outpath (str) – path to the directory containing output files

  • wires (Wires, list, tuple, dict) – Custom wire mapping for connecting to Pennylane ansatz. For types Wires/list/tuple, each item in the iterable represents a wire label corresponding to the qubit number equal to its index. For type dict, only int-keyed dict (for qubit-to-wire conversion) is accepted for partial mapping. If None, will use identity map.

  • args (array[array[float]]) – initial values of the differentiable parameters

  • convert_tol (float) – Tolerance in machine epsilon for the imaginary part of the Hamiltonian coefficients created by openfermion. Coefficients with imaginary part less than 2.22e-16*tol are considered to be real.

Returns

the fermionic-to-qubit transformed Hamiltonian and the number of qubits

Return type

tuple[pennylane.Operator, int]

Note

The molecular_hamiltonian function accepts a Molecule object as its first argument. Look at the Usage Details for more details on the old interface.

The molecular_hamiltonian function is not currently compatible with qjit() and jax.jit.

Example

>>> symbols = ['H', 'H']
>>> coordinates = np.array([[0., 0., -0.66140414], [0., 0., 0.66140414]])
>>> molecule = qml.qchem.Molecule(symbols, coordinates)
>>> H, qubits = qml.qchem.molecular_hamiltonian(molecule)
>>> print(qubits)
4
>>> print(H)
(-0.04207897647782188) [I0]
+ (0.17771287465139934) [Z0]
+ (0.1777128746513993) [Z1]
+ (-0.24274280513140484) [Z2]
+ (-0.24274280513140484) [Z3]
+ (0.17059738328801055) [Z0 Z1]
+ (0.04475014401535161) [Y0 X1 X2 Y3]
+ (-0.04475014401535161) [Y0 Y1 X2 X3]
+ (-0.04475014401535161) [X0 X1 Y2 Y3]
+ (0.04475014401535161) [X0 Y1 Y2 X3]
+ (0.12293305056183801) [Z0 Z2]
+ (0.1676831945771896) [Z0 Z3]
+ (0.1676831945771896) [Z1 Z2]
+ (0.12293305056183801) [Z1 Z3]
+ (0.176276408043196) [Z2 Z3]

The old interface for this method involved passing molecular information as separate arguments:

molecular_hamiltonian(symbols, coordinates, name=’molecule’, charge=0, mult=1, basis=’sto-3g’, method=’dhf’, active_electrons=None, active_orbitals=None, mapping=’jordan_wigner’, outpath=’.’, wires=None, alpha=None, coeff=None, args=None, load_data=False, convert_tol=1e12)

Molecule-based Arguments:
  • symbols (list[str]): symbols of the atomic species in the molecule

  • coordinates (array[float]): atomic positions in Cartesian coordinates. The atomic coordinates must be in atomic units and can be given as either a 1D array of size 3*N, or a 2D array of shape (N, 3) where N is the number of atoms. name (str): name of the molecule

  • charge (int): Net charge of the molecule. If not specified a neutral system is assumed.

  • mult (int): Spin multiplicity \(\mathrm{mult}=N_\mathrm{unpaired} + 1\) for \(N_\mathrm{unpaired}\) unpaired electrons occupying the HF orbitals. Possible values of mult are \(1, 2, 3, \ldots\). If not specified, a closed-shell HF state is assumed.

  • basis (str): atomic basis set used to represent the molecular orbitals

  • alpha (array[float]): exponents of the primitive Gaussian functions

  • coeff (array[float]): coefficients of the contracted Gaussian functions

Therefore, a molecular Hamiltonian had to be constructed in the following manner:

from pennylane import qchem

symbols = ["H", "H"]
geometry = np.array([[0.0, 0.0, 0.0], [0.0, 0.0, 1.0]])

H, qubit = qchem.molecular_hamiltonian(symbols, geometry, charge=0)

As part of the new interface, we are shifting towards extracting all the molecular information from the Molecule within the molecular_hamiltonian method.