map_majorana_action_generators¶
- map_majorana_action_generators(operator, map_action, identity, compose=None)¶
Map a
MajoranaOperatorto another operator type.This is a generic function to aid in implementing new mappers for
MajoranaOperatorinstances. At its core, it simply iterates over the terms of the operator, mapping each encounteredMajoranaActionwith the user-providedmap_actionfunction. In combination with the user-providedidentitygenerator, this allows mapping to arbitrary output types.Note
The output type
Tmust support multiplication by a scalar via__mul__. Ifcompose=Noneit must also support composition of two instances via__and__.>>> from qiskit_fermions.mappers import map_majorana_action_generators >>> from qiskit_fermions.operators import MajoranaAction, MajoranaOperator, gamma >>> from qiskit.quantum_info import SparsePauliOp >>> >>> def jordan_wigner(mode: MajoranaAction) -> SparsePauliOp: ... idx = mode // 2 ... qubits = list(range(idx + 1)) ... pauli = "Y" if mode % 2 else "X" ... return SparsePauliOp.from_sparse_list( ... [("Z" * idx + pauli, qubits, 1.0)], ... num_qubits=num_qubits, ... ) >>> >>> num_qubits = 2 >>> def identity() -> SparsePauliOp: ... return SparsePauliOp.from_sparse_list([("", [], 1)], num_qubits) >>> >>> op = MajoranaOperator.from_dict({ ... (0, 2): 0.5, ... (1, 3): 0.5, ... (0, 3): 0.5j, ... (1, 2): -0.5j, ... }) >>> qop = map_majorana_action_generators(op, jordan_wigner, identity) >>> print([(label, complex(coeff)) for label, coeff in sorted(qop.label_iter())]) [('II', 0j), ('XX', (0.5-0j)), ('XY', -0.5j), ('YX', 0.5j), ('YY', (0.5+0j))]
- Parameters:
operator (MajoranaOperator) – the operator to be mapped.
map_action (Callable[[MajoranaAction], T]) – the function to map a single
MajoranaActionto the desired output type.identity (Callable[[], T]) – the function to generate the multiplicative identity instance of the output type.
compose (Callable[[T, T], T] | None) – an optional function to implement the compositiion logic of two output type instances. If this is not provided, it will default to using
operator.and_().
- Returns:
The mapped operator.
- Return type:
T