Skip to main contentIBM Quantum Documentation
This page is from the dev version of Qiskit SDK. Go to the stable version

ModularAdderSynthesisDefault

class qiskit.transpiler.passes.synthesis.hls_plugins.ModularAdderSynthesisDefault

GitHub

Bases: HighLevelSynthesisPlugin

The default modular adder (no carry in, no carry out qubit) synthesis.

This plugin name is:ModularAdder.default which can be used as the key on an HLSConfig object to use this method with HighLevelSynthesis.

If at least one clean auxiliary qubit is available, the ModularAdderSynthesisC04 is used, otherwise ModularAdderSynthesisD00.

The plugin supports the following plugin-specific options:

  • num_clean_ancillas: The number of clean auxiliary qubits available.

Methods

run

run(high_level_object, coupling_map=None, target=None, qubits=None, **options)

GitHub

Run synthesis for the given Operation.

Parameters

  • high_level_object (Operation) – The Operation to synthesize to a DAGCircuit object.
  • coupling_map (CouplingMap) – The coupling map of the backend in case synthesis is done on a physical circuit.
  • target (Target) – A target representing the target backend.
  • qubits (list) – List of qubits over which the operation is defined in case synthesis is done on a physical circuit.
  • options – Additional method-specific optional kwargs.

Returns

The quantum circuit representation of the Operation

when successful, and None otherwise.

Return type

QuantumCircuit

Was this page helpful?
Report a bug or request content on GitHub.