From 5465475a70530926fe734d088cc87949e54d14e7 Mon Sep 17 00:00:00 2001 From: Eric Arellano <14852634+Eric-Arellano@users.noreply.github.com> Date: Thu, 15 Feb 2024 15:30:01 -0500 Subject: [PATCH 1/4] Make 0.46 historical --- docs/api/qiskit/0.46/_package.json | 4 + docs/api/qiskit/0.46/_toc.json | 3633 +++++++++++++++ docs/api/qiskit/0.46/algorithms.md | 279 ++ docs/api/qiskit/0.46/assembler.md | 186 + docs/api/qiskit/0.46/circuit.md | 357 ++ docs/api/qiskit/0.46/circuit_classical.md | 974 ++++ docs/api/qiskit/0.46/circuit_library.md | 1292 ++++++ docs/api/qiskit/0.46/circuit_singleton.md | 210 + docs/api/qiskit/0.46/classicalfunction.md | 84 + docs/api/qiskit/0.46/compiler.md | 310 ++ docs/api/qiskit/0.46/converters.md | 310 ++ docs/api/qiskit/0.46/dagcircuit.md | 54 + docs/api/qiskit/0.46/exceptions.md | 72 + docs/api/qiskit/0.46/execute.md | 183 + docs/api/qiskit/0.46/extensions.md | 50 + docs/api/qiskit/0.46/index.md | 64 + docs/api/qiskit/0.46/opflow.md | 214 + docs/api/qiskit/0.46/passmanager.md | 173 + docs/api/qiskit/0.46/primitives.md | 146 + docs/api/qiskit/0.46/providers.md | 509 +++ .../qiskit/0.46/providers_basic_provider.md | 52 + docs/api/qiskit/0.46/providers_basicaer.md | 58 + .../qiskit/0.46/providers_fake_provider.md | 265 ++ docs/api/qiskit/0.46/providers_models.md | 39 + docs/api/qiskit/0.46/pulse.md | 2798 ++++++++++++ docs/api/qiskit/0.46/qasm.md | 54 + docs/api/qiskit/0.46/qasm2.md | 539 +++ docs/api/qiskit/0.46/qasm3.md | 299 ++ .../0.46/qiskit.algorithms.AlgorithmJob.md | 168 + .../qiskit.algorithms.AmplificationProblem.md | 93 + .../qiskit.algorithms.AmplitudeAmplifier.md | 40 + .../qiskit.algorithms.AmplitudeEstimation.md | 209 + ...it.algorithms.AmplitudeEstimationResult.md | 124 + .../qiskit.algorithms.AmplitudeEstimator.md | 36 + ...kit.algorithms.AmplitudeEstimatorResult.md | 82 + .../0.46/qiskit.algorithms.Eigensolver.md | 65 + .../qiskit.algorithms.EigensolverResult.md | 60 + .../qiskit.algorithms.EstimationProblem.md | 116 + .../qiskit.algorithms.EvolutionProblem.md | 62 + .../0.46/qiskit.algorithms.EvolutionResult.md | 43 + ...it.algorithms.FasterAmplitudeEstimation.md | 129 + ...orithms.FasterAmplitudeEstimationResult.md | 106 + .../qiskit/0.46/qiskit.algorithms.Grover.md | 196 + .../0.46/qiskit.algorithms.GroverResult.md | 86 + ...t.algorithms.HamiltonianPhaseEstimation.md | 90 + ...rithms.HamiltonianPhaseEstimationResult.md | 92 + .../qiskit.algorithms.ImaginaryEvolver.md | 48 + .../qiskit.algorithms.ImaginaryTimeEvolver.md | 42 + ...algorithms.IterativeAmplitudeEstimation.md | 141 + ...thms.IterativeAmplitudeEstimationResult.md | 130 + ...kit.algorithms.IterativePhaseEstimation.md | 92 + ...ms.MaximumLikelihoodAmplitudeEstimation.md | 175 + ...imumLikelihoodAmplitudeEstimationResult.md | 112 + .../qiskit.algorithms.MinimumEigensolver.md | 67 + ...kit.algorithms.MinimumEigensolverResult.md | 60 + .../qiskit.algorithms.NumPyEigensolver.md | 88 + ...skit.algorithms.NumPyMinimumEigensolver.md | 77 + .../api/qiskit/0.46/qiskit.algorithms.PVQD.md | 232 + .../0.46/qiskit.algorithms.PVQDResult.md | 42 + .../0.46/qiskit.algorithms.PhaseEstimation.md | 128 + ...qiskit.algorithms.PhaseEstimationResult.md | 103 + .../qiskit.algorithms.PhaseEstimationScale.md | 116 + .../api/qiskit/0.46/qiskit.algorithms.QAOA.md | 252 ++ .../0.46/qiskit.algorithms.RealEvolver.md | 48 + .../0.46/qiskit.algorithms.RealTimeEvolver.md | 42 + ...qiskit.algorithms.SciPyImaginaryEvolver.md | 52 + .../qiskit.algorithms.SciPyRealEvolver.md | 52 + .../qiskit.algorithms.TimeEvolutionProblem.md | 116 + .../qiskit.algorithms.TimeEvolutionResult.md | 79 + .../0.46/qiskit.algorithms.TrotterQRTE.md | 120 + docs/api/qiskit/0.46/qiskit.algorithms.VQD.md | 243 + .../0.46/qiskit.algorithms.VQDResult.md | 108 + docs/api/qiskit/0.46/qiskit.algorithms.VQE.md | 270 ++ .../qiskit/0.46/qiskit.algorithms.VarQITE.md | 56 + .../qiskit/0.46/qiskit.algorithms.VarQRTE.md | 56 + ...kit.algorithms.eigensolvers.Eigensolver.md | 61 + ...gorithms.eigensolvers.EigensolverResult.md | 48 + ...lgorithms.eigensolvers.NumPyEigensolver.md | 84 + ...hms.eigensolvers.NumPyEigensolverResult.md | 54 + .../qiskit.algorithms.eigensolvers.VQD.md | 173 + ...iskit.algorithms.eigensolvers.VQDResult.md | 90 + .../0.46/qiskit.algorithms.eigensolvers.md | 38 + ...orithms.gradients.BaseEstimatorGradient.md | 98 + .../qiskit.algorithms.gradients.BaseQGT.md | 115 + ...lgorithms.gradients.BaseSamplerGradient.md | 76 + ...ithms.gradients.EstimatorGradientResult.md | 44 + ...s.gradients.FiniteDiffEstimatorGradient.md | 107 + ...hms.gradients.FiniteDiffSamplerGradient.md | 96 + ...thms.gradients.LinCombEstimatorGradient.md | 104 + .../qiskit.algorithms.gradients.LinCombQGT.md | 124 + ...rithms.gradients.LinCombSamplerGradient.md | 84 + ...s.gradients.ParamShiftEstimatorGradient.md | 106 + ...hms.gradients.ParamShiftSamplerGradient.md | 84 + .../0.46/qiskit.algorithms.gradients.QFI.md | 77 + .../qiskit.algorithms.gradients.QFIResult.md | 44 + .../qiskit.algorithms.gradients.QGTResult.md | 52 + ...thms.gradients.ReverseEstimatorGradient.md | 104 + .../qiskit.algorithms.gradients.ReverseQGT.md | 100 + ...orithms.gradients.SPSAEstimatorGradient.md | 96 + ...lgorithms.gradients.SPSASamplerGradient.md | 85 + ...orithms.gradients.SamplerGradientResult.md | 44 + .../0.46/qiskit.algorithms.gradients.md | 76 + ...lgorithms.minimum_eigensolvers.AdaptVQE.md | 143 + ...hms.minimum_eigensolvers.AdaptVQEResult.md | 122 + ...minimum_eigensolvers.MinimumEigensolver.md | 61 + ...m_eigensolvers.MinimumEigensolverResult.md | 48 + ...um_eigensolvers.NumPyMinimumEigensolver.md | 71 + ...ensolvers.NumPyMinimumEigensolverResult.md | 54 + ...it.algorithms.minimum_eigensolvers.QAOA.md | 172 + ...eigensolvers.SamplingMinimumEigensolver.md | 59 + ...olvers.SamplingMinimumEigensolverResult.md | 66 + ...rithms.minimum_eigensolvers.SamplingVQE.md | 168 + ....minimum_eigensolvers.SamplingVQEResult.md | 112 + ...kit.algorithms.minimum_eigensolvers.VQE.md | 172 + ...gorithms.minimum_eigensolvers.VQEResult.md | 96 + .../qiskit.algorithms.minimum_eigensolvers.md | 43 + .../0.46/qiskit.algorithms.optimizers.ADAM.md | 282 ++ .../0.46/qiskit.algorithms.optimizers.AQGD.md | 241 + .../qiskit.algorithms.optimizers.AskData.md | 43 + .../qiskit.algorithms.optimizers.BOBYQA.md | 221 + .../0.46/qiskit.algorithms.optimizers.CG.md | 224 + .../qiskit.algorithms.optimizers.COBYLA.md | 222 + .../0.46/qiskit.algorithms.optimizers.CRS.md | 233 + .../qiskit.algorithms.optimizers.DIRECT_L.md | 235 + ...kit.algorithms.optimizers.DIRECT_L_RAND.md | 235 + .../0.46/qiskit.algorithms.optimizers.ESCH.md | 235 + .../0.46/qiskit.algorithms.optimizers.GSLS.md | 342 ++ ...t.algorithms.optimizers.GradientDescent.md | 466 ++ ...orithms.optimizers.GradientDescentState.md | 88 + .../qiskit.algorithms.optimizers.IMFIL.md | 221 + .../qiskit.algorithms.optimizers.ISRES.md | 233 + .../qiskit.algorithms.optimizers.L_BFGS_B.md | 230 + .../qiskit.algorithms.optimizers.Minimizer.md | 40 + ...iskit.algorithms.optimizers.NELDER_MEAD.md | 228 + .../0.46/qiskit.algorithms.optimizers.NFT.md | 232 + .../qiskit.algorithms.optimizers.Optimizer.md | 221 + ...t.algorithms.optimizers.OptimizerResult.md | 70 + ...it.algorithms.optimizers.OptimizerState.md | 70 + ...rithms.optimizers.OptimizerSupportLevel.md | 44 + .../qiskit.algorithms.optimizers.POWELL.md | 223 + .../qiskit.algorithms.optimizers.P_BFGS.md | 225 + .../qiskit.algorithms.optimizers.QNSPSA.md | 416 ++ .../qiskit.algorithms.optimizers.SLSQP.md | 226 + .../qiskit.algorithms.optimizers.SNOBFIT.md | 225 + .../0.46/qiskit.algorithms.optimizers.SPSA.md | 399 ++ ...it.algorithms.optimizers.SciPyOptimizer.md | 218 + ...lgorithms.optimizers.SteppableOptimizer.md | 396 ++ .../0.46/qiskit.algorithms.optimizers.TNC.md | 227 + .../qiskit.algorithms.optimizers.TellData.md | 41 + .../0.46/qiskit.algorithms.optimizers.UMDA.md | 307 ++ .../0.46/qiskit.algorithms.optimizers.md | 97 + ...optimizers.optimizer_utils.LearningRate.md | 56 + ...t.algorithms.optimizers.optimizer_utils.md | 28 + ...thms.state_fidelities.BaseStateFidelity.md | 71 + ...ithms.state_fidelities.ComputeUncompute.md | 117 + ...ms.state_fidelities.StateFidelityResult.md | 52 + .../qiskit.algorithms.state_fidelities.md | 35 + ...ime_evolvers.trotterization.TrotterQRTE.md | 109 + ...algorithms.time_evolvers.trotterization.md | 22 + ...evolvers.variational.ForwardEulerSolver.md | 42 + ...variational.ImaginaryMcLachlanPrinciple.md | 56 + ...riational.ImaginaryVariationalPrinciple.md | 23 + ...vers.variational.RealMcLachlanPrinciple.md | 56 + ...rs.variational.RealVariationalPrinciple.md | 23 + ...olvers.variational.VariationalPrinciple.md | 93 + ...it.algorithms.time_evolvers.variational.md | 78 + .../qiskit/0.46/qiskit.assembler.RunConfig.md | 106 + .../0.46/qiskit.circuit.AncillaQubit.md | 55 + .../0.46/qiskit.circuit.AncillaRegister.md | 90 + .../0.46/qiskit.circuit.AnnotatedOperation.md | 84 + docs/api/qiskit/0.46/qiskit.circuit.Bit.md | 50 + .../qiskit/0.46/qiskit.circuit.BreakLoopOp.md | 345 ++ .../0.46/qiskit.circuit.CircuitInstruction.md | 82 + .../0.46/qiskit.circuit.ClassicalRegister.md | 90 + docs/api/qiskit/0.46/qiskit.circuit.Clbit.md | 55 + .../0.46/qiskit.circuit.CommutationChecker.md | 46 + .../0.46/qiskit.circuit.ContinueLoopOp.md | 349 ++ .../0.46/qiskit.circuit.ControlFlowOp.md | 353 ++ .../0.46/qiskit.circuit.ControlModifier.md | 36 + .../0.46/qiskit.circuit.ControlledGate.md | 495 +++ docs/api/qiskit/0.46/qiskit.circuit.Delay.md | 350 ++ .../0.46/qiskit.circuit.EquivalenceLibrary.md | 184 + .../qiskit/0.46/qiskit.circuit.ForLoopOp.md | 366 ++ docs/api/qiskit/0.46/qiskit.circuit.Gate.md | 427 ++ .../qiskit/0.46/qiskit.circuit.IfElseOp.md | 378 ++ .../qiskit/0.46/qiskit.circuit.Instruction.md | 331 ++ .../0.46/qiskit.circuit.InstructionSet.md | 121 + .../0.46/qiskit.circuit.InverseModifier.md | 18 + .../qiskit/0.46/qiskit.circuit.Operation.md | 55 + .../qiskit/0.46/qiskit.circuit.Parameter.md | 258 ++ .../qiskit.circuit.ParameterExpression.md | 250 ++ .../0.46/qiskit.circuit.ParameterVector.md | 52 + .../0.46/qiskit.circuit.PowerModifier.md | 26 + .../0.46/qiskit.circuit.QuantumCircuit.md | 3922 +++++++++++++++++ .../0.46/qiskit.circuit.QuantumRegister.md | 90 + docs/api/qiskit/0.46/qiskit.circuit.Qubit.md | 55 + .../qiskit/0.46/qiskit.circuit.Register.md | 88 + .../0.46/qiskit.circuit.SwitchCaseOp.md | 392 ++ .../qiskit/0.46/qiskit.circuit.WhileLoopOp.md | 367 ++ ...uit.classicalfunction.BooleanExpression.md | 487 ++ ...uit.classicalfunction.ClassicalFunction.md | 544 +++ ...tion.ClassicalFunctionCompilerTypeError.md | 20 + ...calfunction.ClassicalFunctionParseError.md | 20 + .../qiskit/0.46/qiskit.circuit.library.AND.md | 227 + .../0.46/qiskit.circuit.library.Barrier.md | 311 ++ .../0.46/qiskit.circuit.library.C3SXGate.md | 176 + .../0.46/qiskit.circuit.library.C3XGate.md | 187 + .../0.46/qiskit.circuit.library.C4XGate.md | 191 + .../0.46/qiskit.circuit.library.CCXGate.md | 243 + .../0.46/qiskit.circuit.library.CCZGate.md | 196 + ...it.circuit.library.CDKMRippleCarryAdder.md | 283 ++ .../0.46/qiskit.circuit.library.CHGate.md | 211 + .../0.46/qiskit.circuit.library.CPhaseGate.md | 222 + .../0.46/qiskit.circuit.library.CRXGate.md | 213 + .../0.46/qiskit.circuit.library.CRYGate.md | 213 + .../0.46/qiskit.circuit.library.CRZGate.md | 215 + .../0.46/qiskit.circuit.library.CSGate.md | 195 + .../0.46/qiskit.circuit.library.CSXGate.md | 199 + .../0.46/qiskit.circuit.library.CSdgGate.md | 195 + .../0.46/qiskit.circuit.library.CSwapGate.md | 230 + .../0.46/qiskit.circuit.library.CU1Gate.md | 212 + .../0.46/qiskit.circuit.library.CU3Gate.md | 217 + .../0.46/qiskit.circuit.library.CUGate.md | 207 + .../0.46/qiskit.circuit.library.CXGate.md | 239 + .../0.46/qiskit.circuit.library.CYGate.md | 209 + .../0.46/qiskit.circuit.library.CZGate.md | 190 + .../0.46/qiskit.circuit.library.DCXGate.md | 141 + .../0.46/qiskit.circuit.library.Diagonal.md | 255 ++ .../qiskit.circuit.library.DiagonalGate.md | 137 + .../qiskit.circuit.library.DraperQFTAdder.md | 254 ++ .../0.46/qiskit.circuit.library.ECRGate.md | 175 + .../qiskit.circuit.library.EfficientSU2.md | 351 ++ ...t.circuit.library.EvolvedOperatorAnsatz.md | 319 ++ .../qiskit.circuit.library.ExactReciprocal.md | 224 + ...it.circuit.library.ExcitationPreserving.md | 370 ++ .../qiskit.circuit.library.FourierChecking.md | 238 + ...ircuit.library.FunctionalPauliRotations.md | 188 + .../qiskit/0.46/qiskit.circuit.library.GMS.md | 247 ++ .../qiskit/0.46/qiskit.circuit.library.GR.md | 241 + .../qiskit/0.46/qiskit.circuit.library.GRX.md | 240 + .../qiskit/0.46/qiskit.circuit.library.GRY.md | 240 + .../qiskit/0.46/qiskit.circuit.library.GRZ.md | 240 + .../qiskit.circuit.library.GlobalPhaseGate.md | 145 + .../0.46/qiskit.circuit.library.GraphState.md | 245 + .../qiskit.circuit.library.GroverOperator.md | 380 ++ .../0.46/qiskit.circuit.library.HGate.md | 173 + ...circuit.library.HRSCumulativeMultiplier.md | 277 ++ .../qiskit.circuit.library.HamiltonianGate.md | 181 + ...it.circuit.library.HiddenLinearFunction.md | 247 ++ .../0.46/qiskit.circuit.library.IGate.md | 156 + .../qiskit/0.46/qiskit.circuit.library.IQP.md | 235 + .../0.46/qiskit.circuit.library.Initialize.md | 170 + .../qiskit.circuit.library.InnerProduct.md | 246 ++ ...iskit.circuit.library.IntegerComparator.md | 201 + .../0.46/qiskit.circuit.library.Isometry.md | 174 + ...circuit.library.LinearAmplitudeFunction.md | 283 ++ .../qiskit.circuit.library.LinearFunction.md | 251 ++ ...it.circuit.library.LinearPauliRotations.md | 235 + .../0.46/qiskit.circuit.library.MCMT.md | 263 ++ .../0.46/qiskit.circuit.library.MCMTVChain.md | 279 ++ .../qiskit.circuit.library.MCPhaseGate.md | 206 + .../0.46/qiskit.circuit.library.MCXGate.md | 207 + .../qiskit.circuit.library.MCXGrayCode.md | 171 + .../qiskit.circuit.library.MCXRecursive.md | 179 + .../0.46/qiskit.circuit.library.MCXVChain.md | 177 + .../0.46/qiskit.circuit.library.MSGate.md | 123 + .../0.46/qiskit.circuit.library.Measure.md | 316 ++ .../0.46/qiskit.circuit.library.NLocal.md | 462 ++ .../qiskit/0.46/qiskit.circuit.library.OR.md | 227 + ...skit.circuit.library.PauliEvolutionGate.md | 191 + .../qiskit.circuit.library.PauliFeatureMap.md | 418 ++ .../0.46/qiskit.circuit.library.PauliGate.md | 148 + .../qiskit.circuit.library.PauliTwoDesign.md | 329 ++ .../qiskit.circuit.library.Permutation.md | 229 + .../qiskit.circuit.library.PermutationGate.md | 157 + .../qiskit.circuit.library.PhaseEstimation.md | 246 ++ .../0.46/qiskit.circuit.library.PhaseGate.md | 203 + .../qiskit.circuit.library.PhaseOracle.md | 283 ++ ...skit.circuit.library.PiecewiseChebyshev.md | 241 + ...t.library.PiecewiseLinearPauliRotations.md | 278 ++ ...brary.PiecewisePolynomialPauliRotations.md | 310 ++ ...ircuit.library.PolynomialPauliRotations.md | 238 + .../0.46/qiskit.circuit.library.QAOAAnsatz.md | 345 ++ .../qiskit/0.46/qiskit.circuit.library.QFT.md | 249 ++ .../qiskit.circuit.library.QuadraticForm.md | 272 ++ .../qiskit.circuit.library.QuantumVolume.md | 234 + .../0.46/qiskit.circuit.library.RC3XGate.md | 123 + .../0.46/qiskit.circuit.library.RCCXGate.md | 123 + .../qiskit.circuit.library.RGQFTMultiplier.md | 256 ++ .../0.46/qiskit.circuit.library.RGate.md | 159 + .../0.46/qiskit.circuit.library.RVGate.md | 166 + .../0.46/qiskit.circuit.library.RXGate.md | 181 + .../0.46/qiskit.circuit.library.RXXGate.md | 183 + .../0.46/qiskit.circuit.library.RYGate.md | 181 + .../0.46/qiskit.circuit.library.RYYGate.md | 183 + .../0.46/qiskit.circuit.library.RZGate.md | 191 + .../0.46/qiskit.circuit.library.RZXGate.md | 223 + .../0.46/qiskit.circuit.library.RZZGate.md | 195 + .../qiskit.circuit.library.RealAmplitudes.md | 389 ++ .../0.46/qiskit.circuit.library.Reset.md | 316 ++ .../0.46/qiskit.circuit.library.SGate.md | 160 + .../0.46/qiskit.circuit.library.SXGate.md | 182 + .../0.46/qiskit.circuit.library.SXdgGate.md | 148 + .../0.46/qiskit.circuit.library.SdgGate.md | 160 + ...qiskit.circuit.library.StatePreparation.md | 211 + .../0.46/qiskit.circuit.library.SwapGate.md | 181 + .../0.46/qiskit.circuit.library.TGate.md | 160 + .../0.46/qiskit.circuit.library.TdgGate.md | 160 + .../0.46/qiskit.circuit.library.TwoLocal.md | 415 ++ .../0.46/qiskit.circuit.library.U1Gate.md | 208 + .../0.46/qiskit.circuit.library.U2Gate.md | 187 + .../0.46/qiskit.circuit.library.U3Gate.md | 204 + .../0.46/qiskit.circuit.library.UCGate.md | 169 + .../qiskit.circuit.library.UCPauliRotGate.md | 122 + .../0.46/qiskit.circuit.library.UCRXGate.md | 121 + .../0.46/qiskit.circuit.library.UCRYGate.md | 121 + .../0.46/qiskit.circuit.library.UCRZGate.md | 121 + .../0.46/qiskit.circuit.library.UGate.md | 187 + .../qiskit.circuit.library.UnitaryGate.md | 209 + .../qiskit.circuit.library.UnitaryOverlap.md | 256 ++ ...kit.circuit.library.VBERippleCarryAdder.md | 255 ++ .../qiskit.circuit.library.WeightedAdder.md | 251 ++ .../0.46/qiskit.circuit.library.XGate.md | 191 + .../qiskit/0.46/qiskit.circuit.library.XOR.md | 229 + .../qiskit.circuit.library.XXMinusYYGate.md | 193 + .../qiskit.circuit.library.XXPlusYYGate.md | 193 + .../0.46/qiskit.circuit.library.YGate.md | 191 + .../qiskit.circuit.library.ZFeatureMap.md | 367 ++ .../0.46/qiskit.circuit.library.ZGate.md | 199 + .../qiskit.circuit.library.ZZFeatureMap.md | 372 ++ .../0.46/qiskit.circuit.library.iSwapGate.md | 180 + .../0.46/qiskit.dagcircuit.DAGCircuit.md | 1026 +++++ .../0.46/qiskit.dagcircuit.DAGDepNode.md | 117 + .../0.46/qiskit.dagcircuit.DAGDependency.md | 390 ++ .../0.46/qiskit.dagcircuit.DAGInNode.md | 55 + .../qiskit/0.46/qiskit.dagcircuit.DAGNode.md | 45 + .../0.46/qiskit.dagcircuit.DAGOpNode.md | 69 + .../0.46/qiskit.dagcircuit.DAGOutNode.md | 55 + .../qiskit.extensions.SingleQubitUnitary.md | 424 ++ .../qiskit/0.46/qiskit.extensions.Snapshot.md | 322 ++ .../qiskit/0.46/qiskit.opflow.OperatorBase.md | 420 ++ ...qiskit.opflow.converters.AbelianGrouper.md | 74 + ...qiskit.opflow.converters.CircuitSampler.md | 108 + .../qiskit.opflow.converters.ConverterBase.md | 44 + ...skit.opflow.converters.DictToCircuitSum.md | 50 + ...skit.opflow.converters.PauliBasisChange.md | 268 ++ ...kit.opflow.converters.TwoQubitReduction.md | 50 + .../qiskit/0.46/qiskit.opflow.converters.md | 52 + .../qiskit.opflow.evolutions.EvolutionBase.md | 44 + ...skit.opflow.evolutions.EvolutionFactory.md | 48 + .../qiskit.opflow.evolutions.EvolvedOp.md | 337 ++ ...iskit.opflow.evolutions.MatrixEvolution.md | 44 + ...opflow.evolutions.PauliTrotterEvolution.md | 96 + .../0.46/qiskit.opflow.evolutions.QDrift.md | 60 + .../0.46/qiskit.opflow.evolutions.Suzuki.md | 69 + .../0.46/qiskit.opflow.evolutions.Trotter.md | 40 + ...it.opflow.evolutions.TrotterizationBase.md | 56 + ...opflow.evolutions.TrotterizationFactory.md | 49 + .../qiskit/0.46/qiskit.opflow.evolutions.md | 61 + ...opflow.expectations.AerPauliExpectation.md | 64 + ...kit.opflow.expectations.CVaRExpectation.md | 89 + ...kit.opflow.expectations.ExpectationBase.md | 64 + ....opflow.expectations.ExpectationFactory.md | 50 + ...t.opflow.expectations.MatrixExpectation.md | 64 + ...it.opflow.expectations.PauliExpectation.md | 68 + .../qiskit/0.46/qiskit.opflow.expectations.md | 46 + ...qiskit.opflow.gradients.CircuitGradient.md | 53 + .../qiskit.opflow.gradients.CircuitQFI.md | 53 + .../qiskit.opflow.gradients.DerivativeBase.md | 102 + .../0.46/qiskit.opflow.gradients.Gradient.md | 90 + .../qiskit.opflow.gradients.GradientBase.md | 45 + .../0.46/qiskit.opflow.gradients.Hessian.md | 87 + .../qiskit.opflow.gradients.HessianBase.md | 43 + ...qiskit.opflow.gradients.NaturalGradient.md | 119 + .../0.46/qiskit.opflow.gradients.QFI.md | 66 + .../0.46/qiskit.opflow.gradients.QFIBase.md | 48 + .../qiskit/0.46/qiskit.opflow.gradients.md | 132 + .../0.46/qiskit.opflow.list_ops.ComposedOp.md | 254 ++ .../0.46/qiskit.opflow.list_ops.ListOp.md | 518 +++ .../0.46/qiskit.opflow.list_ops.SummedOp.md | 253 ++ .../0.46/qiskit.opflow.list_ops.TensoredOp.md | 218 + .../api/qiskit/0.46/qiskit.opflow.list_ops.md | 54 + .../qiskit.opflow.primitive_ops.CircuitOp.md | 338 ++ .../qiskit.opflow.primitive_ops.MatrixOp.md | 306 ++ .../qiskit.opflow.primitive_ops.PauliOp.md | 337 ++ .../qiskit.opflow.primitive_ops.PauliSumOp.md | 449 ++ ...qiskit.opflow.primitive_ops.PrimitiveOp.md | 429 ++ ....opflow.primitive_ops.TaperedPauliSumOp.md | 130 + ...iskit.opflow.primitive_ops.Z2Symmetries.md | 220 + .../0.46/qiskit.opflow.primitive_ops.md | 51 + ...qiskit.opflow.state_fns.CVaRMeasurement.md | 352 ++ .../qiskit.opflow.state_fns.CircuitStateFn.md | 375 ++ .../qiskit.opflow.state_fns.DictStateFn.md | 307 ++ ...qiskit.opflow.state_fns.OperatorStateFn.md | 272 ++ ...it.opflow.state_fns.SparseVectorStateFn.md | 281 ++ .../0.46/qiskit.opflow.state_fns.StateFn.md | 461 ++ .../qiskit.opflow.state_fns.VectorStateFn.md | 306 ++ .../qiskit/0.46/qiskit.opflow.state_fns.md | 50 + .../0.46/qiskit.passmanager.BaseController.md | 73 + .../qiskit.passmanager.BasePassManager.md | 141 + ...iskit.passmanager.ConditionalController.md | 95 + .../qiskit.passmanager.DoWhileController.md | 97 + .../0.46/qiskit.passmanager.FlowController.md | 168 + ...qiskit.passmanager.FlowControllerLinear.md | 95 + .../0.46/qiskit.passmanager.GenericPass.md | 97 + .../qiskit.passmanager.PassManagerState.md | 40 + .../0.46/qiskit.passmanager.PropertySet.md | 102 + .../0.46/qiskit.passmanager.WorkflowStatus.md | 50 + .../qiskit.primitives.BackendEstimator.md | 172 + .../0.46/qiskit.primitives.BackendSampler.md | 153 + .../0.46/qiskit.primitives.BaseEstimator.md | 132 + .../0.46/qiskit.primitives.BaseSampler.md | 96 + .../0.46/qiskit.primitives.Estimator.md | 137 + .../0.46/qiskit.primitives.EstimatorResult.md | 81 + .../qiskit/0.46/qiskit.primitives.Sampler.md | 105 + .../0.46/qiskit.primitives.SamplerResult.md | 81 + .../qiskit/0.46/qiskit.providers.Backend.md | 28 + .../qiskit/0.46/qiskit.providers.BackendV1.md | 213 + .../qiskit/0.46/qiskit.providers.BackendV2.md | 382 ++ .../qiskit.providers.BackendV2Converter.md | 333 ++ docs/api/qiskit/0.46/qiskit.providers.Job.md | 28 + .../qiskit/0.46/qiskit.providers.JobStatus.md | 62 + .../api/qiskit/0.46/qiskit.providers.JobV1.md | 170 + .../qiskit/0.46/qiskit.providers.Options.md | 125 + .../qiskit/0.46/qiskit.providers.Provider.md | 28 + .../0.46/qiskit.providers.ProviderV1.md | 76 + .../0.46/qiskit.providers.QubitProperties.md | 42 + ....providers.basic_provider.BasicProvider.md | 76 + ...iders.basic_provider.BasicProviderError.md | 20 + ...oviders.basic_provider.BasicProviderJob.md | 184 + ...providers.basic_provider.BasicSimulator.md | 413 ++ ...qiskit.providers.basicaer.BasicAerError.md | 24 + .../qiskit.providers.basicaer.BasicAerJob.md | 180 + ...kit.providers.basicaer.BasicAerProvider.md | 80 + ...skit.providers.basicaer.QasmSimulatorPy.md | 243 + ...oviders.basicaer.StatevectorSimulatorPy.md | 243 + ...t.providers.basicaer.UnitarySimulatorPy.md | 252 ++ .../qiskit.providers.convert_to_target.md | 26 + ...s.fake_provider.ConfigurableFakeBackend.md | 164 + .../qiskit.providers.fake_provider.Fake1Q.md | 136 + ...kit.providers.fake_provider.FakeAlmaden.md | 175 + ...t.providers.fake_provider.FakeAlmadenV2.md | 361 ++ ...skit.providers.fake_provider.FakeArmonk.md | 183 + ...it.providers.fake_provider.FakeArmonkV2.md | 355 ++ ...skit.providers.fake_provider.FakeAthens.md | 179 + ...it.providers.fake_provider.FakeAthensV2.md | 351 ++ ...it.providers.fake_provider.FakeAuckland.md | 351 ++ ...providers.fake_provider.FakeBackend5QV2.md | 331 ++ ...t.providers.fake_provider.FakeBackendV2.md | 331 ++ ...iskit.providers.fake_provider.FakeBelem.md | 179 + ...kit.providers.fake_provider.FakeBelemV2.md | 351 ++ ....providers.fake_provider.FakeBoeblingen.md | 189 + ...roviders.fake_provider.FakeBoeblingenV2.md | 361 ++ ...skit.providers.fake_provider.FakeBogota.md | 179 + ...it.providers.fake_provider.FakeBogotaV2.md | 351 ++ ...it.providers.fake_provider.FakeBrooklyn.md | 179 + ....providers.fake_provider.FakeBrooklynV2.md | 351 ++ ....providers.fake_provider.FakeBurlington.md | 171 + ...roviders.fake_provider.FakeBurlingtonV2.md | 357 ++ ...iskit.providers.fake_provider.FakeCairo.md | 179 + ...kit.providers.fake_provider.FakeCairoV2.md | 351 ++ ...t.providers.fake_provider.FakeCambridge.md | 177 + ...providers.fake_provider.FakeCambridgeV2.md | 363 ++ ....providers.fake_provider.FakeCasablanca.md | 179 + ...roviders.fake_provider.FakeCasablancaV2.md | 351 ++ ...iskit.providers.fake_provider.FakeEssex.md | 173 + ...kit.providers.fake_provider.FakeEssexV2.md | 359 ++ ...skit.providers.fake_provider.FakeGeneva.md | 351 ++ ...t.providers.fake_provider.FakeGuadalupe.md | 179 + ...providers.fake_provider.FakeGuadalupeV2.md | 351 ++ ...iskit.providers.fake_provider.FakeHanoi.md | 179 + ...kit.providers.fake_provider.FakeHanoiV2.md | 351 ++ ...kit.providers.fake_provider.FakeJakarta.md | 179 + ...t.providers.fake_provider.FakeJakartaV2.md | 351 ++ ...roviders.fake_provider.FakeJohannesburg.md | 175 + ...viders.fake_provider.FakeJohannesburgV2.md | 361 ++ ...kit.providers.fake_provider.FakeKolkata.md | 179 + ...t.providers.fake_provider.FakeKolkataV2.md | 351 ++ ...iskit.providers.fake_provider.FakeLagos.md | 179 + ...kit.providers.fake_provider.FakeLagosV2.md | 351 ++ ...qiskit.providers.fake_provider.FakeLima.md | 179 + ...skit.providers.fake_provider.FakeLimaV2.md | 351 ++ ...skit.providers.fake_provider.FakeLondon.md | 173 + ...it.providers.fake_provider.FakeLondonV2.md | 359 ++ ...t.providers.fake_provider.FakeManhattan.md | 179 + ...providers.fake_provider.FakeManhattanV2.md | 351 ++ ...skit.providers.fake_provider.FakeManila.md | 179 + ...it.providers.fake_provider.FakeManilaV2.md | 351 ++ ...t.providers.fake_provider.FakeMelbourne.md | 140 + ...providers.fake_provider.FakeMelbourneV2.md | 351 ++ ...it.providers.fake_provider.FakeMontreal.md | 179 + ....providers.fake_provider.FakeMontrealV2.md | 351 ++ ...skit.providers.fake_provider.FakeMumbai.md | 179 + ...rs.fake_provider.FakeMumbaiFractionalCX.md | 327 ++ ...it.providers.fake_provider.FakeMumbaiV2.md | 351 ++ ...kit.providers.fake_provider.FakeNairobi.md | 179 + ...t.providers.fake_provider.FakeNairobiV2.md | 351 ++ ...providers.fake_provider.FakeOpenPulse2Q.md | 149 + ...providers.fake_provider.FakeOpenPulse3Q.md | 147 + ...qiskit.providers.fake_provider.FakeOslo.md | 351 ++ ...kit.providers.fake_provider.FakeOurense.md | 171 + ...t.providers.fake_provider.FakeOurenseV2.md | 357 ++ ...iskit.providers.fake_provider.FakeParis.md | 191 + ...kit.providers.fake_provider.FakeParisV2.md | 363 ++ ...iskit.providers.fake_provider.FakePerth.md | 351 ++ ...roviders.fake_provider.FakePoughkeepsie.md | 144 + ...viders.fake_provider.FakePoughkeepsieV2.md | 351 ++ ...skit.providers.fake_provider.FakePrague.md | 351 ++ ...it.providers.fake_provider.FakeProvider.md | 82 + ....fake_provider.FakeProviderForBackendV2.md | 82 + ...oviders.fake_provider.FakeQasmSimulator.md | 138 + ...iskit.providers.fake_provider.FakeQuito.md | 179 + ...kit.providers.fake_provider.FakeQuitoV2.md | 351 ++ ...t.providers.fake_provider.FakeRochester.md | 165 + ...providers.fake_provider.FakeRochesterV2.md | 351 ++ ...qiskit.providers.fake_provider.FakeRome.md | 179 + ...skit.providers.fake_provider.FakeRomeV2.md | 351 ++ ...providers.fake_provider.FakeRueschlikon.md | 140 + ...it.providers.fake_provider.FakeSantiago.md | 179 + ....providers.fake_provider.FakeSantiagoV2.md | 351 ++ ....providers.fake_provider.FakeSherbrooke.md | 351 ++ ...t.providers.fake_provider.FakeSingapore.md | 175 + ...providers.fake_provider.FakeSingaporeV2.md | 361 ++ ...skit.providers.fake_provider.FakeSydney.md | 179 + ...it.providers.fake_provider.FakeSydneyV2.md | 351 ++ ...it.providers.fake_provider.FakeTenerife.md | 142 + ...iskit.providers.fake_provider.FakeTokyo.md | 144 + ...kit.providers.fake_provider.FakeToronto.md | 179 + ...t.providers.fake_provider.FakeTorontoV2.md | 351 ++ ...it.providers.fake_provider.FakeValencia.md | 179 + ....providers.fake_provider.FakeValenciaV2.md | 351 ++ ...qiskit.providers.fake_provider.FakeVigo.md | 171 + ...skit.providers.fake_provider.FakeVigoV2.md | 357 ++ ....providers.fake_provider.FakeWashington.md | 179 + ...roviders.fake_provider.FakeWashingtonV2.md | 351 ++ ...it.providers.fake_provider.FakeYorktown.md | 173 + ....providers.fake_provider.FakeYorktownV2.md | 359 ++ ...roviders.fake_provider.GenericBackendV2.md | 354 ++ ...t.providers.models.BackendConfiguration.md | 138 + ...skit.providers.models.BackendProperties.md | 320 ++ .../qiskit.providers.models.BackendStatus.md | 70 + .../0.46/qiskit.providers.models.Command.md | 71 + .../qiskit.providers.models.GateConfig.md | 86 + .../qiskit.providers.models.GateProperties.md | 83 + .../0.46/qiskit.providers.models.JobStatus.md | 86 + .../0.46/qiskit.providers.models.Nduv.md | 89 + ...viders.models.PulseBackendConfiguration.md | 284 ++ .../qiskit.providers.models.PulseDefaults.md | 64 + ...oviders.models.QasmBackendConfiguration.md | 204 + .../qiskit.providers.models.UchannelLO.md | 79 + .../qiskit.pulse.InstructionScheduleMap.md | 241 + docs/api/qiskit/0.46/qiskit.pulse.Schedule.md | 498 +++ .../qiskit/0.46/qiskit.pulse.ScheduleBlock.md | 662 +++ .../qiskit.pulse.channels.AcquireChannel.md | 68 + .../qiskit.pulse.channels.ControlChannel.md | 68 + .../qiskit.pulse.channels.DriveChannel.md | 68 + .../qiskit.pulse.channels.MeasureChannel.md | 68 + .../0.46/qiskit.pulse.channels.MemorySlot.md | 68 + .../qiskit.pulse.channels.RegisterSlot.md | 68 + .../qiskit.pulse.channels.SnapshotChannel.md | 64 + .../0.46/qiskit.pulse.instructions.Acquire.md | 289 ++ .../0.46/qiskit.pulse.instructions.Call.md | 303 ++ .../0.46/qiskit.pulse.instructions.Delay.md | 263 ++ .../0.46/qiskit.pulse.instructions.Play.md | 257 ++ .../qiskit.pulse.instructions.Reference.md | 268 ++ ...skit.pulse.instructions.RelativeBarrier.md | 244 + .../qiskit.pulse.instructions.SetFrequency.md | 265 ++ .../qiskit.pulse.instructions.SetPhase.md | 263 ++ ...iskit.pulse.instructions.ShiftFrequency.md | 255 ++ .../qiskit.pulse.instructions.ShiftPhase.md | 267 ++ .../qiskit.pulse.instructions.Snapshot.md | 261 ++ .../qiskit.pulse.instructions.TimeBlockade.md | 280 ++ ...qiskit.pulse.library.Constant_class.rst.md | 45 + .../qiskit.pulse.library.Cos_class.rst.md | 44 + .../qiskit.pulse.library.Drag_class.rst.md | 61 + .../qiskit.pulse.library.GaussianDeriv.md | 44 + .../qiskit.pulse.library.GaussianSquare.md | 79 + ...qiskit.pulse.library.GaussianSquareDrag.md | 90 + ...qiskit.pulse.library.Gaussian_class.rst.md | 50 + .../qiskit.pulse.library.ParametricPulse.md | 138 + ...qiskit.pulse.library.Sawtooth_class.rst.md | 45 + .../0.46/qiskit.pulse.library.SechDeriv.md | 44 + .../0.46/qiskit.pulse.library.Sech_fun.rst.md | 53 + .../qiskit.pulse.library.Sin_class.rst.md | 44 + .../qiskit.pulse.library.Square_fun.rst.md | 45 + .../qiskit.pulse.library.SymbolicPulse.md | 258 ++ ...qiskit.pulse.library.Triangle_class.rst.md | 44 + .../0.46/qiskit.pulse.library.Waveform.md | 113 + ...skit.pulse.library.gaussian_square_echo.md | 77 + ...qiskit.pulse.transforms.AlignEquispaced.md | 62 + .../0.46/qiskit.pulse.transforms.AlignFunc.md | 82 + .../0.46/qiskit.pulse.transforms.AlignLeft.md | 52 + .../qiskit.pulse.transforms.AlignRight.md | 52 + ...qiskit.pulse.transforms.AlignSequential.md | 52 + .../0.46/qiskit.qobj.GateCalibration.md | 65 + .../0.46/qiskit.qobj.PulseLibraryItem.md | 63 + docs/api/qiskit/0.46/qiskit.qobj.PulseQobj.md | 84 + .../0.46/qiskit.qobj.PulseQobjConfig.md | 73 + .../0.46/qiskit.qobj.PulseQobjExperiment.md | 66 + .../qiskit.qobj.PulseQobjExperimentConfig.md | 64 + .../0.46/qiskit.qobj.PulseQobjInstruction.md | 78 + .../qiskit.qobj.QasmExperimentCalibrations.md | 62 + docs/api/qiskit/0.46/qiskit.qobj.QasmQobj.md | 84 + .../qiskit/0.46/qiskit.qobj.QasmQobjConfig.md | 75 + .../0.46/qiskit.qobj.QasmQobjExperiment.md | 66 + .../qiskit.qobj.QasmQobjExperimentConfig.md | 63 + .../0.46/qiskit.qobj.QasmQobjInstruction.md | 73 + .../0.46/qiskit.qobj.QobjExperimentHeader.md | 62 + .../api/qiskit/0.46/qiskit.qobj.QobjHeader.md | 62 + .../0.46/qiskit.qobj.QobjMeasurementOption.md | 63 + .../0.46/qiskit.quantum_info.CNOTDihedral.md | 361 ++ .../qiskit/0.46/qiskit.quantum_info.Chi.md | 395 ++ .../qiskit/0.46/qiskit.quantum_info.Choi.md | 407 ++ .../0.46/qiskit.quantum_info.Clifford.md | 661 +++ .../0.46/qiskit.quantum_info.DensityMatrix.md | 703 +++ .../qiskit/0.46/qiskit.quantum_info.Kraus.md | 395 ++ .../0.46/qiskit.quantum_info.Operator.md | 488 ++ .../qiskit/0.46/qiskit.quantum_info.PTM.md | 403 ++ .../qiskit/0.46/qiskit.quantum_info.Pauli.md | 589 +++ .../0.46/qiskit.quantum_info.PauliList.md | 865 ++++ .../0.46/qiskit.quantum_info.Quaternion.md | 126 + .../0.46/qiskit.quantum_info.ScalarOp.md | 302 ++ .../0.46/qiskit.quantum_info.SparsePauliOp.md | 881 ++++ .../qiskit.quantum_info.StabilizerState.md | 438 ++ .../0.46/qiskit.quantum_info.Statevector.md | 732 +++ .../0.46/qiskit.quantum_info.Stinespring.md | 399 ++ .../0.46/qiskit.quantum_info.SuperOp.md | 395 ++ .../0.46/qiskit.quantum_info.Z2Symmetries.md | 192 + .../0.46/qiskit.quantum_info.pauli_basis.md | 31 + .../qiskit.result.BaseReadoutMitigator.md | 69 + ...iskit.result.CorrelatedReadoutMitigator.md | 166 + docs/api/qiskit/0.46/qiskit.result.Counts.md | 204 + .../qiskit.result.LocalReadoutMitigator.md | 172 + .../0.46/qiskit.result.ProbDistribution.md | 161 + .../0.46/qiskit.result.QuasiDistribution.md | 199 + docs/api/qiskit/0.46/qiskit.result.Result.md | 258 ++ .../qiskit/0.46/qiskit.result.ResultError.md | 34 + .../qiskit.synthesis.EvolutionSynthesis.md | 56 + .../0.46/qiskit.synthesis.LieTrotter.md | 79 + .../qiskit.synthesis.MatrixExponential.md | 58 + ...iskit.synthesis.OneQubitEulerDecomposer.md | 106 + .../0.46/qiskit.synthesis.ProductFormula.md | 66 + .../qiskit/0.46/qiskit.synthesis.QDrift.md | 68 + ...it.synthesis.SolovayKitaevDecomposition.md | 93 + .../0.46/qiskit.synthesis.SuzukiTrotter.md | 86 + ...iskit.synthesis.TwoQubitBasisDecomposer.md | 89 + .../0.46/qiskit.synthesis.XXDecomposer.md | 41 + .../0.46/qiskit.synthesis.unitary.aqc.AQC.md | 49 + ...ynthesis.unitary.aqc.ApproximateCircuit.md | 240 + ...esis.unitary.aqc.ApproximatingObjective.md | 74 + ...t.synthesis.unitary.aqc.CNOTUnitCircuit.md | 242 + ...synthesis.unitary.aqc.CNOTUnitObjective.md | 43 + ...is.unitary.aqc.DefaultCNOTUnitObjective.md | 85 + ...hesis.unitary.aqc.FastCNOTUnitObjective.md | 69 + .../0.46/qiskit.transpiler.AnalysisPass.md | 109 + .../0.46/qiskit.transpiler.CouplingMap.md | 426 ++ .../qiskit.transpiler.FencedDAGCircuit.md | 22 + .../qiskit.transpiler.FencedPropertySet.md | 22 + .../qiskit.transpiler.InstructionDurations.md | 116 + ...qiskit.transpiler.InstructionProperties.md | 52 + .../qiskit/0.46/qiskit.transpiler.Layout.md | 267 ++ .../0.46/qiskit.transpiler.PassManager.md | 217 + .../qiskit.transpiler.PassManagerConfig.md | 70 + .../qiskit.transpiler.StagedPassManager.md | 241 + .../qiskit/0.46/qiskit.transpiler.Target.md | 649 +++ .../qiskit.transpiler.TransformationPass.md | 109 + .../0.46/qiskit.transpiler.TranspileLayout.md | 234 + .../qiskit.transpiler.passes.ALAPSchedule.md | 130 + ....transpiler.passes.ALAPScheduleAnalysis.md | 133 + ...it.transpiler.passes.AQCSynthesisPlugin.md | 181 + .../qiskit.transpiler.passes.ASAPSchedule.md | 134 + ....transpiler.passes.ASAPScheduleAnalysis.md | 133 + .../qiskit.transpiler.passes.AlignMeasures.md | 165 + .../qiskit.transpiler.passes.ApplyLayout.md | 121 + ...r.passes.BarrierBeforeFinalMeasurements.md | 103 + .../qiskit.transpiler.passes.BasicSwap.md | 127 + ...iskit.transpiler.passes.BasisTranslator.md | 172 + .../qiskit.transpiler.passes.CSPLayout.md | 118 + ...qiskit.transpiler.passes.CXCancellation.md | 113 + ...it.transpiler.passes.CheckGateDirection.md | 114 + .../0.46/qiskit.transpiler.passes.CheckMap.md | 116 + .../qiskit.transpiler.passes.Collect1qRuns.md | 105 + ...iskit.transpiler.passes.Collect2qBlocks.md | 105 + ...skit.transpiler.passes.CollectCliffords.md | 119 + ...ranspiler.passes.CollectLinearFunctions.md | 119 + ...t.transpiler.passes.CollectMultiQBlocks.md | 133 + ...t.transpiler.passes.CommutationAnalysis.md | 105 + ...anspiler.passes.CommutativeCancellation.md | 130 + ...r.passes.CommutativeInverseCancellation.md | 113 + ...transpiler.passes.Commuting2qGateRouter.md | 206 + ...kit.transpiler.passes.ConsolidateBlocks.md | 121 + ...transpiler.passes.ConstrainedReschedule.md | 175 + ...t.transpiler.passes.ContainsInstruction.md | 110 + ...nspiler.passes.ConvertConditionsToIfOps.md | 111 + .../0.46/qiskit.transpiler.passes.CountOps.md | 103 + ...t.transpiler.passes.CountOpsLongestPath.md | 103 + ...spiler.passes.CrosstalkAdaptiveSchedule.md | 343 ++ .../qiskit.transpiler.passes.DAGFixedPoint.md | 103 + ...qiskit.transpiler.passes.DAGLongestPath.md | 101 + .../qiskit.transpiler.passes.Decompose.md | 119 + .../qiskit.transpiler.passes.DenseLayout.md | 125 + .../0.46/qiskit.transpiler.passes.Depth.md | 105 + ...t.transpiler.passes.DynamicalDecoupling.md | 202 + ...nspiler.passes.EchoRZXWeylDecomposition.md | 128 + ...it.transpiler.passes.EnlargeWithAncilla.md | 119 + .../qiskit.transpiler.passes.FixedPoint.md | 109 + ...transpiler.passes.FullAncillaAllocation.md | 141 + .../qiskit.transpiler.passes.GateDirection.md | 153 + .../qiskit.transpiler.passes.GatesInBasis.md | 108 + ...it.transpiler.passes.HighLevelSynthesis.md | 152 + ...qiskit.transpiler.passes.HoareOptimizer.md | 119 + ...nspiler.passes.InstructionDurationCheck.md | 118 + ...t.transpiler.passes.InverseCancellation.md | 123 + ...skit.transpiler.passes.Layout2qDistance.md | 110 + ...nspiler.passes.LinearFunctionsSynthesis.md | 124 + ...er.passes.LinearFunctionsToPermutations.md | 109 + .../qiskit.transpiler.passes.LookaheadSwap.md | 145 + ...transpiler.passes.MergeAdjacentBarriers.md | 138 + .../qiskit.transpiler.passes.MinimumPoint.md | 121 + ...t.transpiler.passes.NoiseAdaptiveLayout.md | 156 + ...skit.transpiler.passes.NormalizeRXAngle.md | 156 + ...skit.transpiler.passes.NumTensorFactors.md | 103 + ...iskit.transpiler.passes.Optimize1qGates.md | 158 + ...ler.passes.Optimize1qGatesDecomposition.md | 129 + ...passes.Optimize1qGatesSimpleCommutation.md | 123 + ...kit.transpiler.passes.OptimizeCliffords.md | 113 + .../0.46/qiskit.transpiler.passes.PadDelay.md | 149 + ...ranspiler.passes.PadDynamicalDecoupling.md | 207 + .../qiskit.transpiler.passes.PulseGates.md | 178 + ....transpiler.passes.RXCalibrationBuilder.md | 187 + ...transpiler.passes.RZXCalibrationBuilder.md | 199 + ...iler.passes.RZXCalibrationBuilderNoEcho.md | 201 + ...qiskit.transpiler.passes.RemoveBarriers.md | 124 + ...passes.RemoveDiagonalGatesBeforeMeasure.md | 115 + ...anspiler.passes.RemoveFinalMeasurements.md | 117 + ...ranspiler.passes.RemoveResetInZeroState.md | 113 + ....passes.ResetAfterMeasureSimplification.md | 103 + .../qiskit.transpiler.passes.SabreLayout.md | 213 + ...qiskit.transpiler.passes.SabrePreLayout.md | 171 + .../qiskit.transpiler.passes.SabreSwap.md | 178 + .../qiskit.transpiler.passes.SetIOLatency.md | 116 + .../qiskit.transpiler.passes.SetLayout.md | 126 + .../0.46/qiskit.transpiler.passes.Size.md | 107 + .../qiskit.transpiler.passes.SolovayKitaev.md | 206 + ...ranspiler.passes.SolovayKitaevSynthesis.md | 173 + ...qiskit.transpiler.passes.StochasticSwap.md | 139 + ....transpiler.passes.TemplateOptimization.md | 122 + ...it.transpiler.passes.TimeUnitConversion.md | 132 + ...iler.passes.TranslateParameterizedGates.md | 174 + .../qiskit.transpiler.passes.TrivialLayout.md | 125 + ...skit.transpiler.passes.UnitarySynthesis.md | 135 + ...qiskit.transpiler.passes.Unroll3qOrMore.md | 124 + ...anspiler.passes.UnrollCustomDefinitions.md | 136 + ...qiskit.transpiler.passes.UnrollForLoops.md | 123 + .../0.46/qiskit.transpiler.passes.Unroller.md | 131 + .../qiskit.transpiler.passes.VF2Layout.md | 137 + .../qiskit.transpiler.passes.VF2PostLayout.md | 139 + ...it.transpiler.passes.ValidatePulseGates.md | 132 + .../0.46/qiskit.transpiler.passes.Width.md | 103 + ...nthesis.plugin.HighLevelSynthesisPlugin.md | 48 + ....plugin.HighLevelSynthesisPluginManager.md | 36 + ...synthesis.plugin.UnitarySynthesisPlugin.md | 200 + ...is.plugin.UnitarySynthesisPluginManager.md | 20 + ...s.plugin.unitary_synthesis_plugin_names.md | 26 + ...smanagers.plugin.PassManagerStagePlugin.md | 39 + ...rs.plugin.PassManagerStagePluginManager.md | 32 + .../0.46/qiskit.utils.QuantumInstance.md | 316 ++ ...kit.utils.mitigation.CompleteMeasFitter.md | 128 + ...kit.utils.mitigation.TensoredMeasFitter.md | 139 + .../qiskit.visualization.array_to_latex.md | 51 + ...ualization.circuit.qcstyle.DefaultStyle.md | 161 + .../qiskit.visualization.circuit_drawer.md | 91 + .../0.46/qiskit.visualization.dag_drawer.md | 62 + ...iskit.visualization.pass_manager_drawer.md | 62 + ...it.visualization.plot_bloch_multivector.md | 85 + .../qiskit.visualization.plot_bloch_vector.md | 62 + ...iskit.visualization.plot_circuit_layout.md | 62 + .../qiskit.visualization.plot_coupling_map.md | 62 + .../qiskit.visualization.plot_distribution.md | 79 + .../qiskit.visualization.plot_error_map.md | 51 + .../qiskit.visualization.plot_gate_map.md | 62 + .../qiskit.visualization.plot_histogram.md | 84 + .../qiskit.visualization.plot_state_city.md | 89 + .../qiskit.visualization.plot_state_hinton.md | 62 + ...iskit.visualization.plot_state_paulivec.md | 92 + ...qiskit.visualization.plot_state_qsphere.md | 81 + ...qiskit.visualization.pulse.IQXDebugging.md | 113 + .../qiskit.visualization.pulse.IQXSimple.md | 110 + .../qiskit.visualization.pulse.IQXStandard.md | 110 + .../0.46/qiskit.visualization.pulse_drawer.md | 323 ++ .../qiskit.visualization.timeline_drawer.md | 321 ++ ...skit.visualization.visualize_transition.md | 39 + docs/api/qiskit/0.46/qobj.md | 51 + docs/api/qiskit/0.46/qpy.md | 1088 +++++ docs/api/qiskit/0.46/quantum_info.md | 944 ++++ docs/api/qiskit/0.46/result.md | 160 + docs/api/qiskit/0.46/scheduler.md | 122 + docs/api/qiskit/0.46/synthesis.md | 729 +++ docs/api/qiskit/0.46/synthesis_aqc.md | 168 + docs/api/qiskit/0.46/tools.md | 140 + docs/api/qiskit/0.46/tools_jupyter.md | 86 + docs/api/qiskit/0.46/transpiler.md | 980 ++++ .../qiskit/0.46/transpiler_builtin_plugins.md | 8 + docs/api/qiskit/0.46/transpiler_passes.md | 162 + docs/api/qiskit/0.46/transpiler_plugins.md | 170 + docs/api/qiskit/0.46/transpiler_preset.md | 398 ++ .../0.46/transpiler_synthesis_plugins.md | 169 + docs/api/qiskit/0.46/utils.md | 712 +++ docs/api/qiskit/0.46/utils_mitigation.md | 37 + docs/api/qiskit/0.46/visualization.md | 245 + public/images/api/qiskit/0.46/circuit-1.png | Bin 0 -> 4978 bytes public/images/api/qiskit/0.46/circuit-2.png | Bin 0 -> 3885 bytes public/images/api/qiskit/0.46/circuit-3.png | Bin 0 -> 5628 bytes public/images/api/qiskit/0.46/circuit-4.png | Bin 0 -> 27444 bytes public/images/api/qiskit/0.46/circuit-5.png | Bin 0 -> 7137 bytes .../api/qiskit/0.46/circuit_library-1.png | Bin 0 -> 5904 bytes .../images/api/qiskit/0.46/converters-1.png | Bin 0 -> 8110 bytes public/images/api/qiskit/0.46/depth.gif | Bin 0 -> 2874095 bytes public/images/api/qiskit/0.46/mapping.png | Bin 0 -> 60165 bytes .../0.46/providers_fake_provider-1_00.png | Bin 0 -> 12644 bytes .../0.46/providers_fake_provider-1_01.png | Bin 0 -> 21668 bytes .../0.46/providers_fake_provider-1_02.png | Bin 0 -> 14483 bytes public/images/api/qiskit/0.46/pulse-1.png | Bin 0 -> 15975 bytes public/images/api/qiskit/0.46/pulse-2.png | Bin 0 -> 16712 bytes public/images/api/qiskit/0.46/pulse-3.png | Bin 0 -> 31312 bytes public/images/api/qiskit/0.46/pulse-4.png | Bin 0 -> 11069 bytes public/images/api/qiskit/0.46/pulse-5.png | Bin 0 -> 54614 bytes public/images/api/qiskit/0.46/pulse-6.png | Bin 0 -> 19242 bytes public/images/api/qiskit/0.46/pulse-7.png | Bin 0 -> 16404 bytes public/images/api/qiskit/0.46/pulse-8.png | Bin 0 -> 11645 bytes public/images/api/qiskit/0.46/pulse-9.png | Bin 0 -> 14096 bytes public/images/api/qiskit/0.46/qasm3-1.png | Bin 0 -> 25454 bytes .../0.46/qiskit-circuit-ControlledGate-1.png | Bin 0 -> 4422 bytes .../0.46/qiskit-circuit-ControlledGate-2.png | Bin 0 -> 6965 bytes .../0.46/qiskit-circuit-InstructionSet-1.png | Bin 0 -> 8858 bytes .../0.46/qiskit-circuit-Operation-1.png | Bin 0 -> 5552 bytes .../0.46/qiskit-circuit-Parameter-1_00.png | Bin 0 -> 1697 bytes .../0.46/qiskit-circuit-Parameter-1_01.png | Bin 0 -> 5365 bytes .../0.46/qiskit-circuit-QuantumCircuit-1.png | Bin 0 -> 6702 bytes .../0.46/qiskit-circuit-QuantumCircuit-2.png | Bin 0 -> 15875 bytes .../qiskit-circuit-QuantumCircuit-3_00.png | Bin 0 -> 3595 bytes .../qiskit-circuit-QuantumCircuit-3_01.png | Bin 0 -> 3580 bytes .../qiskit-circuit-QuantumCircuit-4_00.png | Bin 0 -> 3527 bytes .../qiskit-circuit-QuantumCircuit-4_01.png | Bin 0 -> 3850 bytes .../0.46/qiskit-circuit-QuantumCircuit-5.png | Bin 0 -> 3673 bytes .../0.46/qiskit-circuit-QuantumCircuit-6.png | Bin 0 -> 4169 bytes .../0.46/qiskit-circuit-library-AND-1.png | Bin 0 -> 16847 bytes .../0.46/qiskit-circuit-library-AND-2.png | Bin 0 -> 17434 bytes ...skit-circuit-library-FourierChecking-1.png | Bin 0 -> 11424 bytes .../0.46/qiskit-circuit-library-GMS-1.png | Bin 0 -> 12635 bytes .../0.46/qiskit-circuit-library-GR-1.png | Bin 0 -> 18949 bytes .../0.46/qiskit-circuit-library-GRX-1.png | Bin 0 -> 18704 bytes .../0.46/qiskit-circuit-library-GRY-1.png | Bin 0 -> 18949 bytes .../0.46/qiskit-circuit-library-GRZ-1.png | Bin 0 -> 12178 bytes .../qiskit-circuit-library-GraphState-1.png | Bin 0 -> 15618 bytes ...circuit-library-HiddenLinearFunction-1.png | Bin 0 -> 12956 bytes .../0.46/qiskit-circuit-library-IQP-1.png | Bin 0 -> 6586 bytes .../0.46/qiskit-circuit-library-IQP-2.png | Bin 0 -> 14797 bytes .../qiskit-circuit-library-InnerProduct-1.png | Bin 0 -> 14228 bytes .../qiskit-circuit-library-MCMTVChain-1.png | Bin 0 -> 13705 bytes .../0.46/qiskit-circuit-library-OR-1.png | Bin 0 -> 20190 bytes .../0.46/qiskit-circuit-library-OR-2.png | Bin 0 -> 18418 bytes ...iskit-circuit-library-PauliTwoDesign-1.png | Bin 0 -> 10634 bytes .../qiskit-circuit-library-Permutation-1.png | Bin 0 -> 9125 bytes .../qiskit-circuit-library-Permutation-2.png | Bin 0 -> 15619 bytes ...skit-circuit-library-PermutationGate-1.png | Bin 0 -> 7652 bytes ...skit-circuit-library-PermutationGate-2.png | Bin 0 -> 15209 bytes ...skit-circuit-library-PhaseEstimation-1.png | Bin 0 -> 12047 bytes ...t-circuit-library-PiecewiseChebyshev-1.png | Bin 0 -> 7651 bytes .../0.46/qiskit-circuit-library-QFT-1.png | Bin 0 -> 11619 bytes .../0.46/qiskit-circuit-library-QFT-2.png | Bin 0 -> 11789 bytes .../0.46/qiskit-circuit-library-QFT-3.png | Bin 0 -> 11890 bytes ...qiskit-circuit-library-QuantumVolume-1.png | Bin 0 -> 9480 bytes ...qiskit-circuit-library-QuantumVolume-2.png | Bin 0 -> 18170 bytes .../0.46/qiskit-circuit-library-XOR-1.png | Bin 0 -> 12576 bytes .../qiskit-pulse-library-SymbolicPulse-1.png | Bin 0 -> 11401 bytes .../qiskit-quantum_info-Statevector-1.png | Bin 0 -> 7558 bytes ...spiler-passes-DynamicalDecoupling-1_00.png | Bin 0 -> 22803 bytes ...spiler-passes-DynamicalDecoupling-1_01.png | Bin 0 -> 23583 bytes ...ler-passes-PadDynamicalDecoupling-1_00.png | Bin 0 -> 22803 bytes ...ler-passes-PadDynamicalDecoupling-1_01.png | Bin 0 -> 23583 bytes ...kit-transpiler-passes-RemoveBarriers-1.png | Bin 0 -> 1561 bytes .../qiskit-visualization-circuit_drawer-1.png | Bin 0 -> 3934 bytes ...visualization-plot_bloch_multivector-1.png | Bin 0 -> 92847 bytes ...visualization-plot_bloch_multivector-2.png | Bin 0 -> 95603 bytes ...skit-visualization-plot_bloch_vector-1.png | Bin 0 -> 73448 bytes ...skit-visualization-plot_bloch_vector-2.png | Bin 0 -> 74554 bytes ...it-visualization-plot_circuit_layout-1.png | Bin 0 -> 8112 bytes ...skit-visualization-plot_coupling_map-1.png | Bin 0 -> 8007 bytes ...t-visualization-plot_distribution-1_00.png | Bin 0 -> 16020 bytes ...t-visualization-plot_distribution-1_01.png | Bin 0 -> 20219 bytes ...t-visualization-plot_distribution-1_02.png | Bin 0 -> 20276 bytes .../qiskit-visualization-plot_error_map-1.png | Bin 0 -> 37014 bytes .../qiskit-visualization-plot_gate_map-1.png | Bin 0 -> 7345 bytes ...skit-visualization-plot_histogram-1_00.png | Bin 0 -> 12434 bytes ...skit-visualization-plot_histogram-1_01.png | Bin 0 -> 16199 bytes ...skit-visualization-plot_histogram-1_02.png | Bin 0 -> 16249 bytes ...qiskit-visualization-plot_state_city-1.png | Bin 0 -> 117324 bytes ...qiskit-visualization-plot_state_city-2.png | Bin 0 -> 159875 bytes ...skit-visualization-plot_state_hinton-1.png | Bin 0 -> 11116 bytes ...it-visualization-plot_state_paulivec-1.png | Bin 0 -> 17337 bytes ...it-visualization-plot_state_paulivec-2.png | Bin 0 -> 18522 bytes ...kit-visualization-plot_state_qsphere-1.png | Bin 0 -> 33861 bytes ...kit-visualization-plot_state_qsphere-2.png | Bin 0 -> 38572 bytes .../qiskit-visualization-pulse_drawer-1.png | Bin 0 -> 63840 bytes .../qiskit-visualization-pulse_drawer-2.png | Bin 0 -> 29394 bytes .../qiskit-visualization-pulse_drawer-3.png | Bin 0 -> 79687 bytes ...qiskit-visualization-timeline_drawer-1.png | Bin 0 -> 29867 bytes ...qiskit-visualization-timeline_drawer-2.png | Bin 0 -> 7453 bytes ...qiskit-visualization-timeline_drawer-3.png | Bin 0 -> 69676 bytes .../images/api/qiskit/0.46/transpiler-10.png | Bin 0 -> 7906 bytes .../images/api/qiskit/0.46/transpiler-11.png | Bin 0 -> 32887 bytes .../images/api/qiskit/0.46/transpiler-12.png | Bin 0 -> 8856 bytes .../images/api/qiskit/0.46/transpiler-13.png | Bin 0 -> 32887 bytes .../images/api/qiskit/0.46/transpiler-14.png | Bin 0 -> 19570 bytes .../images/api/qiskit/0.46/transpiler-15.png | Bin 0 -> 8855 bytes .../images/api/qiskit/0.46/transpiler-16.png | Bin 0 -> 91600 bytes .../images/api/qiskit/0.46/transpiler-17.png | Bin 0 -> 35255 bytes .../images/api/qiskit/0.46/transpiler-4.png | Bin 0 -> 6224 bytes .../images/api/qiskit/0.46/transpiler-5.png | Bin 0 -> 19791 bytes .../images/api/qiskit/0.46/transpiler-6.png | Bin 0 -> 9344 bytes .../images/api/qiskit/0.46/transpiler-7.png | Bin 0 -> 11696 bytes .../images/api/qiskit/0.46/transpiler-8.png | Bin 0 -> 8194 bytes .../images/api/qiskit/0.46/transpiler-9.png | Bin 0 -> 8392 bytes .../qiskit/0.46/transpiling_core_steps.png | Bin 0 -> 246632 bytes .../api/qiskit/0.46/visualization-1.png | Bin 0 -> 10426 bytes .../api/qiskit/0.46/visualization-2.png | Bin 0 -> 17293 bytes .../api/qiskit/0.46/visualization-3.png | Bin 0 -> 10033 bytes .../api/qiskit/0.46/visualization-4.png | Bin 0 -> 108756 bytes .../api/qiskit/0.46/visualization-5.png | Bin 0 -> 113083 bytes .../api/qiskit/0.46/visualization-6.png | Bin 0 -> 113083 bytes 931 files changed, 158491 insertions(+) create mode 100644 docs/api/qiskit/0.46/_package.json create mode 100644 docs/api/qiskit/0.46/_toc.json create mode 100644 docs/api/qiskit/0.46/algorithms.md create mode 100644 docs/api/qiskit/0.46/assembler.md create mode 100644 docs/api/qiskit/0.46/circuit.md create mode 100644 docs/api/qiskit/0.46/circuit_classical.md create mode 100644 docs/api/qiskit/0.46/circuit_library.md create mode 100644 docs/api/qiskit/0.46/circuit_singleton.md create mode 100644 docs/api/qiskit/0.46/classicalfunction.md create mode 100644 docs/api/qiskit/0.46/compiler.md create mode 100644 docs/api/qiskit/0.46/converters.md create mode 100644 docs/api/qiskit/0.46/dagcircuit.md create mode 100644 docs/api/qiskit/0.46/exceptions.md create mode 100644 docs/api/qiskit/0.46/execute.md create mode 100644 docs/api/qiskit/0.46/extensions.md create mode 100644 docs/api/qiskit/0.46/index.md create mode 100644 docs/api/qiskit/0.46/opflow.md create mode 100644 docs/api/qiskit/0.46/passmanager.md create mode 100644 docs/api/qiskit/0.46/primitives.md create mode 100644 docs/api/qiskit/0.46/providers.md create mode 100644 docs/api/qiskit/0.46/providers_basic_provider.md create mode 100644 docs/api/qiskit/0.46/providers_basicaer.md create mode 100644 docs/api/qiskit/0.46/providers_fake_provider.md create mode 100644 docs/api/qiskit/0.46/providers_models.md create mode 100644 docs/api/qiskit/0.46/pulse.md create mode 100644 docs/api/qiskit/0.46/qasm.md create mode 100644 docs/api/qiskit/0.46/qasm2.md create mode 100644 docs/api/qiskit/0.46/qasm3.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.AlgorithmJob.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.AmplificationProblem.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeAmplifier.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimationResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimator.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimatorResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.Eigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.EigensolverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.EstimationProblem.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.EvolutionProblem.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.EvolutionResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimationResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.Grover.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.GroverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimationResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryEvolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryTimeEvolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimationResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.IterativePhaseEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.NumPyEigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.NumPyMinimumEigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.PVQD.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.PVQDResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationScale.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.QAOA.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.RealEvolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.RealTimeEvolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.SciPyImaginaryEvolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.SciPyRealEvolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionProblem.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.TrotterQRTE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.VQD.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.VQDResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.VQE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.VarQITE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.VarQRTE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.Eigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.EigensolverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQD.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQDResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseEstimatorGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseQGT.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseSamplerGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.EstimatorGradientResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffEstimatorGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffSamplerGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombEstimatorGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombQGT.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombSamplerGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftEstimatorGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftSamplerGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFI.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFIResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.QGTResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseEstimatorGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseQGT.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSAEstimatorGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSASamplerGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.SamplerGradientResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.gradients.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.QAOA.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQEResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ADAM.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AQGD.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AskData.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.BOBYQA.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CG.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.COBYLA.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CRS.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L_RAND.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ESCH.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GSLS.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescent.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescentState.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.IMFIL.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ISRES.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.L_BFGS_B.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Minimizer.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NELDER_MEAD.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NFT.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Optimizer.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerState.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerSupportLevel.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.POWELL.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.P_BFGS.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.QNSPSA.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SLSQP.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SNOBFIT.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SPSA.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SciPyOptimizer.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SteppableOptimizer.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TNC.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TellData.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.UMDA.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.LearningRate.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.BaseStateFidelity.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.ComputeUncompute.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.StateFidelityResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.VariationalPrinciple.md create mode 100644 docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.md create mode 100644 docs/api/qiskit/0.46/qiskit.assembler.RunConfig.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.AncillaQubit.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.AncillaRegister.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.AnnotatedOperation.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Bit.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.BreakLoopOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.CircuitInstruction.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ClassicalRegister.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Clbit.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.CommutationChecker.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ContinueLoopOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ControlFlowOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ControlModifier.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ControlledGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Delay.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.EquivalenceLibrary.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ForLoopOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Gate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.IfElseOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Instruction.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.InstructionSet.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.InverseModifier.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Operation.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Parameter.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ParameterExpression.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.ParameterVector.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.PowerModifier.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.QuantumCircuit.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.QuantumRegister.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Qubit.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.Register.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.SwitchCaseOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.WhileLoopOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.BooleanExpression.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunction.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.AND.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.Barrier.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.C3SXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.C3XGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.C4XGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CCXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CCZGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CDKMRippleCarryAdder.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CHGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CPhaseGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CRXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CRYGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CRZGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CSGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CSXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CSdgGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CSwapGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CU1Gate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CU3Gate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CUGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CYGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.CZGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.DCXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.Diagonal.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.DiagonalGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.DraperQFTAdder.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.ECRGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.EfficientSU2.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.EvolvedOperatorAnsatz.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.ExactReciprocal.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.ExcitationPreserving.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.FourierChecking.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.FunctionalPauliRotations.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GMS.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GR.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GRX.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GRY.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GRZ.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GlobalPhaseGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GraphState.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.GroverOperator.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.HGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.HRSCumulativeMultiplier.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.HamiltonianGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.HiddenLinearFunction.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.IGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.IQP.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.Initialize.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.InnerProduct.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.IntegerComparator.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.Isometry.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.LinearAmplitudeFunction.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.LinearFunction.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.LinearPauliRotations.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MCMT.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MCMTVChain.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MCPhaseGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MCXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MCXGrayCode.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MCXRecursive.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MCXVChain.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.MSGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.Measure.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.NLocal.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.OR.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PauliEvolutionGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PauliFeatureMap.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PauliGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PauliTwoDesign.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.Permutation.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PermutationGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PhaseEstimation.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PhaseGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PhaseOracle.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseChebyshev.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseLinearPauliRotations.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PiecewisePolynomialPauliRotations.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.PolynomialPauliRotations.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.QAOAAnsatz.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.QFT.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.QuadraticForm.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.QuantumVolume.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RC3XGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RCCXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RGQFTMultiplier.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RVGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RXXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RYGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RYYGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RZGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RZXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RZZGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.RealAmplitudes.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.Reset.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.SGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.SXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.SXdgGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.SdgGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.StatePreparation.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.SwapGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.TGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.TdgGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.TwoLocal.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.U1Gate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.U2Gate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.U3Gate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UCGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UCPauliRotGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UCRXGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UCRYGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UCRZGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryOverlap.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.VBERippleCarryAdder.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.WeightedAdder.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.XGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.XOR.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.XXMinusYYGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.XXPlusYYGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.YGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.ZFeatureMap.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.ZGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.ZZFeatureMap.md create mode 100644 docs/api/qiskit/0.46/qiskit.circuit.library.iSwapGate.md create mode 100644 docs/api/qiskit/0.46/qiskit.dagcircuit.DAGCircuit.md create mode 100644 docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDepNode.md create mode 100644 docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDependency.md create mode 100644 docs/api/qiskit/0.46/qiskit.dagcircuit.DAGInNode.md create mode 100644 docs/api/qiskit/0.46/qiskit.dagcircuit.DAGNode.md create mode 100644 docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOpNode.md create mode 100644 docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOutNode.md create mode 100644 docs/api/qiskit/0.46/qiskit.extensions.SingleQubitUnitary.md create mode 100644 docs/api/qiskit/0.46/qiskit.extensions.Snapshot.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.OperatorBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.converters.AbelianGrouper.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.converters.CircuitSampler.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.converters.ConverterBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.converters.DictToCircuitSum.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.converters.PauliBasisChange.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.converters.TwoQubitReduction.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.converters.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionFactory.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolvedOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.MatrixEvolution.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.PauliTrotterEvolution.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.QDrift.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.Suzuki.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.Trotter.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationFactory.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.evolutions.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.expectations.AerPauliExpectation.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.expectations.CVaRExpectation.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationFactory.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.expectations.MatrixExpectation.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.expectations.PauliExpectation.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.expectations.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitQFI.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.DerivativeBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.Gradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.GradientBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.Hessian.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.HessianBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.NaturalGradient.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.QFI.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.QFIBase.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.gradients.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.list_ops.ComposedOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.list_ops.ListOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.list_ops.SummedOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.list_ops.TensoredOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.list_ops.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.CircuitOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.MatrixOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliSumOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PrimitiveOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.TaperedPauliSumOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.Z2Symmetries.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.CVaRMeasurement.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.CircuitStateFn.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.DictStateFn.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.OperatorStateFn.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.SparseVectorStateFn.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.StateFn.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.VectorStateFn.md create mode 100644 docs/api/qiskit/0.46/qiskit.opflow.state_fns.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.BaseController.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.BasePassManager.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.ConditionalController.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.DoWhileController.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.FlowController.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.FlowControllerLinear.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.GenericPass.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.PassManagerState.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.PropertySet.md create mode 100644 docs/api/qiskit/0.46/qiskit.passmanager.WorkflowStatus.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.BackendEstimator.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.BackendSampler.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.BaseEstimator.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.BaseSampler.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.Estimator.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.EstimatorResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.Sampler.md create mode 100644 docs/api/qiskit/0.46/qiskit.primitives.SamplerResult.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.Backend.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.BackendV1.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.BackendV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.BackendV2Converter.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.Job.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.JobStatus.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.JobV1.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.Options.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.Provider.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.ProviderV1.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.QubitProperties.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProvider.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderError.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderJob.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicSimulator.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerError.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerJob.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerProvider.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basicaer.QasmSimulatorPy.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basicaer.StatevectorSimulatorPy.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.basicaer.UnitarySimulatorPy.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.convert_to_target.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.ConfigurableFakeBackend.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.Fake1Q.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmaden.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmadenV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonk.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonkV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthens.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthensV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAuckland.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackend5QV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackendV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelem.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelemV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingen.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingenV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogota.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogotaV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklyn.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklynV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlington.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlingtonV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairo.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairoV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridge.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridgeV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablanca.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablancaV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssex.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssexV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGeneva.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupe.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupeV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoi.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoiV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakarta.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakartaV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburg.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburgV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkata.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkataV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagos.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagosV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLima.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLimaV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondon.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondonV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattan.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattanV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManila.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManilaV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourne.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourneV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontreal.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontrealV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbai.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiFractionalCX.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobi.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobiV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse2Q.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse3Q.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOslo.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurense.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurenseV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParis.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParisV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePerth.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsie.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsieV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePrague.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProvider.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProviderForBackendV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQasmSimulator.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuito.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuitoV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochester.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochesterV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRome.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRomeV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRueschlikon.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiago.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiagoV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSherbrooke.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingapore.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingaporeV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydney.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydneyV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTenerife.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTokyo.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeToronto.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTorontoV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValencia.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValenciaV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigo.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigoV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashington.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashingtonV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktown.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktownV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.fake_provider.GenericBackendV2.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.BackendConfiguration.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.BackendProperties.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.BackendStatus.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.Command.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.GateConfig.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.GateProperties.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.JobStatus.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.Nduv.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.PulseBackendConfiguration.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.PulseDefaults.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.QasmBackendConfiguration.md create mode 100644 docs/api/qiskit/0.46/qiskit.providers.models.UchannelLO.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.InstructionScheduleMap.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.Schedule.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.ScheduleBlock.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.channels.AcquireChannel.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.channels.ControlChannel.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.channels.DriveChannel.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.channels.MeasureChannel.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.channels.MemorySlot.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.channels.RegisterSlot.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.channels.SnapshotChannel.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.Acquire.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.Call.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.Delay.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.Play.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.Reference.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.RelativeBarrier.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.SetFrequency.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.SetPhase.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftFrequency.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftPhase.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.Snapshot.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.instructions.TimeBlockade.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Constant_class.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Cos_class.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Drag_class.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.GaussianDeriv.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquare.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquareDrag.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Gaussian_class.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.ParametricPulse.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Sawtooth_class.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.SechDeriv.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Sech_fun.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Sin_class.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Square_fun.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.SymbolicPulse.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Triangle_class.rst.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.Waveform.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.library.gaussian_square_echo.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignEquispaced.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignFunc.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignLeft.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignRight.md create mode 100644 docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignSequential.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.GateCalibration.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.PulseLibraryItem.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.PulseQobj.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.PulseQobjConfig.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperiment.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperimentConfig.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.PulseQobjInstruction.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QasmExperimentCalibrations.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QasmQobj.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QasmQobjConfig.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperiment.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperimentConfig.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QasmQobjInstruction.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QobjExperimentHeader.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QobjHeader.md create mode 100644 docs/api/qiskit/0.46/qiskit.qobj.QobjMeasurementOption.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.CNOTDihedral.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Chi.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Choi.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Clifford.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.DensityMatrix.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Kraus.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Operator.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.PTM.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Pauli.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.PauliList.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Quaternion.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.ScalarOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.SparsePauliOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.StabilizerState.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Statevector.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Stinespring.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.SuperOp.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.Z2Symmetries.md create mode 100644 docs/api/qiskit/0.46/qiskit.quantum_info.pauli_basis.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.BaseReadoutMitigator.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.CorrelatedReadoutMitigator.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.Counts.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.LocalReadoutMitigator.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.ProbDistribution.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.QuasiDistribution.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.Result.md create mode 100644 docs/api/qiskit/0.46/qiskit.result.ResultError.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.EvolutionSynthesis.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.LieTrotter.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.MatrixExponential.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.OneQubitEulerDecomposer.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.ProductFormula.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.QDrift.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.SolovayKitaevDecomposition.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.SuzukiTrotter.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.TwoQubitBasisDecomposer.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.XXDecomposer.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.AQC.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximateCircuit.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximatingObjective.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.md create mode 100644 docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.AnalysisPass.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.CouplingMap.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.FencedDAGCircuit.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.FencedPropertySet.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.InstructionDurations.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.InstructionProperties.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.Layout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.PassManager.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.PassManagerConfig.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.StagedPassManager.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.Target.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.TransformationPass.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.TranspileLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPSchedule.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPScheduleAnalysis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.AQCSynthesisPlugin.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPSchedule.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPScheduleAnalysis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.AlignMeasures.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ApplyLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.BasicSwap.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.BasisTranslator.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CSPLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CXCancellation.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckGateDirection.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckMap.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect1qRuns.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect2qBlocks.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectCliffords.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectLinearFunctions.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectMultiQBlocks.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutationAnalysis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeCancellation.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeInverseCancellation.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Commuting2qGateRouter.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ConsolidateBlocks.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ConstrainedReschedule.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ContainsInstruction.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ConvertConditionsToIfOps.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOps.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOpsLongestPath.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.CrosstalkAdaptiveSchedule.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGFixedPoint.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGLongestPath.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Decompose.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.DenseLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Depth.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.DynamicalDecoupling.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.EchoRZXWeylDecomposition.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.EnlargeWithAncilla.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.FixedPoint.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.FullAncillaAllocation.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.GateDirection.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.GatesInBasis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.HighLevelSynthesis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.HoareOptimizer.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.InstructionDurationCheck.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.InverseCancellation.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Layout2qDistance.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsSynthesis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsToPermutations.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.LookaheadSwap.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.MergeAdjacentBarriers.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.MinimumPoint.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.NoiseAdaptiveLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.NormalizeRXAngle.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.NumTensorFactors.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGates.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesDecomposition.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.OptimizeCliffords.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDelay.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDynamicalDecoupling.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.PulseGates.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.RXCalibrationBuilder.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilder.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveBarriers.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveFinalMeasurements.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveResetInZeroState.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ResetAfterMeasureSimplification.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.SabrePreLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreSwap.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.SetIOLatency.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.SetLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Size.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaev.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaevSynthesis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.StochasticSwap.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.TemplateOptimization.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.TimeUnitConversion.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.TranslateParameterizedGates.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.TrivialLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.UnitarySynthesis.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroll3qOrMore.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollCustomDefinitions.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollForLoops.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroller.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2Layout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2PostLayout.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.ValidatePulseGates.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.Width.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.md create mode 100644 docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.md create mode 100644 docs/api/qiskit/0.46/qiskit.utils.QuantumInstance.md create mode 100644 docs/api/qiskit/0.46/qiskit.utils.mitigation.CompleteMeasFitter.md create mode 100644 docs/api/qiskit/0.46/qiskit.utils.mitigation.TensoredMeasFitter.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.array_to_latex.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.circuit.qcstyle.DefaultStyle.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.circuit_drawer.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.dag_drawer.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.pass_manager_drawer.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_multivector.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_vector.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_circuit_layout.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_coupling_map.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_distribution.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_error_map.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_gate_map.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_histogram.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_state_city.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_state_hinton.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_state_paulivec.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.plot_state_qsphere.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXDebugging.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXSimple.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXStandard.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.pulse_drawer.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.timeline_drawer.md create mode 100644 docs/api/qiskit/0.46/qiskit.visualization.visualize_transition.md create mode 100644 docs/api/qiskit/0.46/qobj.md create mode 100644 docs/api/qiskit/0.46/qpy.md create mode 100644 docs/api/qiskit/0.46/quantum_info.md create mode 100644 docs/api/qiskit/0.46/result.md create mode 100644 docs/api/qiskit/0.46/scheduler.md create mode 100644 docs/api/qiskit/0.46/synthesis.md create mode 100644 docs/api/qiskit/0.46/synthesis_aqc.md create mode 100644 docs/api/qiskit/0.46/tools.md create mode 100644 docs/api/qiskit/0.46/tools_jupyter.md create mode 100644 docs/api/qiskit/0.46/transpiler.md create mode 100644 docs/api/qiskit/0.46/transpiler_builtin_plugins.md create mode 100644 docs/api/qiskit/0.46/transpiler_passes.md create mode 100644 docs/api/qiskit/0.46/transpiler_plugins.md create mode 100644 docs/api/qiskit/0.46/transpiler_preset.md create mode 100644 docs/api/qiskit/0.46/transpiler_synthesis_plugins.md create mode 100644 docs/api/qiskit/0.46/utils.md create mode 100644 docs/api/qiskit/0.46/utils_mitigation.md create mode 100644 docs/api/qiskit/0.46/visualization.md create mode 100644 public/images/api/qiskit/0.46/circuit-1.png create mode 100644 public/images/api/qiskit/0.46/circuit-2.png create mode 100644 public/images/api/qiskit/0.46/circuit-3.png create mode 100644 public/images/api/qiskit/0.46/circuit-4.png create mode 100644 public/images/api/qiskit/0.46/circuit-5.png create mode 100644 public/images/api/qiskit/0.46/circuit_library-1.png create mode 100644 public/images/api/qiskit/0.46/converters-1.png create mode 100644 public/images/api/qiskit/0.46/depth.gif create mode 100644 public/images/api/qiskit/0.46/mapping.png create mode 100644 public/images/api/qiskit/0.46/providers_fake_provider-1_00.png create mode 100644 public/images/api/qiskit/0.46/providers_fake_provider-1_01.png create mode 100644 public/images/api/qiskit/0.46/providers_fake_provider-1_02.png create mode 100644 public/images/api/qiskit/0.46/pulse-1.png create mode 100644 public/images/api/qiskit/0.46/pulse-2.png create mode 100644 public/images/api/qiskit/0.46/pulse-3.png create mode 100644 public/images/api/qiskit/0.46/pulse-4.png create mode 100644 public/images/api/qiskit/0.46/pulse-5.png create mode 100644 public/images/api/qiskit/0.46/pulse-6.png create mode 100644 public/images/api/qiskit/0.46/pulse-7.png create mode 100644 public/images/api/qiskit/0.46/pulse-8.png create mode 100644 public/images/api/qiskit/0.46/pulse-9.png create mode 100644 public/images/api/qiskit/0.46/qasm3-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-ControlledGate-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-ControlledGate-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-InstructionSet-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-Operation-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-Parameter-1_00.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-Parameter-1_01.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-3_00.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-3_01.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-4_00.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-4_01.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-5.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-6.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-AND-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-AND-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-FourierChecking-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-GMS-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-GR-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-GRX-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-GRY-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-GRZ-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-GraphState-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-HiddenLinearFunction-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-IQP-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-IQP-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-InnerProduct-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-MCMTVChain-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-OR-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-OR-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-PauliTwoDesign-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-Permutation-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-Permutation-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-PermutationGate-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-PermutationGate-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-PhaseEstimation-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-PiecewiseChebyshev-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-QFT-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-QFT-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-QFT-3.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-QuantumVolume-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-QuantumVolume-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-circuit-library-XOR-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-pulse-library-SymbolicPulse-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-quantum_info-Statevector-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-transpiler-passes-DynamicalDecoupling-1_00.png create mode 100644 public/images/api/qiskit/0.46/qiskit-transpiler-passes-DynamicalDecoupling-1_01.png create mode 100644 public/images/api/qiskit/0.46/qiskit-transpiler-passes-PadDynamicalDecoupling-1_00.png create mode 100644 public/images/api/qiskit/0.46/qiskit-transpiler-passes-PadDynamicalDecoupling-1_01.png create mode 100644 public/images/api/qiskit/0.46/qiskit-transpiler-passes-RemoveBarriers-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-circuit_drawer-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_multivector-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_multivector-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_vector-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_vector-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_circuit_layout-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_coupling_map-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_distribution-1_00.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_distribution-1_01.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_distribution-1_02.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_error_map-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_gate_map-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_histogram-1_00.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_histogram-1_01.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_histogram-1_02.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_state_city-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_state_city-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_state_hinton-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_state_paulivec-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_state_paulivec-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_state_qsphere-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-plot_state_qsphere-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-pulse_drawer-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-pulse_drawer-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-pulse_drawer-3.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-timeline_drawer-1.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-timeline_drawer-2.png create mode 100644 public/images/api/qiskit/0.46/qiskit-visualization-timeline_drawer-3.png create mode 100644 public/images/api/qiskit/0.46/transpiler-10.png create mode 100644 public/images/api/qiskit/0.46/transpiler-11.png create mode 100644 public/images/api/qiskit/0.46/transpiler-12.png create mode 100644 public/images/api/qiskit/0.46/transpiler-13.png create mode 100644 public/images/api/qiskit/0.46/transpiler-14.png create mode 100644 public/images/api/qiskit/0.46/transpiler-15.png create mode 100644 public/images/api/qiskit/0.46/transpiler-16.png create mode 100644 public/images/api/qiskit/0.46/transpiler-17.png create mode 100644 public/images/api/qiskit/0.46/transpiler-4.png create mode 100644 public/images/api/qiskit/0.46/transpiler-5.png create mode 100644 public/images/api/qiskit/0.46/transpiler-6.png create mode 100644 public/images/api/qiskit/0.46/transpiler-7.png create mode 100644 public/images/api/qiskit/0.46/transpiler-8.png create mode 100644 public/images/api/qiskit/0.46/transpiler-9.png create mode 100644 public/images/api/qiskit/0.46/transpiling_core_steps.png create mode 100644 public/images/api/qiskit/0.46/visualization-1.png create mode 100644 public/images/api/qiskit/0.46/visualization-2.png create mode 100644 public/images/api/qiskit/0.46/visualization-3.png create mode 100644 public/images/api/qiskit/0.46/visualization-4.png create mode 100644 public/images/api/qiskit/0.46/visualization-5.png create mode 100644 public/images/api/qiskit/0.46/visualization-6.png diff --git a/docs/api/qiskit/0.46/_package.json b/docs/api/qiskit/0.46/_package.json new file mode 100644 index 00000000000..cfb4023267e --- /dev/null +++ b/docs/api/qiskit/0.46/_package.json @@ -0,0 +1,4 @@ +{ + "name": "qiskit", + "version": "0.46.0" +} diff --git a/docs/api/qiskit/0.46/_toc.json b/docs/api/qiskit/0.46/_toc.json new file mode 100644 index 00000000000..3bfafd17182 --- /dev/null +++ b/docs/api/qiskit/0.46/_toc.json @@ -0,0 +1,3633 @@ +{ + "title": "Qiskit", + "children": [ + { + "title": "qiskit", + "url": "/api/qiskit/0.46" + }, + { + "title": "qiskit.algorithms", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/algorithms" + }, + { + "title": "AlgorithmJob", + "url": "/api/qiskit/0.46/qiskit.algorithms.AlgorithmJob" + }, + { + "title": "AmplificationProblem", + "url": "/api/qiskit/0.46/qiskit.algorithms.AmplificationProblem" + }, + { + "title": "AmplitudeAmplifier", + "url": "/api/qiskit/0.46/qiskit.algorithms.AmplitudeAmplifier" + }, + { + "title": "AmplitudeEstimation", + "url": "/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimation" + }, + { + "title": "AmplitudeEstimationResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimationResult" + }, + { + "title": "AmplitudeEstimator", + "url": "/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimator" + }, + { + "title": "AmplitudeEstimatorResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimatorResult" + }, + { + "title": "Eigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.Eigensolver" + }, + { + "title": "EigensolverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.EigensolverResult" + }, + { + "title": "EstimationProblem", + "url": "/api/qiskit/0.46/qiskit.algorithms.EstimationProblem" + }, + { + "title": "EvolutionProblem", + "url": "/api/qiskit/0.46/qiskit.algorithms.EvolutionProblem" + }, + { + "title": "EvolutionResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.EvolutionResult" + }, + { + "title": "FasterAmplitudeEstimation", + "url": "/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimation" + }, + { + "title": "FasterAmplitudeEstimationResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimationResult" + }, + { + "title": "Grover", + "url": "/api/qiskit/0.46/qiskit.algorithms.Grover" + }, + { + "title": "GroverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.GroverResult" + }, + { + "title": "HamiltonianPhaseEstimation", + "url": "/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimation" + }, + { + "title": "HamiltonianPhaseEstimationResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimationResult" + }, + { + "title": "ImaginaryEvolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.ImaginaryEvolver" + }, + { + "title": "ImaginaryTimeEvolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.ImaginaryTimeEvolver" + }, + { + "title": "IterativeAmplitudeEstimation", + "url": "/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimation" + }, + { + "title": "IterativeAmplitudeEstimationResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimationResult" + }, + { + "title": "IterativePhaseEstimation", + "url": "/api/qiskit/0.46/qiskit.algorithms.IterativePhaseEstimation" + }, + { + "title": "MaximumLikelihoodAmplitudeEstimation", + "url": "/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation" + }, + { + "title": "MaximumLikelihoodAmplitudeEstimationResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult" + }, + { + "title": "MinimumEigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolver" + }, + { + "title": "MinimumEigensolverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolverResult" + }, + { + "title": "NumPyEigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.NumPyEigensolver" + }, + { + "title": "NumPyMinimumEigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.NumPyMinimumEigensolver" + }, + { + "title": "PhaseEstimation", + "url": "/api/qiskit/0.46/qiskit.algorithms.PhaseEstimation" + }, + { + "title": "PhaseEstimationResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationResult" + }, + { + "title": "PhaseEstimationScale", + "url": "/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationScale" + }, + { + "title": "PVQD", + "url": "/api/qiskit/0.46/qiskit.algorithms.PVQD" + }, + { + "title": "PVQDResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.PVQDResult" + }, + { + "title": "QAOA", + "url": "/api/qiskit/0.46/qiskit.algorithms.QAOA" + }, + { + "title": "RealEvolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.RealEvolver" + }, + { + "title": "RealTimeEvolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.RealTimeEvolver" + }, + { + "title": "SciPyImaginaryEvolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.SciPyImaginaryEvolver" + }, + { + "title": "SciPyRealEvolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.SciPyRealEvolver" + }, + { + "title": "TimeEvolutionProblem", + "url": "/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionProblem" + }, + { + "title": "TimeEvolutionResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionResult" + }, + { + "title": "TrotterQRTE", + "url": "/api/qiskit/0.46/qiskit.algorithms.TrotterQRTE" + }, + { + "title": "VarQITE", + "url": "/api/qiskit/0.46/qiskit.algorithms.VarQITE" + }, + { + "title": "VarQRTE", + "url": "/api/qiskit/0.46/qiskit.algorithms.VarQRTE" + }, + { + "title": "VQD", + "url": "/api/qiskit/0.46/qiskit.algorithms.VQD" + }, + { + "title": "VQDResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.VQDResult" + }, + { + "title": "VQE", + "url": "/api/qiskit/0.46/qiskit.algorithms.VQE" + }, + { + "title": "qiskit.algorithms.eigensolvers", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.eigensolvers" + }, + { + "title": "Eigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.eigensolvers.Eigensolver" + }, + { + "title": "EigensolverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.eigensolvers.EigensolverResult" + }, + { + "title": "NumPyEigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolver" + }, + { + "title": "NumPyEigensolverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolverResult" + }, + { + "title": "VQD", + "url": "/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQD" + }, + { + "title": "VQDResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQDResult" + } + ] + }, + { + "title": "qiskit.algorithms.gradients", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients" + }, + { + "title": "BaseEstimatorGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.BaseEstimatorGradient" + }, + { + "title": "BaseQGT", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.BaseQGT" + }, + { + "title": "BaseSamplerGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.BaseSamplerGradient" + }, + { + "title": "EstimatorGradientResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.EstimatorGradientResult" + }, + { + "title": "FiniteDiffEstimatorGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffEstimatorGradient" + }, + { + "title": "FiniteDiffSamplerGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffSamplerGradient" + }, + { + "title": "LinCombEstimatorGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombEstimatorGradient" + }, + { + "title": "LinCombQGT", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombQGT" + }, + { + "title": "LinCombSamplerGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombSamplerGradient" + }, + { + "title": "ParamShiftEstimatorGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftEstimatorGradient" + }, + { + "title": "ParamShiftSamplerGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftSamplerGradient" + }, + { + "title": "QFI", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.QFI" + }, + { + "title": "QFIResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.QFIResult" + }, + { + "title": "QGTResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.QGTResult" + }, + { + "title": "ReverseEstimatorGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseEstimatorGradient" + }, + { + "title": "ReverseQGT", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseQGT" + }, + { + "title": "SamplerGradientResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.SamplerGradientResult" + }, + { + "title": "SPSAEstimatorGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.SPSAEstimatorGradient" + }, + { + "title": "SPSASamplerGradient", + "url": "/api/qiskit/0.46/qiskit.algorithms.gradients.SPSASamplerGradient" + } + ] + }, + { + "title": "qiskit.algorithms.minimum_eigensolvers", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers" + }, + { + "title": "AdaptVQE", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQE" + }, + { + "title": "AdaptVQEResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult" + }, + { + "title": "MinimumEigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver" + }, + { + "title": "MinimumEigensolverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult" + }, + { + "title": "NumPyMinimumEigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver" + }, + { + "title": "NumPyMinimumEigensolverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult" + }, + { + "title": "QAOA", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.QAOA" + }, + { + "title": "SamplingMinimumEigensolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver" + }, + { + "title": "SamplingMinimumEigensolverResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult" + }, + { + "title": "SamplingVQE", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQE" + }, + { + "title": "SamplingVQEResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult" + }, + { + "title": "VQE", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQE" + }, + { + "title": "VQEResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQEResult" + } + ] + }, + { + "title": "qiskit.algorithms.optimizers", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers" + }, + { + "title": "ADAM", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.ADAM" + }, + { + "title": "AQGD", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.AQGD" + }, + { + "title": "AskData", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.AskData" + }, + { + "title": "BOBYQA", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.BOBYQA" + }, + { + "title": "CG", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.CG" + }, + { + "title": "COBYLA", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.COBYLA" + }, + { + "title": "CRS", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.CRS" + }, + { + "title": "DIRECT_L", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L" + }, + { + "title": "DIRECT_L_RAND", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L_RAND" + }, + { + "title": "ESCH", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.ESCH" + }, + { + "title": "GradientDescent", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescent" + }, + { + "title": "GradientDescentState", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescentState" + }, + { + "title": "GSLS", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.GSLS" + }, + { + "title": "IMFIL", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.IMFIL" + }, + { + "title": "ISRES", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.ISRES" + }, + { + "title": "L_BFGS_B", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.L_BFGS_B" + }, + { + "title": "Minimizer", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.Minimizer" + }, + { + "title": "NELDER_MEAD", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.NELDER_MEAD" + }, + { + "title": "NFT", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.NFT" + }, + { + "title": "Optimizer", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.Optimizer" + }, + { + "title": "OptimizerResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerResult" + }, + { + "title": "OptimizerState", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerState" + }, + { + "title": "OptimizerSupportLevel", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerSupportLevel" + }, + { + "title": "P_BFGS", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.P_BFGS" + }, + { + "title": "POWELL", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.POWELL" + }, + { + "title": "QNSPSA", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.QNSPSA" + }, + { + "title": "SciPyOptimizer", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.SciPyOptimizer" + }, + { + "title": "SLSQP", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.SLSQP" + }, + { + "title": "SNOBFIT", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.SNOBFIT" + }, + { + "title": "SPSA", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.SPSA" + }, + { + "title": "SteppableOptimizer", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.SteppableOptimizer" + }, + { + "title": "TellData", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.TellData" + }, + { + "title": "TNC", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.TNC" + }, + { + "title": "UMDA", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.UMDA" + }, + { + "title": "qiskit.algorithms.optimizers.optimizer_utils", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils" + }, + { + "title": "LearningRate", + "url": "/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.LearningRate" + } + ] + } + ] + }, + { + "title": "qiskit.algorithms.state_fidelities", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.state_fidelities" + }, + { + "title": "BaseStateFidelity", + "url": "/api/qiskit/0.46/qiskit.algorithms.state_fidelities.BaseStateFidelity" + }, + { + "title": "ComputeUncompute", + "url": "/api/qiskit/0.46/qiskit.algorithms.state_fidelities.ComputeUncompute" + }, + { + "title": "StateFidelityResult", + "url": "/api/qiskit/0.46/qiskit.algorithms.state_fidelities.StateFidelityResult" + } + ] + }, + { + "title": "qiskit.algorithms.time_evolvers.trotterization", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization" + }, + { + "title": "TrotterQRTE", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE" + } + ] + }, + { + "title": "qiskit.algorithms.time_evolvers.variational", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational" + }, + { + "title": "ForwardEulerSolver", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver" + }, + { + "title": "ImaginaryMcLachlanPrinciple", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple" + }, + { + "title": "ImaginaryVariationalPrinciple", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple" + }, + { + "title": "RealMcLachlanPrinciple", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple" + }, + { + "title": "RealVariationalPrinciple", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple" + }, + { + "title": "VariationalPrinciple", + "url": "/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.VariationalPrinciple" + } + ] + } + ] + }, + { + "title": "qiskit.assembler", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/assembler" + }, + { + "title": "RunConfig", + "url": "/api/qiskit/0.46/qiskit.assembler.RunConfig" + } + ] + }, + { + "title": "qiskit.circuit", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/circuit" + }, + { + "title": "AncillaQubit", + "url": "/api/qiskit/0.46/qiskit.circuit.AncillaQubit" + }, + { + "title": "AncillaRegister", + "url": "/api/qiskit/0.46/qiskit.circuit.AncillaRegister" + }, + { + "title": "AnnotatedOperation", + "url": "/api/qiskit/0.46/qiskit.circuit.AnnotatedOperation" + }, + { + "title": "Bit", + "url": "/api/qiskit/0.46/qiskit.circuit.Bit" + }, + { + "title": "BreakLoopOp", + "url": "/api/qiskit/0.46/qiskit.circuit.BreakLoopOp" + }, + { + "title": "CircuitInstruction", + "url": "/api/qiskit/0.46/qiskit.circuit.CircuitInstruction" + }, + { + "title": "ClassicalRegister", + "url": "/api/qiskit/0.46/qiskit.circuit.ClassicalRegister" + }, + { + "title": "Clbit", + "url": "/api/qiskit/0.46/qiskit.circuit.Clbit" + }, + { + "title": "CommutationChecker", + "url": "/api/qiskit/0.46/qiskit.circuit.CommutationChecker" + }, + { + "title": "ContinueLoopOp", + "url": "/api/qiskit/0.46/qiskit.circuit.ContinueLoopOp" + }, + { + "title": "ControlFlowOp", + "url": "/api/qiskit/0.46/qiskit.circuit.ControlFlowOp" + }, + { + "title": "ControlledGate", + "url": "/api/qiskit/0.46/qiskit.circuit.ControlledGate" + }, + { + "title": "ControlModifier", + "url": "/api/qiskit/0.46/qiskit.circuit.ControlModifier" + }, + { + "title": "Delay", + "url": "/api/qiskit/0.46/qiskit.circuit.Delay" + }, + { + "title": "EquivalenceLibrary", + "url": "/api/qiskit/0.46/qiskit.circuit.EquivalenceLibrary" + }, + { + "title": "ForLoopOp", + "url": "/api/qiskit/0.46/qiskit.circuit.ForLoopOp" + }, + { + "title": "Gate", + "url": "/api/qiskit/0.46/qiskit.circuit.Gate" + }, + { + "title": "IfElseOp", + "url": "/api/qiskit/0.46/qiskit.circuit.IfElseOp" + }, + { + "title": "Instruction", + "url": "/api/qiskit/0.46/qiskit.circuit.Instruction" + }, + { + "title": "InstructionSet", + "url": "/api/qiskit/0.46/qiskit.circuit.InstructionSet" + }, + { + "title": "InverseModifier", + "url": "/api/qiskit/0.46/qiskit.circuit.InverseModifier" + }, + { + "title": "Operation", + "url": "/api/qiskit/0.46/qiskit.circuit.Operation" + }, + { + "title": "Parameter", + "url": "/api/qiskit/0.46/qiskit.circuit.Parameter" + }, + { + "title": "ParameterExpression", + "url": "/api/qiskit/0.46/qiskit.circuit.ParameterExpression" + }, + { + "title": "ParameterVector", + "url": "/api/qiskit/0.46/qiskit.circuit.ParameterVector" + }, + { + "title": "PowerModifier", + "url": "/api/qiskit/0.46/qiskit.circuit.PowerModifier" + }, + { + "title": "qiskit.circuit.classical", + "url": "/api/qiskit/0.46/circuit_classical" + }, + { + "title": "qiskit.circuit.singleton", + "url": "/api/qiskit/0.46/circuit_singleton" + }, + { + "title": "QuantumCircuit", + "url": "/api/qiskit/0.46/qiskit.circuit.QuantumCircuit" + }, + { + "title": "QuantumRegister", + "url": "/api/qiskit/0.46/qiskit.circuit.QuantumRegister" + }, + { + "title": "Qubit", + "url": "/api/qiskit/0.46/qiskit.circuit.Qubit" + }, + { + "title": "Register", + "url": "/api/qiskit/0.46/qiskit.circuit.Register" + }, + { + "title": "SwitchCaseOp", + "url": "/api/qiskit/0.46/qiskit.circuit.SwitchCaseOp" + }, + { + "title": "WhileLoopOp", + "url": "/api/qiskit/0.46/qiskit.circuit.WhileLoopOp" + }, + { + "title": "qiskit.circuit.classicalfunction", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/classicalfunction" + }, + { + "title": "BooleanExpression", + "url": "/api/qiskit/0.46/qiskit.circuit.classicalfunction.BooleanExpression" + }, + { + "title": "ClassicalFunction", + "url": "/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunction" + }, + { + "title": "ClassicalFunctionCompilerTypeError", + "url": "/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError" + }, + { + "title": "ClassicalFunctionParseError", + "url": "/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionParseError" + } + ] + }, + { + "title": "qiskit.circuit.library", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/circuit_library" + }, + { + "title": "AND", + "url": "/api/qiskit/0.46/qiskit.circuit.library.AND" + }, + { + "title": "Barrier", + "url": "/api/qiskit/0.46/qiskit.circuit.library.Barrier" + }, + { + "title": "C3SXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.C3SXGate" + }, + { + "title": "C3XGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.C3XGate" + }, + { + "title": "C4XGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.C4XGate" + }, + { + "title": "CCXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CCXGate" + }, + { + "title": "CCZGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CCZGate" + }, + { + "title": "CDKMRippleCarryAdder", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CDKMRippleCarryAdder" + }, + { + "title": "CHGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CHGate" + }, + { + "title": "CPhaseGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CPhaseGate" + }, + { + "title": "CRXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CRXGate" + }, + { + "title": "CRYGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CRYGate" + }, + { + "title": "CRZGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CRZGate" + }, + { + "title": "CSdgGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CSdgGate" + }, + { + "title": "CSGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CSGate" + }, + { + "title": "CSwapGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CSwapGate" + }, + { + "title": "CSXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CSXGate" + }, + { + "title": "CU1Gate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CU1Gate" + }, + { + "title": "CU3Gate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CU3Gate" + }, + { + "title": "CUGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CUGate" + }, + { + "title": "CXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CXGate" + }, + { + "title": "CYGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CYGate" + }, + { + "title": "CZGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.CZGate" + }, + { + "title": "DCXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.DCXGate" + }, + { + "title": "Diagonal", + "url": "/api/qiskit/0.46/qiskit.circuit.library.Diagonal" + }, + { + "title": "DiagonalGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.DiagonalGate" + }, + { + "title": "DraperQFTAdder", + "url": "/api/qiskit/0.46/qiskit.circuit.library.DraperQFTAdder" + }, + { + "title": "ECRGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.ECRGate" + }, + { + "title": "EfficientSU2", + "url": "/api/qiskit/0.46/qiskit.circuit.library.EfficientSU2" + }, + { + "title": "EvolvedOperatorAnsatz", + "url": "/api/qiskit/0.46/qiskit.circuit.library.EvolvedOperatorAnsatz" + }, + { + "title": "ExactReciprocal", + "url": "/api/qiskit/0.46/qiskit.circuit.library.ExactReciprocal" + }, + { + "title": "ExcitationPreserving", + "url": "/api/qiskit/0.46/qiskit.circuit.library.ExcitationPreserving" + }, + { + "title": "FourierChecking", + "url": "/api/qiskit/0.46/qiskit.circuit.library.FourierChecking" + }, + { + "title": "FunctionalPauliRotations", + "url": "/api/qiskit/0.46/qiskit.circuit.library.FunctionalPauliRotations" + }, + { + "title": "GlobalPhaseGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GlobalPhaseGate" + }, + { + "title": "GMS", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GMS" + }, + { + "title": "GR", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GR" + }, + { + "title": "GraphState", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GraphState" + }, + { + "title": "GroverOperator", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GroverOperator" + }, + { + "title": "GRX", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GRX" + }, + { + "title": "GRY", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GRY" + }, + { + "title": "GRZ", + "url": "/api/qiskit/0.46/qiskit.circuit.library.GRZ" + }, + { + "title": "HamiltonianGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.HamiltonianGate" + }, + { + "title": "HGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.HGate" + }, + { + "title": "HiddenLinearFunction", + "url": "/api/qiskit/0.46/qiskit.circuit.library.HiddenLinearFunction" + }, + { + "title": "HRSCumulativeMultiplier", + "url": "/api/qiskit/0.46/qiskit.circuit.library.HRSCumulativeMultiplier" + }, + { + "title": "IGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.IGate" + }, + { + "title": "Initialize", + "url": "/api/qiskit/0.46/qiskit.circuit.library.Initialize" + }, + { + "title": "InnerProduct", + "url": "/api/qiskit/0.46/qiskit.circuit.library.InnerProduct" + }, + { + "title": "IntegerComparator", + "url": "/api/qiskit/0.46/qiskit.circuit.library.IntegerComparator" + }, + { + "title": "IQP", + "url": "/api/qiskit/0.46/qiskit.circuit.library.IQP" + }, + { + "title": "Isometry", + "url": "/api/qiskit/0.46/qiskit.circuit.library.Isometry" + }, + { + "title": "iSwapGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.iSwapGate" + }, + { + "title": "LinearAmplitudeFunction", + "url": "/api/qiskit/0.46/qiskit.circuit.library.LinearAmplitudeFunction" + }, + { + "title": "LinearFunction", + "url": "/api/qiskit/0.46/qiskit.circuit.library.LinearFunction" + }, + { + "title": "LinearPauliRotations", + "url": "/api/qiskit/0.46/qiskit.circuit.library.LinearPauliRotations" + }, + { + "title": "MCMT", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MCMT" + }, + { + "title": "MCMTVChain", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MCMTVChain" + }, + { + "title": "MCPhaseGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MCPhaseGate" + }, + { + "title": "MCXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MCXGate" + }, + { + "title": "MCXGrayCode", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MCXGrayCode" + }, + { + "title": "MCXRecursive", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MCXRecursive" + }, + { + "title": "MCXVChain", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MCXVChain" + }, + { + "title": "Measure", + "url": "/api/qiskit/0.46/qiskit.circuit.library.Measure" + }, + { + "title": "MSGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.MSGate" + }, + { + "title": "NLocal", + "url": "/api/qiskit/0.46/qiskit.circuit.library.NLocal" + }, + { + "title": "OR", + "url": "/api/qiskit/0.46/qiskit.circuit.library.OR" + }, + { + "title": "PauliEvolutionGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PauliEvolutionGate" + }, + { + "title": "PauliFeatureMap", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PauliFeatureMap" + }, + { + "title": "PauliGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PauliGate" + }, + { + "title": "PauliTwoDesign", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PauliTwoDesign" + }, + { + "title": "Permutation", + "url": "/api/qiskit/0.46/qiskit.circuit.library.Permutation" + }, + { + "title": "PermutationGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PermutationGate" + }, + { + "title": "PhaseEstimation", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PhaseEstimation" + }, + { + "title": "PhaseGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PhaseGate" + }, + { + "title": "PhaseOracle", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PhaseOracle" + }, + { + "title": "PiecewiseChebyshev", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PiecewiseChebyshev" + }, + { + "title": "PiecewiseLinearPauliRotations", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PiecewiseLinearPauliRotations" + }, + { + "title": "PiecewisePolynomialPauliRotations", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PiecewisePolynomialPauliRotations" + }, + { + "title": "PolynomialPauliRotations", + "url": "/api/qiskit/0.46/qiskit.circuit.library.PolynomialPauliRotations" + }, + { + "title": "QAOAAnsatz", + "url": "/api/qiskit/0.46/qiskit.circuit.library.QAOAAnsatz" + }, + { + "title": "QFT", + "url": "/api/qiskit/0.46/qiskit.circuit.library.QFT" + }, + { + "title": "QuadraticForm", + "url": "/api/qiskit/0.46/qiskit.circuit.library.QuadraticForm" + }, + { + "title": "QuantumVolume", + "url": "/api/qiskit/0.46/qiskit.circuit.library.QuantumVolume" + }, + { + "title": "RC3XGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RC3XGate" + }, + { + "title": "RCCXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RCCXGate" + }, + { + "title": "RealAmplitudes", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RealAmplitudes" + }, + { + "title": "Reset", + "url": "/api/qiskit/0.46/qiskit.circuit.library.Reset" + }, + { + "title": "RGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RGate" + }, + { + "title": "RGQFTMultiplier", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RGQFTMultiplier" + }, + { + "title": "RVGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RVGate" + }, + { + "title": "RXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RXGate" + }, + { + "title": "RXXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RXXGate" + }, + { + "title": "RYGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RYGate" + }, + { + "title": "RYYGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RYYGate" + }, + { + "title": "RZGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RZGate" + }, + { + "title": "RZXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RZXGate" + }, + { + "title": "RZZGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.RZZGate" + }, + { + "title": "SdgGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.SdgGate" + }, + { + "title": "SGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.SGate" + }, + { + "title": "StatePreparation", + "url": "/api/qiskit/0.46/qiskit.circuit.library.StatePreparation" + }, + { + "title": "SwapGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.SwapGate" + }, + { + "title": "SXdgGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.SXdgGate" + }, + { + "title": "SXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.SXGate" + }, + { + "title": "TdgGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.TdgGate" + }, + { + "title": "TGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.TGate" + }, + { + "title": "TwoLocal", + "url": "/api/qiskit/0.46/qiskit.circuit.library.TwoLocal" + }, + { + "title": "U1Gate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.U1Gate" + }, + { + "title": "U2Gate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.U2Gate" + }, + { + "title": "U3Gate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.U3Gate" + }, + { + "title": "UCGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UCGate" + }, + { + "title": "UCPauliRotGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UCPauliRotGate" + }, + { + "title": "UCRXGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UCRXGate" + }, + { + "title": "UCRYGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UCRYGate" + }, + { + "title": "UCRZGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UCRZGate" + }, + { + "title": "UGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UGate" + }, + { + "title": "UnitaryGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UnitaryGate" + }, + { + "title": "UnitaryOverlap", + "url": "/api/qiskit/0.46/qiskit.circuit.library.UnitaryOverlap" + }, + { + "title": "VBERippleCarryAdder", + "url": "/api/qiskit/0.46/qiskit.circuit.library.VBERippleCarryAdder" + }, + { + "title": "WeightedAdder", + "url": "/api/qiskit/0.46/qiskit.circuit.library.WeightedAdder" + }, + { + "title": "XGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.XGate" + }, + { + "title": "XOR", + "url": "/api/qiskit/0.46/qiskit.circuit.library.XOR" + }, + { + "title": "XXMinusYYGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.XXMinusYYGate" + }, + { + "title": "XXPlusYYGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.XXPlusYYGate" + }, + { + "title": "YGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.YGate" + }, + { + "title": "ZFeatureMap", + "url": "/api/qiskit/0.46/qiskit.circuit.library.ZFeatureMap" + }, + { + "title": "ZGate", + "url": "/api/qiskit/0.46/qiskit.circuit.library.ZGate" + }, + { + "title": "ZZFeatureMap", + "url": "/api/qiskit/0.46/qiskit.circuit.library.ZZFeatureMap" + } + ] + } + ] + }, + { + "title": "qiskit.compiler", + "url": "/api/qiskit/0.46/compiler" + }, + { + "title": "qiskit.converters", + "url": "/api/qiskit/0.46/converters" + }, + { + "title": "qiskit.dagcircuit", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/dagcircuit" + }, + { + "title": "DAGCircuit", + "url": "/api/qiskit/0.46/qiskit.dagcircuit.DAGCircuit" + }, + { + "title": "DAGDependency", + "url": "/api/qiskit/0.46/qiskit.dagcircuit.DAGDependency" + }, + { + "title": "DAGDepNode", + "url": "/api/qiskit/0.46/qiskit.dagcircuit.DAGDepNode" + }, + { + "title": "DAGInNode", + "url": "/api/qiskit/0.46/qiskit.dagcircuit.DAGInNode" + }, + { + "title": "DAGNode", + "url": "/api/qiskit/0.46/qiskit.dagcircuit.DAGNode" + }, + { + "title": "DAGOpNode", + "url": "/api/qiskit/0.46/qiskit.dagcircuit.DAGOpNode" + }, + { + "title": "DAGOutNode", + "url": "/api/qiskit/0.46/qiskit.dagcircuit.DAGOutNode" + } + ] + }, + { + "title": "qiskit.exceptions", + "url": "/api/qiskit/0.46/exceptions" + }, + { + "title": "qiskit.execute_function", + "url": "/api/qiskit/0.46/execute" + }, + { + "title": "qiskit.extensions", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/extensions" + }, + { + "title": "SingleQubitUnitary", + "url": "/api/qiskit/0.46/qiskit.extensions.SingleQubitUnitary" + }, + { + "title": "Snapshot", + "url": "/api/qiskit/0.46/qiskit.extensions.Snapshot" + } + ] + }, + { + "title": "qiskit.opflow", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/opflow" + }, + { + "title": "OperatorBase", + "url": "/api/qiskit/0.46/qiskit.opflow.OperatorBase" + }, + { + "title": "qiskit.opflow.converters", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.opflow.converters" + }, + { + "title": "AbelianGrouper", + "url": "/api/qiskit/0.46/qiskit.opflow.converters.AbelianGrouper" + }, + { + "title": "CircuitSampler", + "url": "/api/qiskit/0.46/qiskit.opflow.converters.CircuitSampler" + }, + { + "title": "ConverterBase", + "url": "/api/qiskit/0.46/qiskit.opflow.converters.ConverterBase" + }, + { + "title": "DictToCircuitSum", + "url": "/api/qiskit/0.46/qiskit.opflow.converters.DictToCircuitSum" + }, + { + "title": "PauliBasisChange", + "url": "/api/qiskit/0.46/qiskit.opflow.converters.PauliBasisChange" + }, + { + "title": "TwoQubitReduction", + "url": "/api/qiskit/0.46/qiskit.opflow.converters.TwoQubitReduction" + } + ] + }, + { + "title": "qiskit.opflow.evolutions", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions" + }, + { + "title": "EvolutionBase", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionBase" + }, + { + "title": "EvolutionFactory", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionFactory" + }, + { + "title": "EvolvedOp", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.EvolvedOp" + }, + { + "title": "MatrixEvolution", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.MatrixEvolution" + }, + { + "title": "PauliTrotterEvolution", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.PauliTrotterEvolution" + }, + { + "title": "QDrift", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.QDrift" + }, + { + "title": "Suzuki", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.Suzuki" + }, + { + "title": "Trotter", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.Trotter" + }, + { + "title": "TrotterizationBase", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationBase" + }, + { + "title": "TrotterizationFactory", + "url": "/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationFactory" + } + ] + }, + { + "title": "qiskit.opflow.expectations", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.opflow.expectations" + }, + { + "title": "AerPauliExpectation", + "url": "/api/qiskit/0.46/qiskit.opflow.expectations.AerPauliExpectation" + }, + { + "title": "CVaRExpectation", + "url": "/api/qiskit/0.46/qiskit.opflow.expectations.CVaRExpectation" + }, + { + "title": "ExpectationBase", + "url": "/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationBase" + }, + { + "title": "ExpectationFactory", + "url": "/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationFactory" + }, + { + "title": "MatrixExpectation", + "url": "/api/qiskit/0.46/qiskit.opflow.expectations.MatrixExpectation" + }, + { + "title": "PauliExpectation", + "url": "/api/qiskit/0.46/qiskit.opflow.expectations.PauliExpectation" + } + ] + }, + { + "title": "qiskit.opflow.gradients", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients" + }, + { + "title": "CircuitGradient", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.CircuitGradient" + }, + { + "title": "CircuitQFI", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.CircuitQFI" + }, + { + "title": "DerivativeBase", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.DerivativeBase" + }, + { + "title": "Gradient", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.Gradient" + }, + { + "title": "GradientBase", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.GradientBase" + }, + { + "title": "Hessian", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.Hessian" + }, + { + "title": "HessianBase", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.HessianBase" + }, + { + "title": "NaturalGradient", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.NaturalGradient" + }, + { + "title": "QFI", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.QFI" + }, + { + "title": "QFIBase", + "url": "/api/qiskit/0.46/qiskit.opflow.gradients.QFIBase" + } + ] + }, + { + "title": "qiskit.opflow.list_ops", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.opflow.list_ops" + }, + { + "title": "ComposedOp", + "url": "/api/qiskit/0.46/qiskit.opflow.list_ops.ComposedOp" + }, + { + "title": "ListOp", + "url": "/api/qiskit/0.46/qiskit.opflow.list_ops.ListOp" + }, + { + "title": "SummedOp", + "url": "/api/qiskit/0.46/qiskit.opflow.list_ops.SummedOp" + }, + { + "title": "TensoredOp", + "url": "/api/qiskit/0.46/qiskit.opflow.list_ops.TensoredOp" + } + ] + }, + { + "title": "qiskit.opflow.primitive_ops", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops" + }, + { + "title": "CircuitOp", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops.CircuitOp" + }, + { + "title": "MatrixOp", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops.MatrixOp" + }, + { + "title": "PauliOp", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliOp" + }, + { + "title": "PauliSumOp", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliSumOp" + }, + { + "title": "PrimitiveOp", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops.PrimitiveOp" + }, + { + "title": "TaperedPauliSumOp", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops.TaperedPauliSumOp" + }, + { + "title": "Z2Symmetries", + "url": "/api/qiskit/0.46/qiskit.opflow.primitive_ops.Z2Symmetries" + } + ] + }, + { + "title": "qiskit.opflow.state_fns", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns" + }, + { + "title": "CircuitStateFn", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns.CircuitStateFn" + }, + { + "title": "CVaRMeasurement", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns.CVaRMeasurement" + }, + { + "title": "DictStateFn", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns.DictStateFn" + }, + { + "title": "OperatorStateFn", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns.OperatorStateFn" + }, + { + "title": "SparseVectorStateFn", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns.SparseVectorStateFn" + }, + { + "title": "StateFn", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns.StateFn" + }, + { + "title": "VectorStateFn", + "url": "/api/qiskit/0.46/qiskit.opflow.state_fns.VectorStateFn" + } + ] + } + ] + }, + { + "title": "qiskit.passmanager", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/passmanager" + }, + { + "title": "BaseController", + "url": "/api/qiskit/0.46/qiskit.passmanager.BaseController" + }, + { + "title": "BasePassManager", + "url": "/api/qiskit/0.46/qiskit.passmanager.BasePassManager" + }, + { + "title": "ConditionalController", + "url": "/api/qiskit/0.46/qiskit.passmanager.ConditionalController" + }, + { + "title": "DoWhileController", + "url": "/api/qiskit/0.46/qiskit.passmanager.DoWhileController" + }, + { + "title": "FlowController", + "url": "/api/qiskit/0.46/qiskit.passmanager.FlowController" + }, + { + "title": "FlowControllerLinear", + "url": "/api/qiskit/0.46/qiskit.passmanager.FlowControllerLinear" + }, + { + "title": "GenericPass", + "url": "/api/qiskit/0.46/qiskit.passmanager.GenericPass" + }, + { + "title": "PassManagerState", + "url": "/api/qiskit/0.46/qiskit.passmanager.PassManagerState" + }, + { + "title": "PropertySet", + "url": "/api/qiskit/0.46/qiskit.passmanager.PropertySet" + }, + { + "title": "WorkflowStatus", + "url": "/api/qiskit/0.46/qiskit.passmanager.WorkflowStatus" + } + ] + }, + { + "title": "qiskit.primitives", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/primitives" + }, + { + "title": "BackendEstimator", + "url": "/api/qiskit/0.46/qiskit.primitives.BackendEstimator" + }, + { + "title": "BackendSampler", + "url": "/api/qiskit/0.46/qiskit.primitives.BackendSampler" + }, + { + "title": "BaseEstimator", + "url": "/api/qiskit/0.46/qiskit.primitives.BaseEstimator" + }, + { + "title": "BaseSampler", + "url": "/api/qiskit/0.46/qiskit.primitives.BaseSampler" + }, + { + "title": "Estimator", + "url": "/api/qiskit/0.46/qiskit.primitives.Estimator" + }, + { + "title": "EstimatorResult", + "url": "/api/qiskit/0.46/qiskit.primitives.EstimatorResult" + }, + { + "title": "Sampler", + "url": "/api/qiskit/0.46/qiskit.primitives.Sampler" + }, + { + "title": "SamplerResult", + "url": "/api/qiskit/0.46/qiskit.primitives.SamplerResult" + } + ] + }, + { + "title": "qiskit.providers", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/providers" + }, + { + "title": "Backend", + "url": "/api/qiskit/0.46/qiskit.providers.Backend" + }, + { + "title": "BackendV1", + "url": "/api/qiskit/0.46/qiskit.providers.BackendV1" + }, + { + "title": "BackendV2", + "url": "/api/qiskit/0.46/qiskit.providers.BackendV2" + }, + { + "title": "BackendV2Converter", + "url": "/api/qiskit/0.46/qiskit.providers.BackendV2Converter" + }, + { + "title": "convert_to_target", + "url": "/api/qiskit/0.46/qiskit.providers.convert_to_target" + }, + { + "title": "Job", + "url": "/api/qiskit/0.46/qiskit.providers.Job" + }, + { + "title": "JobStatus", + "url": "/api/qiskit/0.46/qiskit.providers.JobStatus" + }, + { + "title": "JobV1", + "url": "/api/qiskit/0.46/qiskit.providers.JobV1" + }, + { + "title": "Options", + "url": "/api/qiskit/0.46/qiskit.providers.Options" + }, + { + "title": "Provider", + "url": "/api/qiskit/0.46/qiskit.providers.Provider" + }, + { + "title": "ProviderV1", + "url": "/api/qiskit/0.46/qiskit.providers.ProviderV1" + }, + { + "title": "QubitProperties", + "url": "/api/qiskit/0.46/qiskit.providers.QubitProperties" + }, + { + "title": "qiskit.providers.basic_provider", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/providers_basic_provider" + }, + { + "title": "BasicProvider", + "url": "/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProvider" + }, + { + "title": "BasicProviderError", + "url": "/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderError" + }, + { + "title": "BasicProviderJob", + "url": "/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderJob" + }, + { + "title": "BasicSimulator", + "url": "/api/qiskit/0.46/qiskit.providers.basic_provider.BasicSimulator" + } + ] + }, + { + "title": "qiskit.providers.basicaer", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/providers_basicaer" + }, + { + "title": "BasicAerError", + "url": "/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerError" + }, + { + "title": "BasicAerJob", + "url": "/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerJob" + }, + { + "title": "BasicAerProvider", + "url": "/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerProvider" + }, + { + "title": "QasmSimulatorPy", + "url": "/api/qiskit/0.46/qiskit.providers.basicaer.QasmSimulatorPy" + }, + { + "title": "StatevectorSimulatorPy", + "url": "/api/qiskit/0.46/qiskit.providers.basicaer.StatevectorSimulatorPy" + }, + { + "title": "UnitarySimulatorPy", + "url": "/api/qiskit/0.46/qiskit.providers.basicaer.UnitarySimulatorPy" + } + ] + }, + { + "title": "qiskit.providers.fake_provider", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/providers_fake_provider" + }, + { + "title": "ConfigurableFakeBackend", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.ConfigurableFakeBackend" + }, + { + "title": "Fake1Q", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.Fake1Q" + }, + { + "title": "FakeAlmaden", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmaden" + }, + { + "title": "FakeAlmadenV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmadenV2" + }, + { + "title": "FakeArmonk", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonk" + }, + { + "title": "FakeArmonkV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonkV2" + }, + { + "title": "FakeAthens", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthens" + }, + { + "title": "FakeAthensV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthensV2" + }, + { + "title": "FakeAuckland", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAuckland" + }, + { + "title": "FakeBackend5QV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackend5QV2" + }, + { + "title": "FakeBackendV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackendV2" + }, + { + "title": "FakeBelem", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelem" + }, + { + "title": "FakeBelemV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelemV2" + }, + { + "title": "FakeBoeblingen", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingen" + }, + { + "title": "FakeBoeblingenV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingenV2" + }, + { + "title": "FakeBogota", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogota" + }, + { + "title": "FakeBogotaV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogotaV2" + }, + { + "title": "FakeBrooklyn", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklyn" + }, + { + "title": "FakeBrooklynV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklynV2" + }, + { + "title": "FakeBurlington", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlington" + }, + { + "title": "FakeBurlingtonV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlingtonV2" + }, + { + "title": "FakeCairo", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairo" + }, + { + "title": "FakeCairoV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairoV2" + }, + { + "title": "FakeCambridge", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridge" + }, + { + "title": "FakeCambridgeV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridgeV2" + }, + { + "title": "FakeCasablanca", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablanca" + }, + { + "title": "FakeCasablancaV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablancaV2" + }, + { + "title": "FakeEssex", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssex" + }, + { + "title": "FakeEssexV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssexV2" + }, + { + "title": "FakeGeneva", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGeneva" + }, + { + "title": "FakeGuadalupe", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupe" + }, + { + "title": "FakeGuadalupeV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupeV2" + }, + { + "title": "FakeHanoi", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoi" + }, + { + "title": "FakeHanoiV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoiV2" + }, + { + "title": "FakeJakarta", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakarta" + }, + { + "title": "FakeJakartaV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakartaV2" + }, + { + "title": "FakeJohannesburg", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburg" + }, + { + "title": "FakeJohannesburgV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburgV2" + }, + { + "title": "FakeKolkata", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkata" + }, + { + "title": "FakeKolkataV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkataV2" + }, + { + "title": "FakeLagos", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagos" + }, + { + "title": "FakeLagosV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagosV2" + }, + { + "title": "FakeLima", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLima" + }, + { + "title": "FakeLimaV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLimaV2" + }, + { + "title": "FakeLondon", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondon" + }, + { + "title": "FakeLondonV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondonV2" + }, + { + "title": "FakeManhattan", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattan" + }, + { + "title": "FakeManhattanV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattanV2" + }, + { + "title": "FakeManila", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManila" + }, + { + "title": "FakeManilaV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManilaV2" + }, + { + "title": "FakeMelbourne", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourne" + }, + { + "title": "FakeMelbourneV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourneV2" + }, + { + "title": "FakeMontreal", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontreal" + }, + { + "title": "FakeMontrealV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontrealV2" + }, + { + "title": "FakeMumbai", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbai" + }, + { + "title": "FakeMumbaiFractionalCX", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiFractionalCX" + }, + { + "title": "FakeMumbaiV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiV2" + }, + { + "title": "FakeNairobi", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobi" + }, + { + "title": "FakeNairobiV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobiV2" + }, + { + "title": "FakeOpenPulse2Q", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse2Q" + }, + { + "title": "FakeOpenPulse3Q", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse3Q" + }, + { + "title": "FakeOslo", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOslo" + }, + { + "title": "FakeOurense", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurense" + }, + { + "title": "FakeOurenseV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurenseV2" + }, + { + "title": "FakeParis", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParis" + }, + { + "title": "FakeParisV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParisV2" + }, + { + "title": "FakePerth", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakePerth" + }, + { + "title": "FakePoughkeepsie", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsie" + }, + { + "title": "FakePoughkeepsieV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsieV2" + }, + { + "title": "FakePrague", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakePrague" + }, + { + "title": "FakeProvider", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProvider" + }, + { + "title": "FakeProviderForBackendV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProviderForBackendV2" + }, + { + "title": "FakeQasmSimulator", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQasmSimulator" + }, + { + "title": "FakeQuito", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuito" + }, + { + "title": "FakeQuitoV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuitoV2" + }, + { + "title": "FakeRochester", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochester" + }, + { + "title": "FakeRochesterV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochesterV2" + }, + { + "title": "FakeRome", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRome" + }, + { + "title": "FakeRomeV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRomeV2" + }, + { + "title": "FakeRueschlikon", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRueschlikon" + }, + { + "title": "FakeSantiago", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiago" + }, + { + "title": "FakeSantiagoV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiagoV2" + }, + { + "title": "FakeSherbrooke", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSherbrooke" + }, + { + "title": "FakeSingapore", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingapore" + }, + { + "title": "FakeSingaporeV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingaporeV2" + }, + { + "title": "FakeSydney", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydney" + }, + { + "title": "FakeSydneyV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydneyV2" + }, + { + "title": "FakeTenerife", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTenerife" + }, + { + "title": "FakeTokyo", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTokyo" + }, + { + "title": "FakeToronto", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeToronto" + }, + { + "title": "FakeTorontoV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTorontoV2" + }, + { + "title": "FakeValencia", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValencia" + }, + { + "title": "FakeValenciaV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValenciaV2" + }, + { + "title": "FakeVigo", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigo" + }, + { + "title": "FakeVigoV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigoV2" + }, + { + "title": "FakeWashington", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashington" + }, + { + "title": "FakeWashingtonV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashingtonV2" + }, + { + "title": "FakeYorktown", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktown" + }, + { + "title": "FakeYorktownV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktownV2" + }, + { + "title": "GenericBackendV2", + "url": "/api/qiskit/0.46/qiskit.providers.fake_provider.GenericBackendV2" + } + ] + }, + { + "title": "qiskit.providers.models", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/providers_models" + }, + { + "title": "BackendConfiguration", + "url": "/api/qiskit/0.46/qiskit.providers.models.BackendConfiguration" + }, + { + "title": "BackendProperties", + "url": "/api/qiskit/0.46/qiskit.providers.models.BackendProperties" + }, + { + "title": "BackendStatus", + "url": "/api/qiskit/0.46/qiskit.providers.models.BackendStatus" + }, + { + "title": "Command", + "url": "/api/qiskit/0.46/qiskit.providers.models.Command" + }, + { + "title": "GateConfig", + "url": "/api/qiskit/0.46/qiskit.providers.models.GateConfig" + }, + { + "title": "GateProperties", + "url": "/api/qiskit/0.46/qiskit.providers.models.GateProperties" + }, + { + "title": "JobStatus", + "url": "/api/qiskit/0.46/qiskit.providers.models.JobStatus" + }, + { + "title": "Nduv", + "url": "/api/qiskit/0.46/qiskit.providers.models.Nduv" + }, + { + "title": "PulseBackendConfiguration", + "url": "/api/qiskit/0.46/qiskit.providers.models.PulseBackendConfiguration" + }, + { + "title": "PulseDefaults", + "url": "/api/qiskit/0.46/qiskit.providers.models.PulseDefaults" + }, + { + "title": "QasmBackendConfiguration", + "url": "/api/qiskit/0.46/qiskit.providers.models.QasmBackendConfiguration" + }, + { + "title": "UchannelLO", + "url": "/api/qiskit/0.46/qiskit.providers.models.UchannelLO" + } + ] + } + ] + }, + { + "title": "qiskit.pulse", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/pulse" + }, + { + "title": "Acquire", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.Acquire" + }, + { + "title": "AcquireChannel", + "url": "/api/qiskit/0.46/qiskit.pulse.channels.AcquireChannel" + }, + { + "title": "AlignEquispaced", + "url": "/api/qiskit/0.46/qiskit.pulse.transforms.AlignEquispaced" + }, + { + "title": "AlignFunc", + "url": "/api/qiskit/0.46/qiskit.pulse.transforms.AlignFunc" + }, + { + "title": "AlignLeft", + "url": "/api/qiskit/0.46/qiskit.pulse.transforms.AlignLeft" + }, + { + "title": "AlignRight", + "url": "/api/qiskit/0.46/qiskit.pulse.transforms.AlignRight" + }, + { + "title": "AlignSequential", + "url": "/api/qiskit/0.46/qiskit.pulse.transforms.AlignSequential" + }, + { + "title": "Call", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.Call" + }, + { + "title": "Constant", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Constant_class.rst" + }, + { + "title": "ControlChannel", + "url": "/api/qiskit/0.46/qiskit.pulse.channels.ControlChannel" + }, + { + "title": "Cos", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Cos_class.rst" + }, + { + "title": "Delay", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.Delay" + }, + { + "title": "Drag", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Drag_class.rst" + }, + { + "title": "DriveChannel", + "url": "/api/qiskit/0.46/qiskit.pulse.channels.DriveChannel" + }, + { + "title": "Gaussian", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Gaussian_class.rst" + }, + { + "title": "gaussian_square_echo", + "url": "/api/qiskit/0.46/qiskit.pulse.library.gaussian_square_echo" + }, + { + "title": "GaussianDeriv", + "url": "/api/qiskit/0.46/qiskit.pulse.library.GaussianDeriv" + }, + { + "title": "GaussianSquare", + "url": "/api/qiskit/0.46/qiskit.pulse.library.GaussianSquare" + }, + { + "title": "GaussianSquareDrag", + "url": "/api/qiskit/0.46/qiskit.pulse.library.GaussianSquareDrag" + }, + { + "title": "InstructionScheduleMap", + "url": "/api/qiskit/0.46/qiskit.pulse.InstructionScheduleMap" + }, + { + "title": "MeasureChannel", + "url": "/api/qiskit/0.46/qiskit.pulse.channels.MeasureChannel" + }, + { + "title": "MemorySlot", + "url": "/api/qiskit/0.46/qiskit.pulse.channels.MemorySlot" + }, + { + "title": "ParametricPulse", + "url": "/api/qiskit/0.46/qiskit.pulse.library.ParametricPulse" + }, + { + "title": "Play", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.Play" + }, + { + "title": "Reference", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.Reference" + }, + { + "title": "RegisterSlot", + "url": "/api/qiskit/0.46/qiskit.pulse.channels.RegisterSlot" + }, + { + "title": "RelativeBarrier", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.RelativeBarrier" + }, + { + "title": "Sawtooth", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Sawtooth_class.rst" + }, + { + "title": "Schedule", + "url": "/api/qiskit/0.46/qiskit.pulse.Schedule" + }, + { + "title": "ScheduleBlock", + "url": "/api/qiskit/0.46/qiskit.pulse.ScheduleBlock" + }, + { + "title": "Sech", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Sech_fun.rst" + }, + { + "title": "SechDeriv", + "url": "/api/qiskit/0.46/qiskit.pulse.library.SechDeriv" + }, + { + "title": "SetFrequency", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.SetFrequency" + }, + { + "title": "SetPhase", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.SetPhase" + }, + { + "title": "ShiftFrequency", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.ShiftFrequency" + }, + { + "title": "ShiftPhase", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.ShiftPhase" + }, + { + "title": "Sin", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Sin_class.rst" + }, + { + "title": "Snapshot", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.Snapshot" + }, + { + "title": "SnapshotChannel", + "url": "/api/qiskit/0.46/qiskit.pulse.channels.SnapshotChannel" + }, + { + "title": "Square", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Square_fun.rst" + }, + { + "title": "SymbolicPulse", + "url": "/api/qiskit/0.46/qiskit.pulse.library.SymbolicPulse" + }, + { + "title": "TimeBlockade", + "url": "/api/qiskit/0.46/qiskit.pulse.instructions.TimeBlockade" + }, + { + "title": "Triangle", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Triangle_class.rst" + }, + { + "title": "Waveform", + "url": "/api/qiskit/0.46/qiskit.pulse.library.Waveform" + } + ] + }, + { + "title": "qiskit.qasm", + "url": "/api/qiskit/0.46/qasm" + }, + { + "title": "qiskit.qasm2", + "url": "/api/qiskit/0.46/qasm2" + }, + { + "title": "qiskit.qasm3", + "url": "/api/qiskit/0.46/qasm3" + }, + { + "title": "qiskit.qobj", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/qobj" + }, + { + "title": "GateCalibration", + "url": "/api/qiskit/0.46/qiskit.qobj.GateCalibration" + }, + { + "title": "PulseLibraryItem", + "url": "/api/qiskit/0.46/qiskit.qobj.PulseLibraryItem" + }, + { + "title": "PulseQobj", + "url": "/api/qiskit/0.46/qiskit.qobj.PulseQobj" + }, + { + "title": "PulseQobjConfig", + "url": "/api/qiskit/0.46/qiskit.qobj.PulseQobjConfig" + }, + { + "title": "PulseQobjExperiment", + "url": "/api/qiskit/0.46/qiskit.qobj.PulseQobjExperiment" + }, + { + "title": "PulseQobjExperimentConfig", + "url": "/api/qiskit/0.46/qiskit.qobj.PulseQobjExperimentConfig" + }, + { + "title": "PulseQobjInstruction", + "url": "/api/qiskit/0.46/qiskit.qobj.PulseQobjInstruction" + }, + { + "title": "QasmExperimentCalibrations", + "url": "/api/qiskit/0.46/qiskit.qobj.QasmExperimentCalibrations" + }, + { + "title": "QasmQobj", + "url": "/api/qiskit/0.46/qiskit.qobj.QasmQobj" + }, + { + "title": "QasmQobjConfig", + "url": "/api/qiskit/0.46/qiskit.qobj.QasmQobjConfig" + }, + { + "title": "QasmQobjExperiment", + "url": "/api/qiskit/0.46/qiskit.qobj.QasmQobjExperiment" + }, + { + "title": "QasmQobjExperimentConfig", + "url": "/api/qiskit/0.46/qiskit.qobj.QasmQobjExperimentConfig" + }, + { + "title": "QasmQobjInstruction", + "url": "/api/qiskit/0.46/qiskit.qobj.QasmQobjInstruction" + }, + { + "title": "QobjExperimentHeader", + "url": "/api/qiskit/0.46/qiskit.qobj.QobjExperimentHeader" + }, + { + "title": "QobjHeader", + "url": "/api/qiskit/0.46/qiskit.qobj.QobjHeader" + }, + { + "title": "QobjMeasurementOption", + "url": "/api/qiskit/0.46/qiskit.qobj.QobjMeasurementOption" + } + ] + }, + { + "title": "qiskit.qpy", + "url": "/api/qiskit/0.46/qpy" + }, + { + "title": "qiskit.quantum_info", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/quantum_info" + }, + { + "title": "Chi", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Chi" + }, + { + "title": "Choi", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Choi" + }, + { + "title": "Clifford", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Clifford" + }, + { + "title": "CNOTDihedral", + "url": "/api/qiskit/0.46/qiskit.quantum_info.CNOTDihedral" + }, + { + "title": "DensityMatrix", + "url": "/api/qiskit/0.46/qiskit.quantum_info.DensityMatrix" + }, + { + "title": "Kraus", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Kraus" + }, + { + "title": "Operator", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Operator" + }, + { + "title": "Pauli", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Pauli" + }, + { + "title": "pauli_basis", + "url": "/api/qiskit/0.46/qiskit.quantum_info.pauli_basis" + }, + { + "title": "PauliList", + "url": "/api/qiskit/0.46/qiskit.quantum_info.PauliList" + }, + { + "title": "PTM", + "url": "/api/qiskit/0.46/qiskit.quantum_info.PTM" + }, + { + "title": "Quaternion", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Quaternion" + }, + { + "title": "ScalarOp", + "url": "/api/qiskit/0.46/qiskit.quantum_info.ScalarOp" + }, + { + "title": "SparsePauliOp", + "url": "/api/qiskit/0.46/qiskit.quantum_info.SparsePauliOp" + }, + { + "title": "StabilizerState", + "url": "/api/qiskit/0.46/qiskit.quantum_info.StabilizerState" + }, + { + "title": "Statevector", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Statevector" + }, + { + "title": "Stinespring", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Stinespring" + }, + { + "title": "SuperOp", + "url": "/api/qiskit/0.46/qiskit.quantum_info.SuperOp" + }, + { + "title": "Z2Symmetries", + "url": "/api/qiskit/0.46/qiskit.quantum_info.Z2Symmetries" + } + ] + }, + { + "title": "qiskit.result", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/result" + }, + { + "title": "BaseReadoutMitigator", + "url": "/api/qiskit/0.46/qiskit.result.BaseReadoutMitigator" + }, + { + "title": "CorrelatedReadoutMitigator", + "url": "/api/qiskit/0.46/qiskit.result.CorrelatedReadoutMitigator" + }, + { + "title": "Counts", + "url": "/api/qiskit/0.46/qiskit.result.Counts" + }, + { + "title": "LocalReadoutMitigator", + "url": "/api/qiskit/0.46/qiskit.result.LocalReadoutMitigator" + }, + { + "title": "ProbDistribution", + "url": "/api/qiskit/0.46/qiskit.result.ProbDistribution" + }, + { + "title": "QuasiDistribution", + "url": "/api/qiskit/0.46/qiskit.result.QuasiDistribution" + }, + { + "title": "Result", + "url": "/api/qiskit/0.46/qiskit.result.Result" + }, + { + "title": "ResultError", + "url": "/api/qiskit/0.46/qiskit.result.ResultError" + } + ] + }, + { + "title": "qiskit.scheduler", + "url": "/api/qiskit/0.46/scheduler" + }, + { + "title": "qiskit.synthesis", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/synthesis" + }, + { + "title": "EvolutionSynthesis", + "url": "/api/qiskit/0.46/qiskit.synthesis.EvolutionSynthesis" + }, + { + "title": "LieTrotter", + "url": "/api/qiskit/0.46/qiskit.synthesis.LieTrotter" + }, + { + "title": "MatrixExponential", + "url": "/api/qiskit/0.46/qiskit.synthesis.MatrixExponential" + }, + { + "title": "OneQubitEulerDecomposer", + "url": "/api/qiskit/0.46/qiskit.synthesis.OneQubitEulerDecomposer" + }, + { + "title": "ProductFormula", + "url": "/api/qiskit/0.46/qiskit.synthesis.ProductFormula" + }, + { + "title": "QDrift", + "url": "/api/qiskit/0.46/qiskit.synthesis.QDrift" + }, + { + "title": "SolovayKitaevDecomposition", + "url": "/api/qiskit/0.46/qiskit.synthesis.SolovayKitaevDecomposition" + }, + { + "title": "SuzukiTrotter", + "url": "/api/qiskit/0.46/qiskit.synthesis.SuzukiTrotter" + }, + { + "title": "TwoQubitBasisDecomposer", + "url": "/api/qiskit/0.46/qiskit.synthesis.TwoQubitBasisDecomposer" + }, + { + "title": "XXDecomposer", + "url": "/api/qiskit/0.46/qiskit.synthesis.XXDecomposer" + }, + { + "title": "qiskit.synthesis.unitary.aqc", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/synthesis_aqc" + }, + { + "title": "ApproximateCircuit", + "url": "/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximateCircuit" + }, + { + "title": "ApproximatingObjective", + "url": "/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximatingObjective" + }, + { + "title": "AQC", + "url": "/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.AQC" + }, + { + "title": "CNOTUnitCircuit", + "url": "/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit" + }, + { + "title": "CNOTUnitObjective", + "url": "/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitObjective" + }, + { + "title": "DefaultCNOTUnitObjective", + "url": "/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective" + }, + { + "title": "FastCNOTUnitObjective", + "url": "/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective" + } + ] + } + ] + }, + { + "title": "qiskit.tools", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/tools" + }, + { + "title": "qiskit.tools.jupyter", + "url": "/api/qiskit/0.46/tools_jupyter" + } + ] + }, + { + "title": "qiskit.transpiler", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/transpiler" + }, + { + "title": "AnalysisPass", + "url": "/api/qiskit/0.46/qiskit.transpiler.AnalysisPass" + }, + { + "title": "CouplingMap", + "url": "/api/qiskit/0.46/qiskit.transpiler.CouplingMap" + }, + { + "title": "FencedDAGCircuit", + "url": "/api/qiskit/0.46/qiskit.transpiler.FencedDAGCircuit" + }, + { + "title": "FencedPropertySet", + "url": "/api/qiskit/0.46/qiskit.transpiler.FencedPropertySet" + }, + { + "title": "InstructionDurations", + "url": "/api/qiskit/0.46/qiskit.transpiler.InstructionDurations" + }, + { + "title": "InstructionProperties", + "url": "/api/qiskit/0.46/qiskit.transpiler.InstructionProperties" + }, + { + "title": "Layout", + "url": "/api/qiskit/0.46/qiskit.transpiler.Layout" + }, + { + "title": "PassManager", + "url": "/api/qiskit/0.46/qiskit.transpiler.PassManager" + }, + { + "title": "PassManagerConfig", + "url": "/api/qiskit/0.46/qiskit.transpiler.PassManagerConfig" + }, + { + "title": "StagedPassManager", + "url": "/api/qiskit/0.46/qiskit.transpiler.StagedPassManager" + }, + { + "title": "Target", + "url": "/api/qiskit/0.46/qiskit.transpiler.Target" + }, + { + "title": "TransformationPass", + "url": "/api/qiskit/0.46/qiskit.transpiler.TransformationPass" + }, + { + "title": "TranspileLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.TranspileLayout" + }, + { + "title": "qiskit.transpiler.passes", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/transpiler_passes" + }, + { + "title": "ALAPSchedule", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ALAPSchedule" + }, + { + "title": "ALAPScheduleAnalysis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ALAPScheduleAnalysis" + }, + { + "title": "AlignMeasures", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.AlignMeasures" + }, + { + "title": "ApplyLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ApplyLayout" + }, + { + "title": "AQCSynthesisPlugin", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.AQCSynthesisPlugin" + }, + { + "title": "ASAPSchedule", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ASAPSchedule" + }, + { + "title": "ASAPScheduleAnalysis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ASAPScheduleAnalysis" + }, + { + "title": "BarrierBeforeFinalMeasurements", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements" + }, + { + "title": "BasicSwap", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.BasicSwap" + }, + { + "title": "BasisTranslator", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.BasisTranslator" + }, + { + "title": "CheckGateDirection", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CheckGateDirection" + }, + { + "title": "CheckMap", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CheckMap" + }, + { + "title": "Collect1qRuns", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Collect1qRuns" + }, + { + "title": "Collect2qBlocks", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Collect2qBlocks" + }, + { + "title": "CollectCliffords", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CollectCliffords" + }, + { + "title": "CollectLinearFunctions", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CollectLinearFunctions" + }, + { + "title": "CollectMultiQBlocks", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CollectMultiQBlocks" + }, + { + "title": "CommutationAnalysis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CommutationAnalysis" + }, + { + "title": "CommutativeCancellation", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeCancellation" + }, + { + "title": "CommutativeInverseCancellation", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeInverseCancellation" + }, + { + "title": "Commuting2qGateRouter", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Commuting2qGateRouter" + }, + { + "title": "ConsolidateBlocks", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ConsolidateBlocks" + }, + { + "title": "ConstrainedReschedule", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ConstrainedReschedule" + }, + { + "title": "ContainsInstruction", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ContainsInstruction" + }, + { + "title": "ConvertConditionsToIfOps", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ConvertConditionsToIfOps" + }, + { + "title": "CountOps", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CountOps" + }, + { + "title": "CountOpsLongestPath", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CountOpsLongestPath" + }, + { + "title": "CrosstalkAdaptiveSchedule", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CrosstalkAdaptiveSchedule" + }, + { + "title": "CSPLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CSPLayout" + }, + { + "title": "CXCancellation", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.CXCancellation" + }, + { + "title": "DAGFixedPoint", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.DAGFixedPoint" + }, + { + "title": "DAGLongestPath", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.DAGLongestPath" + }, + { + "title": "Decompose", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Decompose" + }, + { + "title": "DenseLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.DenseLayout" + }, + { + "title": "Depth", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Depth" + }, + { + "title": "DynamicalDecoupling", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.DynamicalDecoupling" + }, + { + "title": "EchoRZXWeylDecomposition", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.EchoRZXWeylDecomposition" + }, + { + "title": "EnlargeWithAncilla", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.EnlargeWithAncilla" + }, + { + "title": "FixedPoint", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.FixedPoint" + }, + { + "title": "FullAncillaAllocation", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.FullAncillaAllocation" + }, + { + "title": "GateDirection", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.GateDirection" + }, + { + "title": "GatesInBasis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.GatesInBasis" + }, + { + "title": "HighLevelSynthesis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.HighLevelSynthesis" + }, + { + "title": "HoareOptimizer", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.HoareOptimizer" + }, + { + "title": "InstructionDurationCheck", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.InstructionDurationCheck" + }, + { + "title": "InverseCancellation", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.InverseCancellation" + }, + { + "title": "Layout2qDistance", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Layout2qDistance" + }, + { + "title": "LinearFunctionsSynthesis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsSynthesis" + }, + { + "title": "LinearFunctionsToPermutations", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsToPermutations" + }, + { + "title": "LookaheadSwap", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.LookaheadSwap" + }, + { + "title": "MergeAdjacentBarriers", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.MergeAdjacentBarriers" + }, + { + "title": "MinimumPoint", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.MinimumPoint" + }, + { + "title": "NoiseAdaptiveLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.NoiseAdaptiveLayout" + }, + { + "title": "NormalizeRXAngle", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.NormalizeRXAngle" + }, + { + "title": "NumTensorFactors", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.NumTensorFactors" + }, + { + "title": "Optimize1qGates", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGates" + }, + { + "title": "Optimize1qGatesDecomposition", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesDecomposition" + }, + { + "title": "Optimize1qGatesSimpleCommutation", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation" + }, + { + "title": "OptimizeCliffords", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.OptimizeCliffords" + }, + { + "title": "PadDelay", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.PadDelay" + }, + { + "title": "PadDynamicalDecoupling", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.PadDynamicalDecoupling" + }, + { + "title": "PulseGates", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.PulseGates" + }, + { + "title": "RemoveBarriers", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.RemoveBarriers" + }, + { + "title": "RemoveDiagonalGatesBeforeMeasure", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure" + }, + { + "title": "RemoveFinalMeasurements", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.RemoveFinalMeasurements" + }, + { + "title": "RemoveResetInZeroState", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.RemoveResetInZeroState" + }, + { + "title": "ResetAfterMeasureSimplification", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ResetAfterMeasureSimplification" + }, + { + "title": "RXCalibrationBuilder", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.RXCalibrationBuilder" + }, + { + "title": "RZXCalibrationBuilder", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilder" + }, + { + "title": "RZXCalibrationBuilderNoEcho", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho" + }, + { + "title": "SabreLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.SabreLayout" + }, + { + "title": "SabrePreLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.SabrePreLayout" + }, + { + "title": "SabreSwap", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.SabreSwap" + }, + { + "title": "SetIOLatency", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.SetIOLatency" + }, + { + "title": "SetLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.SetLayout" + }, + { + "title": "Size", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Size" + }, + { + "title": "SolovayKitaev", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaev" + }, + { + "title": "SolovayKitaevSynthesis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaevSynthesis" + }, + { + "title": "StochasticSwap", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.StochasticSwap" + }, + { + "title": "TemplateOptimization", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.TemplateOptimization" + }, + { + "title": "TimeUnitConversion", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.TimeUnitConversion" + }, + { + "title": "TranslateParameterizedGates", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.TranslateParameterizedGates" + }, + { + "title": "TrivialLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.TrivialLayout" + }, + { + "title": "UnitarySynthesis", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.UnitarySynthesis" + }, + { + "title": "Unroll3qOrMore", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Unroll3qOrMore" + }, + { + "title": "UnrollCustomDefinitions", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.UnrollCustomDefinitions" + }, + { + "title": "Unroller", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Unroller" + }, + { + "title": "UnrollForLoops", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.UnrollForLoops" + }, + { + "title": "ValidatePulseGates", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.ValidatePulseGates" + }, + { + "title": "VF2Layout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.VF2Layout" + }, + { + "title": "VF2PostLayout", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.VF2PostLayout" + }, + { + "title": "Width", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.Width" + }, + { + "title": "qiskit.transpiler.passes.synthesis.plugin", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/transpiler_synthesis_plugins" + }, + { + "title": "HighLevelSynthesisPlugin", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin" + }, + { + "title": "HighLevelSynthesisPluginManager", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager" + }, + { + "title": "unitary_synthesis_plugin_names", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names" + }, + { + "title": "UnitarySynthesisPlugin", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin" + }, + { + "title": "UnitarySynthesisPluginManager", + "url": "/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager" + } + ] + } + ] + }, + { + "title": "qiskit.transpiler.preset_passmanagers", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/transpiler_preset" + }, + { + "title": "qiskit.transpiler.preset_passmanagers.plugin", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/transpiler_plugins" + }, + { + "title": "PassManagerStagePlugin", + "url": "/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin" + }, + { + "title": "PassManagerStagePluginManager", + "url": "/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager" + } + ] + } + ] + } + ] + }, + { + "title": "qiskit.utils", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/utils" + }, + { + "title": "QuantumInstance", + "url": "/api/qiskit/0.46/qiskit.utils.QuantumInstance" + }, + { + "title": "qiskit.utils.mitigation", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/utils_mitigation" + }, + { + "title": "CompleteMeasFitter", + "url": "/api/qiskit/0.46/qiskit.utils.mitigation.CompleteMeasFitter" + }, + { + "title": "TensoredMeasFitter", + "url": "/api/qiskit/0.46/qiskit.utils.mitigation.TensoredMeasFitter" + } + ] + } + ] + }, + { + "title": "qiskit.visualization", + "children": [ + { + "title": "Overview", + "url": "/api/qiskit/0.46/visualization" + }, + { + "title": "array_to_latex", + "url": "/api/qiskit/0.46/qiskit.visualization.array_to_latex" + }, + { + "title": "circuit_drawer", + "url": "/api/qiskit/0.46/qiskit.visualization.circuit_drawer" + }, + { + "title": "dag_drawer", + "url": "/api/qiskit/0.46/qiskit.visualization.dag_drawer" + }, + { + "title": "DefaultStyle", + "url": "/api/qiskit/0.46/qiskit.visualization.circuit.qcstyle.DefaultStyle" + }, + { + "title": "IQXDebugging", + "url": "/api/qiskit/0.46/qiskit.visualization.pulse.IQXDebugging" + }, + { + "title": "IQXSimple", + "url": "/api/qiskit/0.46/qiskit.visualization.pulse.IQXSimple" + }, + { + "title": "IQXStandard", + "url": "/api/qiskit/0.46/qiskit.visualization.pulse.IQXStandard" + }, + { + "title": "pass_manager_drawer", + "url": "/api/qiskit/0.46/qiskit.visualization.pass_manager_drawer" + }, + { + "title": "plot_bloch_multivector", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_bloch_multivector" + }, + { + "title": "plot_bloch_vector", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_bloch_vector" + }, + { + "title": "plot_circuit_layout", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_circuit_layout" + }, + { + "title": "plot_coupling_map", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_coupling_map" + }, + { + "title": "plot_distribution", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_distribution" + }, + { + "title": "plot_error_map", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_error_map" + }, + { + "title": "plot_gate_map", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_gate_map" + }, + { + "title": "plot_histogram", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_histogram" + }, + { + "title": "plot_state_city", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_state_city" + }, + { + "title": "plot_state_hinton", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_state_hinton" + }, + { + "title": "plot_state_paulivec", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_state_paulivec" + }, + { + "title": "plot_state_qsphere", + "url": "/api/qiskit/0.46/qiskit.visualization.plot_state_qsphere" + }, + { + "title": "pulse_drawer", + "url": "/api/qiskit/0.46/qiskit.visualization.pulse_drawer" + }, + { + "title": "timeline_drawer", + "url": "/api/qiskit/0.46/qiskit.visualization.timeline_drawer" + }, + { + "title": "visualize_transition", + "url": "/api/qiskit/0.46/qiskit.visualization.visualize_transition" + } + ] + }, + { + "title": "Release notes", + "children": [ + { + "title": "0.46", + "url": "/api/qiskit/release-notes/0.46" + }, + { + "title": "0.45", + "url": "/api/qiskit/release-notes/0.45" + }, + { + "title": "0.44", + "url": "/api/qiskit/release-notes/0.44" + }, + { + "title": "0.43", + "url": "/api/qiskit/release-notes/0.43" + }, + { + "title": "0.42", + "url": "/api/qiskit/release-notes/0.42" + }, + { + "title": "0.41", + "url": "/api/qiskit/release-notes/0.41" + }, + { + "title": "0.40", + "url": "/api/qiskit/release-notes/0.40" + }, + { + "title": "0.39", + "url": "/api/qiskit/release-notes/0.39" + }, + { + "title": "0.38", + "url": "/api/qiskit/release-notes/0.38" + }, + { + "title": "0.37", + "url": "/api/qiskit/release-notes/0.37" + }, + { + "title": "0.36", + "url": "/api/qiskit/release-notes/0.36" + }, + { + "title": "0.35", + "url": "/api/qiskit/release-notes/0.35" + }, + { + "title": "0.34", + "url": "/api/qiskit/release-notes/0.34" + }, + { + "title": "0.33", + "url": "/api/qiskit/release-notes/0.33" + }, + { + "title": "0.32", + "url": "/api/qiskit/release-notes/0.32" + }, + { + "title": "0.31", + "url": "/api/qiskit/release-notes/0.31" + }, + { + "title": "0.30", + "url": "/api/qiskit/release-notes/0.30" + }, + { + "title": "0.29", + "url": "/api/qiskit/release-notes/0.29" + }, + { + "title": "0.28", + "url": "/api/qiskit/release-notes/0.28" + }, + { + "title": "0.27", + "url": "/api/qiskit/release-notes/0.27" + }, + { + "title": "0.26", + "url": "/api/qiskit/release-notes/0.26" + }, + { + "title": "0.25", + "url": "/api/qiskit/release-notes/0.25" + }, + { + "title": "0.24", + "url": "/api/qiskit/release-notes/0.24" + }, + { + "title": "0.23", + "url": "/api/qiskit/release-notes/0.23" + }, + { + "title": "0.22", + "url": "/api/qiskit/release-notes/0.22" + }, + { + "title": "0.21", + "url": "/api/qiskit/release-notes/0.21" + }, + { + "title": "0.20", + "url": "/api/qiskit/release-notes/0.20" + }, + { + "title": "0.19", + "url": "/api/qiskit/release-notes/0.19" + }, + { + "title": "0.18", + "url": "/api/qiskit/release-notes/0.18" + }, + { + "title": "0.17", + "url": "/api/qiskit/release-notes/0.17" + }, + { + "title": "0.16", + "url": "/api/qiskit/release-notes/0.16" + }, + { + "title": "0.15", + "url": "/api/qiskit/release-notes/0.15" + }, + { + "title": "0.14", + "url": "/api/qiskit/release-notes/0.14" + }, + { + "title": "0.13", + "url": "/api/qiskit/release-notes/0.13" + }, + { + "title": "0.12", + "url": "/api/qiskit/release-notes/0.12" + }, + { + "title": "0.11", + "url": "/api/qiskit/release-notes/0.11" + }, + { + "title": "0.10", + "url": "/api/qiskit/release-notes/0.10" + }, + { + "title": "0.9", + "url": "/api/qiskit/release-notes/0.9" + }, + { + "title": "0.8", + "url": "/api/qiskit/release-notes/0.8" + }, + { + "title": "0.7", + "url": "/api/qiskit/release-notes/0.7" + }, + { + "title": "0.6", + "url": "/api/qiskit/release-notes/0.6" + }, + { + "title": "0.5", + "url": "/api/qiskit/release-notes/0.5" + } + ] + } + ], + "collapsed": true +} + diff --git a/docs/api/qiskit/0.46/algorithms.md b/docs/api/qiskit/0.46/algorithms.md new file mode 100644 index 00000000000..069d9bd0d13 --- /dev/null +++ b/docs/api/qiskit/0.46/algorithms.md @@ -0,0 +1,279 @@ +--- +title: algorithms +description: API reference for qiskit.algorithms +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms +--- + + + + + + + +# Algorithms + + + +`qiskit.algorithms` + + + The [`qiskit.algorithms`](#module-qiskit.algorithms "qiskit.algorithms") module has been migrated to an independent package: [https://github.com/qiskit-community/qiskit-algorithms](https://github.com/qiskit-community/qiskit-algorithms). The current import path is deprecated and will be removed no earlier than 3 months after the release date. If your code uses primitives, you can run `pip install qiskit_algorithms` and import `from qiskit_algorithms` instead. If you use opflow/quantum instance-based algorithms, please update your code to use primitives following: [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) before migrating to the new package. + + +It contains a collection of quantum algorithms, for use with quantum computers, to carry out research and investigate how to solve problems in different domains on near-term quantum devices with short depth circuits. + +Algorithms configuration includes the use of [`optimizers`](qiskit.algorithms.optimizers#module-qiskit.algorithms.optimizers "qiskit.algorithms.optimizers") which were designed to be swappable sub-parts of an algorithm. Any component and may be exchanged for a different implementation of the same component type in order to potentially alter the behavior and outcome of the algorithm. + +Quantum algorithms are run via a `QuantumInstance` which must be set with the desired backend where the algorithm’s circuits will be executed and be configured with a number of compile and runtime parameters controlling circuit compilation and execution. It ultimately uses [Terra](https://www.qiskit.org/terra) for the actual compilation and execution of the quantum circuits created by the algorithm and its components. + +## Algorithms + +It contains a variety of quantum algorithms and these have been grouped by logical function such as minimum eigensolvers and amplitude amplifiers. + +### Amplitude Amplifiers + +| | | +| --------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------ | +| [`AmplificationProblem`](qiskit.algorithms.AmplificationProblem "qiskit.algorithms.AmplificationProblem") | The amplification problem is the input to amplitude amplification algorithms, like Grover. | +| [`AmplitudeAmplifier`](qiskit.algorithms.AmplitudeAmplifier "qiskit.algorithms.AmplitudeAmplifier") | The interface for amplification algorithms. | +| [`Grover`](qiskit.algorithms.Grover "qiskit.algorithms.Grover") | Grover's Search algorithm. | +| [`GroverResult`](qiskit.algorithms.GroverResult "qiskit.algorithms.GroverResult") | Grover Result. | + +### Amplitude Estimators + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------- | +| [`AmplitudeEstimator`](qiskit.algorithms.AmplitudeEstimator "qiskit.algorithms.AmplitudeEstimator") | The Amplitude Estimation interface. | +| [`AmplitudeEstimatorResult`](qiskit.algorithms.AmplitudeEstimatorResult "qiskit.algorithms.AmplitudeEstimatorResult") | The results object for amplitude estimation algorithms. | +| [`AmplitudeEstimation`](qiskit.algorithms.AmplitudeEstimation "qiskit.algorithms.AmplitudeEstimation") | The Quantum Phase Estimation-based Amplitude Estimation algorithm. | +| [`AmplitudeEstimationResult`](qiskit.algorithms.AmplitudeEstimationResult "qiskit.algorithms.AmplitudeEstimationResult") | The `AmplitudeEstimation` result object. | +| [`EstimationProblem`](qiskit.algorithms.EstimationProblem "qiskit.algorithms.EstimationProblem") | The estimation problem is the input to amplitude estimation algorithm. | +| [`FasterAmplitudeEstimation`](qiskit.algorithms.FasterAmplitudeEstimation "qiskit.algorithms.FasterAmplitudeEstimation") | The Faster Amplitude Estimation algorithm. | +| [`FasterAmplitudeEstimationResult`](qiskit.algorithms.FasterAmplitudeEstimationResult "qiskit.algorithms.FasterAmplitudeEstimationResult") | The result object for the Faster Amplitude Estimation algorithm. | +| [`IterativeAmplitudeEstimation`](qiskit.algorithms.IterativeAmplitudeEstimation "qiskit.algorithms.IterativeAmplitudeEstimation") | The Iterative Amplitude Estimation algorithm. | +| [`IterativeAmplitudeEstimationResult`](qiskit.algorithms.IterativeAmplitudeEstimationResult "qiskit.algorithms.IterativeAmplitudeEstimationResult") | The `IterativeAmplitudeEstimation` result object. | +| [`MaximumLikelihoodAmplitudeEstimation`](qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation "qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation") | The Maximum Likelihood Amplitude Estimation algorithm. | +| [`MaximumLikelihoodAmplitudeEstimationResult`](qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult "qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult") | The `MaximumLikelihoodAmplitudeEstimation` result object. | + +### Eigensolvers + +Algorithms to find eigenvalues of an operator. For chemistry these can be used to find excited states of a molecule, and `qiskit-nature` has some algorithms that leverage chemistry specific knowledge to do this in that application domain. + +#### Primitive-based Eigensolvers + +These algorithms are based on the Qiskit Primitives, a new execution paradigm that replaces the use of [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") in algorithms. To ensure continued support and development, we recommend using the primitive-based Eigensolvers in place of the legacy [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance")-based ones. + +| | | +| ----------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------- | +| [`eigensolvers`](qiskit.algorithms.eigensolvers#module-qiskit.algorithms.eigensolvers "qiskit.algorithms.eigensolvers") | Eigensolvers Package (qiskit.algorithms.eigensolvers) | + +#### Legacy Eigensolvers + +These algorithms, still based on the [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance"), are superseded by the primitive-based versions in the section above but are still supported for now. + +| | | +| ------------------------------------------------------------------------------------------------ | ---------------------------------------------------- | +| [`Eigensolver`](qiskit.algorithms.Eigensolver "qiskit.algorithms.Eigensolver") | Deprecated: Eigensolver Interface. | +| [`EigensolverResult`](qiskit.algorithms.EigensolverResult "qiskit.algorithms.EigensolverResult") | Deprecated: Eigensolver Result. | +| [`NumPyEigensolver`](qiskit.algorithms.NumPyEigensolver "qiskit.algorithms.NumPyEigensolver") | Deprecated: NumPy Eigensolver algorithm. | +| [`VQD`](qiskit.algorithms.VQD "qiskit.algorithms.VQD") | Deprecated: Variational Quantum Deflation algorithm. | +| [`VQDResult`](qiskit.algorithms.VQDResult "qiskit.algorithms.VQDResult") | Deprecated: VQD Result. | + +### Time Evolvers + +Algorithms to evolve quantum states in time. Both real and imaginary time evolution is possible with algorithms that support them. For machine learning, Quantum Imaginary Time Evolution might be used to train Quantum Boltzmann Machine Neural Networks for example. + +#### Primitive-based Time Evolvers + +These algorithms are based on the Qiskit Primitives, a new execution paradigm that replaces the use of [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") in algorithms. To ensure continued support and development, we recommend using the primitive-based Time Evolvers in place of the legacy [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance")-based ones. + +| | | +| ------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------- | +| [`RealTimeEvolver`](qiskit.algorithms.RealTimeEvolver "qiskit.algorithms.RealTimeEvolver") | Interface for Quantum Real Time Evolution. | +| [`ImaginaryTimeEvolver`](qiskit.algorithms.ImaginaryTimeEvolver "qiskit.algorithms.ImaginaryTimeEvolver") | Interface for Quantum Imaginary Time Evolution. | +| [`TimeEvolutionResult`](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.TimeEvolutionResult") | Class for holding time evolution result. | +| [`TimeEvolutionProblem`](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.TimeEvolutionProblem") | Time evolution problem class. | +| [`PVQD`](qiskit.algorithms.PVQD "qiskit.algorithms.PVQD") | The projected Variational Quantum Dynamics (p-VQD) Algorithm. | +| [`PVQDResult`](qiskit.algorithms.PVQDResult "qiskit.algorithms.PVQDResult") | The result object for the p-VQD algorithm. | +| [`SciPyImaginaryEvolver`](qiskit.algorithms.SciPyImaginaryEvolver "qiskit.algorithms.SciPyImaginaryEvolver") | Classical Evolver for imaginary time evolution. | +| [`SciPyRealEvolver`](qiskit.algorithms.SciPyRealEvolver "qiskit.algorithms.SciPyRealEvolver") | Classical Evolver for real time evolution. | +| [`VarQITE`](qiskit.algorithms.VarQITE "qiskit.algorithms.VarQITE") | Variational Quantum Imaginary Time Evolution algorithm. | +| [`VarQRTE`](qiskit.algorithms.VarQRTE "qiskit.algorithms.VarQRTE") | Variational Quantum Real Time Evolution algorithm. | + +#### Legacy Time Evolvers + +These algorithms, still based on the [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance"), are superseded by the primitive-based versions in the section above but are still supported for now. + +| | | +| --------------------------------------------------------------------------------------------- | ------------------------------------------------------------- | +| [`RealEvolver`](qiskit.algorithms.RealEvolver "qiskit.algorithms.RealEvolver") | Deprecated: Interface for Quantum Real Time Evolution. | +| [`ImaginaryEvolver`](qiskit.algorithms.ImaginaryEvolver "qiskit.algorithms.ImaginaryEvolver") | Deprecated: Interface for Quantum Imaginary Time Evolution. | +| [`TrotterQRTE`](qiskit.algorithms.TrotterQRTE "qiskit.algorithms.TrotterQRTE") | Deprecated: Quantum Real Time Evolution using Trotterization. | +| [`EvolutionResult`](qiskit.algorithms.EvolutionResult "qiskit.algorithms.EvolutionResult") | Deprecated: Class for holding evolution result. | +| [`EvolutionProblem`](qiskit.algorithms.EvolutionProblem "qiskit.algorithms.EvolutionProblem") | Deprecated: Evolution problem class. | + +#### Variational Quantum Time Evolution + +Classes used by variational quantum time evolution algorithms - [`VarQITE`](qiskit.algorithms.VarQITE "qiskit.algorithms.VarQITE") and [`VarQRTE`](qiskit.algorithms.VarQRTE "qiskit.algorithms.VarQRTE"). + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | +| [`time_evolvers.variational`](qiskit.algorithms.time_evolvers.variational#module-qiskit.algorithms.time_evolvers.variational "qiskit.algorithms.time_evolvers.variational") | Variational Quantum Time Evolutions (qiskit.algorithms.time\_evolvers.variational) | + +#### Trotterization-based Quantum Real Time Evolution + +Package for primitives-enabled Trotterization-based quantum time evolution algorithm - `TrotterQRTE`. + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------- | +| [`time_evolvers.trotterization`](qiskit.algorithms.time_evolvers.trotterization#module-qiskit.algorithms.time_evolvers.trotterization "qiskit.algorithms.time_evolvers.trotterization") | This package contains Trotterization-based Quantum Real Time Evolution algorithm. | + +### Gradients + +Algorithms to calculate the gradient of a quantum circuit. + +| | | +| ----------------------------------------------------------------------------------------------------------- | --------------------------------------- | +| [`gradients`](qiskit.algorithms.gradients#module-qiskit.algorithms.gradients "qiskit.algorithms.gradients") | Gradients (qiskit.algorithms.gradients) | + +### Minimum Eigensolvers + +Algorithms that can find the minimum eigenvalue of an operator. + +#### Primitive-based Minimum Eigensolvers + +These algorithms are based on the Qiskit Primitives, a new execution paradigm that replaces the use of [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") in algorithms. To ensure continued support and development, we recommend using the primitive-based Minimum Eigensolvers in place of the legacy [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance")-based ones. + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------- | +| [`minimum_eigensolvers`](qiskit.algorithms.minimum_eigensolvers#module-qiskit.algorithms.minimum_eigensolvers "qiskit.algorithms.minimum_eigensolvers") | Minimum Eigensolvers Package (qiskit.algorithms.minimum\_eigensolvers) | + +#### Legacy Minimum Eigensolvers + +These algorithms, still based on the [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance"), are superseded by the primitive-based versions in the section above but are still supported for now. + +| | | +| --------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------- | +| [`MinimumEigensolver`](qiskit.algorithms.MinimumEigensolver "qiskit.algorithms.MinimumEigensolver") | Deprecated: Minimum Eigensolver Interface. | +| [`MinimumEigensolverResult`](qiskit.algorithms.MinimumEigensolverResult "qiskit.algorithms.MinimumEigensolverResult") | Deprecated: Minimum Eigensolver Result. | +| [`NumPyMinimumEigensolver`](qiskit.algorithms.NumPyMinimumEigensolver "qiskit.algorithms.NumPyMinimumEigensolver") | Deprecated: Numpy Minimum Eigensolver algorithm. | +| [`QAOA`](qiskit.algorithms.QAOA "qiskit.algorithms.QAOA") | Deprecated: Quantum Approximate Optimization Algorithm. | +| [`VQE`](qiskit.algorithms.VQE "qiskit.algorithms.VQE") | Deprecated: Variational Quantum Eigensolver algorithm. | + +### Optimizers + +Classical optimizers for use by quantum variational algorithms. + +| | | +| --------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`optimizers`](qiskit.algorithms.optimizers#module-qiskit.algorithms.optimizers "qiskit.algorithms.optimizers") | Optimizers (qiskit.algorithms.optimizers) It contains a variety of classical optimizers for use by quantum variational algorithms, such as VQE. Logically, these optimizers can be divided into two categories: | + +### Phase Estimators + +Algorithms that estimate the phases of eigenstates of a unitary. + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`HamiltonianPhaseEstimation`](qiskit.algorithms.HamiltonianPhaseEstimation "qiskit.algorithms.HamiltonianPhaseEstimation") | Run the Quantum Phase Estimation algorithm to find the eigenvalues of a Hermitian operator. | +| [`HamiltonianPhaseEstimationResult`](qiskit.algorithms.HamiltonianPhaseEstimationResult "qiskit.algorithms.HamiltonianPhaseEstimationResult") | Store and manipulate results from running HamiltonianPhaseEstimation. | +| [`PhaseEstimationScale`](qiskit.algorithms.PhaseEstimationScale "qiskit.algorithms.PhaseEstimationScale") | Set and use a bound on eigenvalues of a Hermitian operator in order to ensure phases are in the desired range and to convert measured phases into eigenvectors. | +| [`PhaseEstimation`](qiskit.algorithms.PhaseEstimation "qiskit.algorithms.PhaseEstimation") | Run the Quantum Phase Estimation (QPE) algorithm. | +| [`PhaseEstimationResult`](qiskit.algorithms.PhaseEstimationResult "qiskit.algorithms.PhaseEstimationResult") | Store and manipulate results from running PhaseEstimation. | +| [`IterativePhaseEstimation`](qiskit.algorithms.IterativePhaseEstimation "qiskit.algorithms.IterativePhaseEstimation") | Run the Iterative quantum phase estimation (QPE) algorithm. | + +### State Fidelities + +Algorithms that compute the fidelity of pairs of quantum states. + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------- | +| [`state_fidelities`](qiskit.algorithms.state_fidelities#module-qiskit.algorithms.state_fidelities "qiskit.algorithms.state_fidelities") | State Fidelity Interfaces (qiskit.algorithms.state\_fidelities) | + +### Exceptions + +### AlgorithmError + + + +`qiskit.algorithms.AlgorithmError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/exceptions.py "view source code") + +For Algorithm specific errors. + +Set the error message. + +### Utility classes + +Utility classes used by algorithms (mainly for type-hinting purposes). + +| | | +| --------------------------------------------------------------------------------------------------------------- | --------------------------------------------------- | +| [`AlgorithmJob`](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob")(function, \*args, \*\*kwargs) | This empty class is introduced for typing purposes. | + +### Utility functions + +Utility functions used by algorithms. + +### eval\_observables + + + +`qiskit.algorithms.eval_observables(quantum_instance, quantum_state, observables, expectation, threshold=1e-12)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/aux_ops_evaluator.py "view source code") + +Deprecated: Accepts a list or a dictionary of operators and calculates their expectation values - means and standard deviations. They are calculated with respect to a quantum state provided. A user can optionally provide a threshold value which filters mean values falling below the threshold. + +This function has been superseded by the `qiskit.algorithms.observables_evaluator.eval_observables()` function. It will be deprecated in a future release and subsequently removed after that. + + + The function `qiskit.algorithms.aux_ops_evaluator.eval_observables()` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the function `qiskit.algorithms.observables_evaluator.estimate_observables`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – A quantum instance used for calculations. +* **quantum\_state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – An unparametrized quantum circuit representing a quantum state that expectation values are computed against. +* **observables** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*]*) – A list or a dictionary of operators whose expectation values are to be calculated. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")) – An instance of ExpectationBase which defines a method for calculating expectation values. +* **threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – A threshold value that defines which mean values should be neglected (helpful for ignoring numerical instabilities close to 0). + +**Returns** + +A list or a dictionary of tuples (mean, standard deviation). + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If a `quantum_state` with free parameters is provided. + +**Return type** + +ListOrDict\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"), [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")]] + +### estimate\_observables + + + +`qiskit.algorithms.estimate_observables(estimator, quantum_state, observables, parameter_values=None, threshold=1e-12)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/observables_evaluator.py "view source code") + +Accepts a sequence of operators and calculates their expectation values - means and metadata. They are calculated with respect to a quantum state provided. A user can optionally provide a threshold value which filters mean values falling below the threshold. + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – An estimator primitive used for calculations. +* **quantum\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A (parameterized) quantum circuit preparing a quantum state that expectation values are computed against. +* **observables** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*]*) – A list or a dictionary of operators whose expectation values are to be calculated. +* **parameter\_values** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Optional list of parameters values to evaluate the quantum circuit on. +* **threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – A threshold value that defines which mean values should be neglected (helpful for ignoring numerical instabilities close to 0). + +**Returns** + +A list or a dictionary of tuples (mean, metadata). + +**Raises** + +[**AlgorithmError**](#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If a primitive job is not successful. + +**Return type** + +ListOrDict\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"), [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), Any]]] + diff --git a/docs/api/qiskit/0.46/assembler.md b/docs/api/qiskit/0.46/assembler.md new file mode 100644 index 00000000000..e41da15b1d5 --- /dev/null +++ b/docs/api/qiskit/0.46/assembler.md @@ -0,0 +1,186 @@ +--- +title: assembler +description: API reference for qiskit.assembler +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.assembler +--- + + + + + + + +# Circuit and Schedule Assembler + + + +`qiskit.assembler` + +## Circuit Assembler + +### assemble\_circuits + + + +`qiskit.assembler.assemble_circuits(circuits, run_config, qobj_id, qobj_header)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/assembler/assemble_circuits.py "view source code") + +Assembles a list of circuits into a qobj that can be run on the backend. + +**Parameters** + +* **circuits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*]*) – circuit(s) to assemble +* **run\_config** ([*RunConfig*](qiskit.assembler.RunConfig "qiskit.assembler.run_config.RunConfig")) – configuration of the runtime environment +* **qobj\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – identifier for the generated qobj +* **qobj\_header** ([*QobjHeader*](qiskit.qobj.QobjHeader "qiskit.qobj.common.QobjHeader")) – header to pass to the results + +**Returns** + +The qobj to be run on the backends + +**Return type** + +[*QasmQobj*](qiskit.qobj.QasmQobj "qiskit.qobj.qasm_qobj.QasmQobj") + +**Examples** + +```python +from qiskit.circuit import QuantumRegister, ClassicalRegister, QuantumCircuit +from qiskit.assembler import assemble_circuits +from qiskit.assembler.run_config import RunConfig +# Build a circuit to convert into a Qobj +q = QuantumRegister(2) +c = ClassicalRegister(2) +qc = QuantumCircuit(q, c) +qc.h(q[0]) +qc.cx(q[0], q[1]) +qc.measure(q, c) +# Assemble a Qobj from the input circuit +qobj = assemble_circuits(circuits=[qc], + qobj_id="custom-id", + qobj_header=[], + run_config=RunConfig(shots=2000, memory=True, init_qubits=True)) +``` + +## Schedule Assembler + +### assemble\_schedules + + + +`qiskit.assembler.assemble_schedules(schedules, qobj_id, qobj_header, run_config)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/assembler/assemble_schedules.py "view source code") + +Assembles a list of schedules into a qobj that can be run on the backend. + +**Parameters** + +* **schedules** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *|*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") *|*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")*]]*) – Schedules to assemble. +* **qobj\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Identifier for the generated qobj. +* **qobj\_header** ([*QobjHeader*](qiskit.qobj.QobjHeader "qiskit.qobj.common.QobjHeader")) – Header to pass to the results. +* **run\_config** ([*RunConfig*](qiskit.assembler.RunConfig "qiskit.assembler.run_config.RunConfig")) – Configuration of the runtime environment. + +**Returns** + +The Qobj to be run on the backends. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – when frequency settings are not supplied. + +**Return type** + +[*PulseQobj*](qiskit.qobj.PulseQobj "qiskit.qobj.pulse_qobj.PulseQobj") + +**Examples** + +```python +from qiskit import pulse +from qiskit.assembler import assemble_schedules +from qiskit.assembler.run_config import RunConfig +# Construct a Qobj header for the output Qobj +header = {"backend_name": "FakeOpenPulse2Q", "backend_version": "0.0.0"} +# Build a configuration object for the output Qobj +config = RunConfig(shots=1024, + memory=False, + meas_level=1, + meas_return='avg', + memory_slot_size=100, + parametric_pulses=[], + init_qubits=True, + qubit_lo_freq=[4900000000.0, 5000000000.0], + meas_lo_freq=[6500000000.0, 6600000000.0], + schedule_los=[]) +# Build a Pulse schedule to assemble into a Qobj +schedule = pulse.Schedule() +schedule += pulse.Play(pulse.Waveform([0.1] * 16, name="test0"), + pulse.DriveChannel(0), + name="test1") +schedule += pulse.Play(pulse.Waveform([0.1] * 16, name="test1"), + pulse.DriveChannel(0), + name="test2") +schedule += pulse.Play(pulse.Waveform([0.5] * 16, name="test0"), + pulse.DriveChannel(0), + name="test1") +# Assemble a Qobj from the schedule. +pulseQobj = assemble_schedules(schedules=[schedule], + qobj_id="custom-id", + qobj_header=header, + run_config=config) +``` + +## Disassembler + +### disassemble + + + +`qiskit.assembler.disassemble(qobj)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/assembler/disassemble.py "view source code") + +Disassemble a qobj and return the circuits or pulse schedules, run\_config, and user header. + + + `disassemble(assemble(qc))` is not guaranteed to produce an exactly equal circuit to the input, due to limitations in the [`QasmQobj`](qiskit.qobj.QasmQobj "qiskit.qobj.QasmQobj") format that need to be maintained for backend system compatibility. This is most likely to be the case when using newer features of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). In most cases, the output should be equivalent, if not quite equal. + + +**Parameters** + +**qobj** (*Qobj*) – The input qobj object to disassemble + +**Returns** + +The disassembled program which consists of: + +> * programs: A list of quantum circuits or pulse schedules +> * run\_config: The dict of the run config +> * user\_qobj\_header: The dict of any user headers in the qobj + +**Return type** + +Union\[CircuitModule, PulseModule] + +**Examples** + +```python +from qiskit.circuit import QuantumRegister, ClassicalRegister, QuantumCircuit +from qiskit.compiler.assembler import assemble +from qiskit.assembler.disassemble import disassemble +# Create a circuit to assemble into a qobj +q = QuantumRegister(2) +c = ClassicalRegister(2) +qc = QuantumCircuit(q, c) +qc.h(q[0]) +qc.cx(q[0], q[1]) +qc.measure(q, c) +# Assemble the circuit into a Qobj +qobj = assemble(qc, shots=2000, memory=True) +# Disassemble the qobj back into a circuit +circuits, run_config_out, headers = disassemble(qobj) +``` + +## RunConfig + +| | | +| -------------------------------------------------------------------------------------------------------------- | ---------------------------- | +| [`RunConfig`](qiskit.assembler.RunConfig "qiskit.assembler.RunConfig")(\[shots, seed\_simulator, memory, ...]) | Class for Run Configuration. | + diff --git a/docs/api/qiskit/0.46/circuit.md b/docs/api/qiskit/0.46/circuit.md new file mode 100644 index 00000000000..0f3a54be0dd --- /dev/null +++ b/docs/api/qiskit/0.46/circuit.md @@ -0,0 +1,357 @@ +--- +title: circuit +description: API reference for qiskit.circuit +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.circuit +--- + + + + + + + +# Quantum Circuits + + + +`qiskit.circuit` + +## Overview + +The fundamental element of quantum computing is the **quantum circuit**. A quantum circuit is a computational routine consisting of coherent quantum operations on quantum data, such as qubits. It is an ordered sequence of quantum gates, measurements and resets, which may be conditioned on real-time classical computation. A set of quantum gates is said to be universal if any unitary transformation of the quantum data can be efficiently approximated arbitrarily well as a sequence of gates in the set. Any quantum program can be represented by a sequence of quantum circuits and classical near-time computation. + +In Qiskit, this core element is represented by the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class. Below is an example of a quantum circuit that makes a three-qubit GHZ state defined as: + +$$ +|\psi\rangle = \left(|000\rangle+|111\rangle\right)/\sqrt{2} +$$ + +```python +from qiskit import QuantumCircuit +# Create a circuit with a register of three qubits +circ = QuantumCircuit(3) +# H gate on qubit 0, putting this qubit in a superposition of |0> + |1>. +circ.h(0) +# A CX (CNOT) gate on control qubit 0 and target qubit 1 generating a Bell state. +circ.cx(0, 1) +# CX (CNOT) gate on control qubit 0 and target qubit 2 resulting in a GHZ state. +circ.cx(0, 2) +# Draw the circuit +circ.draw('mpl') +``` + +![../\_images/circuit-1.png](/images/api/qiskit/0.46/circuit-1.png) + +## Supplementary Information + +### Quantum Circuit with conditionals + +When building a quantum circuit, there can be interest in applying a certain gate only if a classical register has a specific value. This can be done with the [`InstructionSet.c_if()`](qiskit.circuit.InstructionSet#c_if "qiskit.circuit.InstructionSet.c_if") method. + +In the following example, we start with a single-qubit circuit formed by only a Hadamard gate ([`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate")), in which we expect to get $|0\rangle$ and $|1\rangle$ with equal probability. + +```python +from qiskit import transpile, QuantumRegister, ClassicalRegister, QuantumCircuit +qr = QuantumRegister(1) +cr = ClassicalRegister(1) +qc = QuantumCircuit(qr, cr) +qc.h(0) +qc.measure(0, 0) +qc.draw('mpl') +``` + +![../\_images/circuit-2.png](/images/api/qiskit/0.46/circuit-2.png) + +```python +from qiskit.providers.basic_provider import BasicSimulator +backend = BasicSimulator() +tqc = transpile(qc, backend) +counts = backend.run(tqc).result().get_counts() + +print(counts) +``` + +```python +{'0': 524, '1': 500} +``` + +Now, we add an [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") only if the value of the [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") is 0. That way, if the state is $|0\rangle$, it will be changed to $|1\rangle$ and if the state is $|1\rangle$, it will not be changed at all, so the final state will always be $|1\rangle$. + +```python +from qiskit import transpile, QuantumRegister, ClassicalRegister, QuantumCircuit + +qr = QuantumRegister(1) +cr = ClassicalRegister(1) +qc = QuantumCircuit(qr, cr) +qc.h(0) +qc.measure(0, 0) + +qc.x(0).c_if(cr, 0) +qc.measure(0, 0) + +qc.draw('mpl') +``` + +![../\_images/circuit-3.png](/images/api/qiskit/0.46/circuit-3.png) + +```python +from qiskit.providers.basic_provider import BasicSimulator +backend = BasicSimulator() +tqc = transpile(qc, backend) +counts = backend.run(tqc).result().get_counts() + +print(counts) +``` + +```python +{'1': 1024} +``` + +### Quantum Circuit Properties + +When constructing quantum circuits, there are several properties that help quantify the “size” of the circuits, and their ability to be run on a noisy quantum device. Some of these, like number of qubits, are straightforward to understand, while others like depth and number of tensor components require a bit more explanation. Here we will explain all of these properties, and, in preparation for understanding how circuits change when run on actual devices, highlight the conditions under which they change. + +Consider the following circuit: + +```python +from qiskit import QuantumCircuit +qc = QuantumCircuit(12) +for idx in range(5): + qc.h(idx) + qc.cx(idx, idx+5) + +qc.cx(1, 7) +qc.x(8) +qc.cx(1, 9) +qc.x(7) +qc.cx(1, 11) +qc.swap(6, 11) +qc.swap(6, 9) +qc.swap(6, 10) +qc.x(6) +qc.draw('mpl') +``` + +![../\_images/circuit-4.png](/images/api/qiskit/0.46/circuit-4.png) + +From the plot, it is easy to see that this circuit has 12 qubits, and a collection of Hadamard, CNOT, X, and SWAP gates. But how to quantify this programmatically? Because we can do single-qubit gates on all the qubits simultaneously, the number of qubits in this circuit is equal to the **width** of the circuit: + +```python +qc.width() +``` + +```python +12 +``` + +We can also just get the number of qubits directly: + +```python +qc.num_qubits +``` + +```python +12 +``` + + + For a quantum circuit composed from just qubits, the circuit width is equal to the number of qubits. This is the definition used in quantum computing. However, for more complicated circuits with classical registers, and classically controlled gates, this equivalence breaks down. As such, from now on we will not refer to the number of qubits in a quantum circuit as the width. + + +It is also straightforward to get the number and type of the gates in a circuit using [`QuantumCircuit.count_ops()`](qiskit.circuit.QuantumCircuit#count_ops "qiskit.circuit.QuantumCircuit.count_ops"): + +```python +qc.count_ops() +``` + +```python +OrderedDict([('cx', 8), ('h', 5), ('x', 3), ('swap', 3)]) +``` + +We can also get just the raw count of operations by computing the circuits [`QuantumCircuit.size()`](qiskit.circuit.QuantumCircuit#size "qiskit.circuit.QuantumCircuit.size"): + +```python +qc.size() +``` + +```python +19 +``` + +A particularly important circuit property is known as the circuit **depth**. The depth of a quantum circuit is a measure of how many “layers” of quantum gates, executed in parallel, it takes to complete the computation defined by the circuit. Because quantum gates take time to implement, the depth of a circuit roughly corresponds to the amount of time it takes the quantum computer to execute the circuit. Thus, the depth of a circuit is one important quantity used to measure if a quantum circuit can be run on a device. + +The depth of a quantum circuit has a mathematical definition as the longest path in a directed acyclic graph (DAG). However, such a definition is a bit hard to grasp, even for experts. Fortunately, the depth of a circuit can be easily understood by anyone familiar with playing [Tetris](https://en.wikipedia.org/wiki/Tetris). Lets see how to compute this graphically: + +![../\_images/depth.gif](/images/api/qiskit/0.46/depth.gif) + +We can verify our graphical result using [`QuantumCircuit.depth()`](qiskit.circuit.QuantumCircuit#depth "qiskit.circuit.QuantumCircuit.depth"): + +```python +qc.depth() +``` + +```python +9 +``` + +## Quantum Circuit API + +### Quantum Circuit Construction + +| | | +| --------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")(\*regs\[, name, global\_phase, ...]) | Create a new circuit. | +| [`QuantumRegister`](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")(\[size, name, bits]) | Implement a quantum register. | +| [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit")(\[register, index]) | Implement a quantum bit. | +| [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")(\[size, name, bits]) | Implement a classical register. | +| [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit")(\[register, index]) | Implement a classical bit. | +| [`AncillaRegister`](qiskit.circuit.AncillaRegister "qiskit.circuit.AncillaRegister")(\[size, name, bits]) | Implement an ancilla register. | +| [`AncillaQubit`](qiskit.circuit.AncillaQubit "qiskit.circuit.AncillaQubit")(\[register, index]) | A qubit used as ancillary qubit. | +| [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")(operation\[, qubits, clbits]) | A single instruction in a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), comprised of the `operation` and various operands. | +| [`Register`](qiskit.circuit.Register "qiskit.circuit.Register")(\[size, name, bits]) | Implement a generic register. | +| [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit")(\[register, index]) | Implement a generic bit. | + +### Gates and Instructions + +| | | +| -------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------ | +| [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate")(name, num\_qubits, params\[, label, ...]) | Unitary gate. | +| [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate")(name, num\_qubits, params\[, ...]) | Controlled unitary gate. | +| [`Delay`](qiskit.circuit.Delay "qiskit.circuit.Delay")(duration\[, unit]) | Do nothing and just delay/wait/idle for a specified duration. | +| [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")(name, num\_qubits, num\_clbits, params) | Generic quantum instruction. | +| [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet")(\*\[, resource\_requester]) | Instruction collection, and their contexts. | +| [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation")() | Quantum Operation Interface Class. | +| [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary")(\*\[, base]) | A library providing a one-way mapping of Gates to their equivalent implementations as QuantumCircuits. | + +### Control Flow Operations + +| | | +| --------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp")(name, num\_qubits, num\_clbits, ...) | Abstract class to encapsulate all control flow operations. | +| [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp")(condition, true\_body\[, false\_body, ...]) | A circuit operation which executes a program (`true_body`) if a provided condition (`condition`) evaluates to true, and optionally evaluates another program (`false_body`) otherwise. | +| [`WhileLoopOp`](qiskit.circuit.WhileLoopOp "qiskit.circuit.WhileLoopOp")(condition, body\[, label]) | A circuit operation which repeatedly executes a subcircuit (`body`) until a condition (`condition`) evaluates as False. | +| [`ForLoopOp`](qiskit.circuit.ForLoopOp "qiskit.circuit.ForLoopOp")(indexset, loop\_parameter, body\[, ...]) | A circuit operation which repeatedly executes a subcircuit (`body`) parameterized by a parameter `loop_parameter` through the set of integer values provided in `indexset`. | +| [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp")(target, cases, \*\[, label]) | A circuit operation that executes one particular circuit block based on matching a given `target` against an ordered list of `values`. | +| [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp")(num\_qubits, num\_clbits\[, label]) | A circuit operation which, when encountered, jumps to the end of the nearest enclosing loop. | +| [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp")(num\_qubits, num\_clbits\[, label]) | A circuit operation which, when encountered, moves to the next iteration of the nearest enclosing loop. | + +The [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") also understands a special value: + +**qiskit.circuit.CASE\_DEFAULT** + +A special object that represents the “default” case of a switch statement. If you use this as a case target, it must be the last case, and will match anything that wasn’t already matched. For example: + +```python +from qiskit import QuantumCircuit, QuantumRegister, ClassicalRegister +from qiskit.circuit import SwitchCaseOp, CASE_DEFAULT + +body0 = QuantumCircuit(2, 2) +body0.x(0) +body1 = QuantumCircuit(2, 2) +body1.z(0) +body2 = QuantumCircuit(2, 2) +body2.cx(0, 1) + +qr, cr = QuantumRegister(2), ClassicalRegister(2) +qc = QuantumCircuit(qr, cr) +qc.switch(cr, [(0, body0), (1, body1), (CASE_DEFAULT, body2)], qr, cr) +``` + +When using the builder interface of [`QuantumCircuit.switch()`](qiskit.circuit.QuantumCircuit#switch "qiskit.circuit.QuantumCircuit.switch"), this can also be accessed as the `DEFAULT` attribute of the bound case-builder object, such as: + +```python +from qiskit import QuantumCircuit, QuantumRegister, ClassicalRegister + +qr, cr = QuantumRegister(2), ClassicalRegister(2) +qc = QuantumCircuit(qr, cr) +with qc.switch(cr) as case: + with case(0): + qc.x(0) + with case(1): + qc.z(0) + with case(case.DEFAULT): + qc.cx(0, 1) +``` + +### Parametric Quantum Circuits + +| | | +| ------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------- | +| [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")(name, \*\[, uuid]) | Parameter Class for variable parameters. | +| [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector")(name\[, length]) | ParameterVector class to quickly generate lists of parameters. | +| [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")(symbol\_map, expr) | ParameterExpression class to enable creating expressions of Parameters. | + +### Random Circuits + +### random\_circuit + + + +`qiskit.circuit.random.random_circuit(num_qubits, depth, max_operands=4, measure=False, conditional=False, reset=False, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/random/utils.py "view source code") + +Generate random circuit of arbitrary size and form. + +This function will generate a random circuit by randomly selecting gates from the set of standard gates in `qiskit.circuit.library.standard_gates`. For example: + +```python +from qiskit.circuit.random import random_circuit + +circ = random_circuit(2, 2, measure=True) +circ.draw(output='mpl') +``` + +![../\_images/circuit-5.png](/images/api/qiskit/0.46/circuit-5.png) + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of quantum wires +* **depth** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – layers of operations (i.e. critical path length) +* **max\_operands** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – maximum qubit operands of each gate (between 1 and 4) +* **measure** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, measure all qubits at the end +* **conditional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, insert middle measurements and conditionals +* **reset** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, insert middle resets +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – sets random seed (optional) + +**Returns** + +constructed circuit + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**CircuitError**](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when invalid options given + +### Circuit Analysis + +| | | +| ----------------------------------------------------------------------------------------------- | ------------------------------------------------------------------- | +| [`CommutationChecker`](qiskit.circuit.CommutationChecker "qiskit.circuit.CommutationChecker")() | This code is essentially copy-pasted from commutative\_analysis.py. | + +### Annotated Operations + +| | | +| ----------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------- | +| [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")(base\_op, modifiers) | Annotated operation. | +| [`ControlModifier`](qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier")(\[num\_ctrl\_qubits, ctrl\_state]) | Control modifier: specifies that the operation is controlled by `num_ctrl_qubits` and has control state `ctrl_state`. | +| [`PowerModifier`](qiskit.circuit.PowerModifier "qiskit.circuit.PowerModifier")(power) | Power modifier: specifies that the operation is raised to the power `power`. | +| [`InverseModifier`](qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier")() | Inverse modifier: specifies that the operation is inverted. | + +### Exceptions + +Almost all circuit functions and methods will raise a [`CircuitError`](#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") when encountering an error that is particular to usage of Qiskit (as opposed to regular typing or indexing problems, which will typically raise the corresponding standard Python error). + +### CircuitError + + + +`qiskit.circuit.CircuitError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/exceptions.py "view source code") + +Base class for errors raised while processing a circuit. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/circuit_classical.md b/docs/api/qiskit/0.46/circuit_classical.md new file mode 100644 index 00000000000..844cf16d370 --- /dev/null +++ b/docs/api/qiskit/0.46/circuit_classical.md @@ -0,0 +1,974 @@ +--- +title: classical +description: API reference for qiskit.circuit.classical +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.circuit.classical +--- + + + + + + + +# Classical expressions + + + +`qiskit.circuit.classical` + +This module contains an exploratory representation of runtime operations on classical values during circuit execution. + +Currently, only simple expressions on bits and registers that result in a Boolean value are supported, and these are only valid for use in the conditions of [`QuantumCircuit.if_test()`](qiskit.circuit.QuantumCircuit#if_test "qiskit.circuit.QuantumCircuit.if_test") ([`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp")) and [`QuantumCircuit.while_loop()`](qiskit.circuit.QuantumCircuit#while_loop "qiskit.circuit.QuantumCircuit.while_loop") ([`WhileLoopOp`](qiskit.circuit.WhileLoopOp "qiskit.circuit.WhileLoopOp")), and in the target of [`QuantumCircuit.switch()`](qiskit.circuit.QuantumCircuit#switch "qiskit.circuit.QuantumCircuit.switch") ([`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp")). + + + This is an exploratory module, and while we will commit to the standard Qiskit deprecation policy within it, please be aware that the module will be deliberately limited in scope at the start, and early versions may not evolve cleanly into the final version. It is possible that various components of this module will be replaced (subject to deprecations) instead of improved into a new form. + + The type system and expression tree will be expanded over time, and it is possible that the allowed types of some operations may need to change between versions of Qiskit as the classical processing capabilities develop. + + + + + + +## Expressions + + + +`qiskit.circuit.classical.expr` + +The necessary components for building expressions are all exported from the [`expr`](#module-qiskit.circuit.classical.expr "qiskit.circuit.classical.expr") namespace within [`qiskit.circuit.classical`](#module-qiskit.circuit.classical "qiskit.circuit.classical"), so you can choose whether to use qualified access (for example [`expr.Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.expr.Value")) or import the names you need directly and call them without the prefix. + +There are two pathways for constructing expressions. The classes that form [the representation of the expression system](#circuit-classical-expressions-expr-representation) have constructors that perform zero type checking; it is up to the caller to ensure that they are building valid objects. For a more user-friendly interface to direct construction, there are helper functions associated with most of the classes that do type validation and inference. These are described below, in [Construction](#circuit-classical-expressions-expr-construction). + + + +### Representation + +The expression system is based on tree representation. All nodes in the tree are final (uninheritable) instances of the abstract base class: + + + +`qiskit.circuit.classical.expr.Expr`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/expr.py "view source code") + +Root base class of all nodes in the expression tree. The base case should never be instantiated directly. + +This must not be subclassed by users; subclasses form the internal data of the representation of expressions, and it does not make sense to add more outside of Qiskit library code. + +All subclasses are responsible for setting their `type` attribute in their `__init__`, and should not call the parent initialiser. + +These objects are mutable and should not be reused in a different location without a copy. + +The entry point from general circuit objects to the expression system is by wrapping the object in a [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node and associating a [`Type`](#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type") with it. + + + +`final class qiskit.circuit.classical.expr.Var(var, type)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/expr.py "view source code") + +A classical variable. + +Similarly, literals used in comparison (such as integers) should be lifted to [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes with associated types. + + + +`final class qiskit.circuit.classical.expr.Value(value, type)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/expr.py "view source code") + +A single scalar value. + +The operations traditionally associated with pre-, post- or infix operators in programming are represented by the [`Unary`](#qiskit.circuit.classical.expr.Unary "qiskit.circuit.classical.expr.Unary") and [`Binary`](#qiskit.circuit.classical.expr.Binary "qiskit.circuit.classical.expr.Binary") nodes as appropriate. These each take an operation type code, which are exposed as enumerations inside each class as [`Unary.Op`](#qiskit.circuit.classical.expr.Unary.Op "qiskit.circuit.classical.expr.Unary.Op") and [`Binary.Op`](#qiskit.circuit.classical.expr.Binary.Op "qiskit.circuit.classical.expr.Binary.Op") respectively. + + + +`final class qiskit.circuit.classical.expr.Unary(op, operand, type)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/expr.py "view source code") + +A unary expression. + +**Parameters** + +* **op** ([*Unary.Op*](#qiskit.circuit.classical.expr.Unary.Op "qiskit.circuit.classical.expr.Unary.Op")) – The opcode describing which operation is being done. +* **operand** ([*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – The operand of the operation. +* **type** ([*Type*](#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.types.Type")) – The resolved type of the result. + + + +`Op(value)` + +Enumeration of the opcodes for unary operations. + +The bitwise negation [`BIT_NOT`](#qiskit.circuit.classical.expr.Unary.Op.BIT_NOT "qiskit.circuit.classical.expr.Unary.Op.BIT_NOT") takes a single bit or an unsigned integer of known width, and returns a value of the same type. + +The logical negation [`LOGIC_NOT`](#qiskit.circuit.classical.expr.Unary.Op.LOGIC_NOT "qiskit.circuit.classical.expr.Unary.Op.LOGIC_NOT") takes an input that is implicitly coerced to a Boolean, and returns a Boolean. + + + +### BIT\_NOT + +`= 1` + +Bitwise negation. `~operand`. + + + +### LOGIC\_NOT + +`= 2` + +Logical negation. `!operand`. + + + +`final class qiskit.circuit.classical.expr.Binary(op, left, right, type)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/expr.py "view source code") + +A binary expression. + +**Parameters** + +* **op** ([*Binary.Op*](#qiskit.circuit.classical.expr.Binary.Op "qiskit.circuit.classical.expr.Binary.Op")) – The opcode describing which operation is being done. +* **left** ([*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – The left-hand operand. +* **right** ([*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – The right-hand operand. +* **type** ([*Type*](#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.types.Type")) – The resolved type of the result. + + + +`Op(value)` + +Enumeration of the opcodes for binary operations. + +The bitwise operations [`BIT_AND`](#qiskit.circuit.classical.expr.Binary.Op.BIT_AND "qiskit.circuit.classical.expr.Binary.Op.BIT_AND"), [`BIT_OR`](#qiskit.circuit.classical.expr.Binary.Op.BIT_OR "qiskit.circuit.classical.expr.Binary.Op.BIT_OR") and [`BIT_XOR`](#qiskit.circuit.classical.expr.Binary.Op.BIT_XOR "qiskit.circuit.classical.expr.Binary.Op.BIT_XOR") apply to two operands of the same type, which must be a single bit or an unsigned integer of fixed width. The resultant type is the same as the two input types. + +The logical operations [`LOGIC_AND`](#qiskit.circuit.classical.expr.Binary.Op.LOGIC_AND "qiskit.circuit.classical.expr.Binary.Op.LOGIC_AND") and [`LOGIC_OR`](#qiskit.circuit.classical.expr.Binary.Op.LOGIC_OR "qiskit.circuit.classical.expr.Binary.Op.LOGIC_OR") first implicitly coerce their arguments to Booleans, and then apply the logical operation. The resultant type is always Boolean. + +The binary mathematical relations [`EQUAL`](#qiskit.circuit.classical.expr.Binary.Op.EQUAL "qiskit.circuit.classical.expr.Binary.Op.EQUAL"), [`NOT_EQUAL`](#qiskit.circuit.classical.expr.Binary.Op.NOT_EQUAL "qiskit.circuit.classical.expr.Binary.Op.NOT_EQUAL"), [`LESS`](#qiskit.circuit.classical.expr.Binary.Op.LESS "qiskit.circuit.classical.expr.Binary.Op.LESS"), [`LESS_EQUAL`](#qiskit.circuit.classical.expr.Binary.Op.LESS_EQUAL "qiskit.circuit.classical.expr.Binary.Op.LESS_EQUAL"), [`GREATER`](#qiskit.circuit.classical.expr.Binary.Op.GREATER "qiskit.circuit.classical.expr.Binary.Op.GREATER") and [`GREATER_EQUAL`](#qiskit.circuit.classical.expr.Binary.Op.GREATER_EQUAL "qiskit.circuit.classical.expr.Binary.Op.GREATER_EQUAL") take unsigned integers (with an implicit cast to make them the same width), and return a Boolean. + + + +### BIT\_AND + +`= 1` + +Bitwise “and”. `lhs & rhs`. + + + +### BIT\_OR + +`= 2` + +Bitwise “or”. `lhs | rhs`. + + + +### BIT\_XOR + +`= 3` + +Bitwise “exclusive or”. `lhs ^ rhs`. + + + +### LOGIC\_AND + +`= 4` + +Logical “and”. `lhs && rhs`. + + + +### LOGIC\_OR + +`= 5` + +Logical “or”. `lhs || rhs`. + + + +### EQUAL + +`= 6` + +Numeric equality. `lhs == rhs`. + + + +### NOT\_EQUAL + +`= 7` + +Numeric inequality. `lhs != rhs`. + + + +### LESS + +`= 8` + +Numeric less than. `lhs < rhs`. + + + +### LESS\_EQUAL + +`= 9` + +Numeric less than or equal to. `lhs <= rhs` + + + +### GREATER + +`= 10` + +Numeric greater than. `lhs > rhs`. + + + +### GREATER\_EQUAL + +`= 11` + +Numeric greater than or equal to. `lhs >= rhs`. + +When constructing expressions, one must ensure that the types are valid for the operation. Attempts to construct expressions with invalid types will raise a regular Python `TypeError`. + +Expressions in this system are defined to act only on certain sets of types. However, values may be cast to a suitable supertype in order to satisfy the typing requirements. In these cases, a node in the expression tree is used to represent the promotion. In all cases where operations note that they “implicitly cast” or “coerce” their arguments, the expression tree must have this node representing the conversion. + + + +`final class qiskit.circuit.classical.expr.Cast(operand, type, implicit=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/expr.py "view source code") + +A cast from one type to another, implied by the use of an expression in a different context. + + + +### Construction + +Constructing the tree representation directly is verbose and easy to make a mistake with the typing. In many cases, much of the typing can be inferred, scalar values can automatically be promoted to [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") instances, and any required promotions can be resolved into suitable [`Cast`](#qiskit.circuit.classical.expr.Cast "qiskit.circuit.classical.expr.Cast") nodes. + +The functions and methods described in this section are a more user-friendly way to build the expression tree, while staying close to the internal representation. All these functions will automatically lift valid Python scalar values into corresponding [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") or [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") objects, and will resolve any required implicit casts on your behalf. + +### lift + + + +`qiskit.circuit.classical.expr.lift(value, /, type=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Lift the given Python `value` to a [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.expr.Value") or [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var"). + +If an explicit `type` is given, the typing in the output will reflect that. + +**Examples** + +Lifting simple circuit objects to be [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var") instances: + +```python +>>> from qiskit.circuit import Clbit, ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.lift(Clbit()) +Var(, Bool()) +>>> expr.lift(ClassicalRegister(3, "c")) +Var(ClassicalRegister(3, "c"), Uint(3)) +``` + +The type of the return value can be influenced, if the given value could be interpreted losslessly as the given type (use [`cast()`](#qiskit.circuit.classical.expr.cast "qiskit.circuit.classical.expr.cast") to perform a full set of casting operations, include lossy ones): + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr, types +>>> expr.lift(ClassicalRegister(3, "c"), types.Uint(5)) +Var(ClassicalRegister(3, "c"), Uint(5)) +>>> expr.lift(5, types.Uint(4)) +Value(5, Uint(4)) +``` + +**Return type** + +[Expr](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") + +You can manually specify casts in cases where the cast is allowed in explicit form, but may be lossy (such as the cast of a higher precision [`Uint`](#qiskit.circuit.classical.types.Uint "qiskit.circuit.classical.types.Uint") to a lower precision one). + +### cast + + + +`qiskit.circuit.classical.expr.cast(operand, type, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create an explicit cast from the given value to the given type. + +**Examples** + +Add an explicit cast node that explicitly casts a higher precision type to a lower precision one: + +```python +>>> from qiskit.circuit.classical import expr, types +>>> value = expr.value(5, types.Uint(32)) +>>> expr.cast(value, types.Uint(8)) +Cast(Value(5, types.Uint(32)), types.Uint(8), implicit=False) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +There are helper constructor functions for each of the unary operations. + +### bit\_not + + + +`qiskit.circuit.classical.expr.bit_not(operand, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a bitwise ‘not’ expression node from the given value, resolving any implicit casts and lifting the value into a [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") node if required. + +**Examples** + +Bitwise negation of a [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"): + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.bit_not(ClassicalRegister(3, "c")) +Unary(Unary.Op.BIT_NOT, Var(ClassicalRegister(3, 'c'), Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### logic\_not + + + +`qiskit.circuit.classical.expr.logic_not(operand, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a logical ‘not’ expression node from the given value, resolving any implicit casts and lifting the value into a [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") node if required. + +**Examples** + +Logical negation of a [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"): + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.logic_not(ClassicalRegister(3, "c")) +Unary(Unary.Op.LOGIC_NOT, Cast(Var(ClassicalRegister(3, 'c'), Uint(3)), Bool(), implicit=True), Bool()) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +Similarly, the binary operations and relations have helper functions defined. + +### bit\_and + + + +`qiskit.circuit.classical.expr.bit_and(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a bitwise ‘and’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Bitwise ‘and’ of a classical register and an integer literal: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.bit_and(ClassicalRegister(3, "c"), 0b111) +Binary(Binary.Op.BIT_AND, Var(ClassicalRegister(3, 'c'), Uint(3)), Value(7, Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### bit\_or + + + +`qiskit.circuit.classical.expr.bit_or(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a bitwise ‘or’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Bitwise ‘or’ of a classical register and an integer literal: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.bit_or(ClassicalRegister(3, "c"), 0b101) +Binary(Binary.Op.BIT_OR, Var(ClassicalRegister(3, 'c'), Uint(3)), Value(5, Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### bit\_xor + + + +`qiskit.circuit.classical.expr.bit_xor(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a bitwise ‘exclusive or’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Bitwise ‘exclusive or’ of a classical register and an integer literal: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.bit_xor(ClassicalRegister(3, "c"), 0b101) +Binary(Binary.Op.BIT_XOR, Var(ClassicalRegister(3, 'c'), Uint(3)), Value(5, Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### logic\_and + + + +`qiskit.circuit.classical.expr.logic_and(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a logical ‘and’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Logical ‘and’ of two classical bits: + +```python +>>> from qiskit.circuit import Clbit +>>> from qiskit.circuit.classical import expr +>>> expr.logical_and(Clbit(), Clbit()) +Binary(Binary.Op.LOGIC_AND, Var(, Bool()), Var(, Bool()), Bool()) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### logic\_or + + + +`qiskit.circuit.classical.expr.logic_or(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a logical ‘or’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Logical ‘or’ of two classical bits + +```python +>>> from qiskit.circuit import Clbit +>>> from qiskit.circuit.classical import expr +>>> expr.logical_and(Clbit(), Clbit()) +Binary(Binary.Op.LOGIC_OR, Var(, Bool()), Var(, Bool()), Bool()) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### equal + + + +`qiskit.circuit.classical.expr.equal(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create an ‘equal’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Equality between a classical register and an integer: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.equal(ClassicalRegister(3, "c"), 7) +Binary(Binary.Op.EQUAL, Var(ClassicalRegister(3, "c"), Uint(3)), Value(7, Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### not\_equal + + + +`qiskit.circuit.classical.expr.not_equal(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a ‘not equal’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Inequality between a classical register and an integer: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.not_equal(ClassicalRegister(3, "c"), 7) +Binary(Binary.Op.NOT_EQUAL, Var(ClassicalRegister(3, "c"), Uint(3)), Value(7, Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### less + + + +`qiskit.circuit.classical.expr.less(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a ‘less than’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Query if a classical register is less than an integer: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.less(ClassicalRegister(3, "c"), 5) +Binary(Binary.Op.LESS, Var(ClassicalRegister(3, "c"), Uint(3)), Value(5, Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### less\_equal + + + +`qiskit.circuit.classical.expr.less_equal(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a ‘less than or equal to’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Query if a classical register is less than or equal to another: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.less(ClassicalRegister(3, "a"), ClassicalRegister(3, "b")) +Binary(Binary.Op.LESS_EQUAL, Var(ClassicalRegister(3, "a"), Uint(3)), Var(ClassicalRegister(3, "b"), Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### greater + + + +`qiskit.circuit.classical.expr.greater(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a ‘greater than’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Query if a classical register is greater than an integer: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.less(ClassicalRegister(3, "c"), 5) +Binary(Binary.Op.GREATER, Var(ClassicalRegister(3, "c"), Uint(3)), Value(5, Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +### greater\_equal + + + +`qiskit.circuit.classical.expr.greater_equal(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Create a ‘greater than or equal to’ expression node from the given value, resolving any implicit casts and lifting the values into [`Value`](#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") nodes if required. + +**Examples** + +Query if a classical register is greater than or equal to another: + +```python +>>> from qiskit.circuit import ClassicalRegister +>>> from qiskit.circuit.classical import expr +>>> expr.less(ClassicalRegister(3, "a"), ClassicalRegister(3, "b")) +Binary(Binary.Op.GREATER_EQUAL, Var(ClassicalRegister(3, "a"), Uint(3)), Var(ClassicalRegister(3, "b"), Uint(3)), Uint(3)) +``` + +**Return type** + +[*Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") + +Qiskit’s legacy method for specifying equality conditions for use in conditionals is to use a two-tuple of a [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") or [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") and an integer. This represents an exact equality condition, and there are no ways to specify any other relations. The helper function [`lift_legacy_condition()`](#qiskit.circuit.classical.expr.lift_legacy_condition "qiskit.circuit.classical.expr.lift_legacy_condition") converts this legacy format into the new expression syntax. + +### lift\_legacy\_condition + + + +`qiskit.circuit.classical.expr.lift_legacy_condition(condition, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/constructors.py "view source code") + +Lift a legacy two-tuple equality condition into a new-style [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr"). + +**Examples** + +Taking an old-style conditional instruction and getting an [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") from its condition: + +```python +from qiskit.circuit import ClassicalRegister +from qiskit.circuit.library import HGate +from qiskit.circuit.classical import expr + +cr = ClassicalRegister(2) +instr = HGate().c_if(cr, 3) + +lifted = expr.lift_legacy_condition(instr.condition) +``` + +**Return type** + +[Expr](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") + +### Working with the expression tree + +A typical consumer of the expression tree wants to recursively walk through the tree, potentially statefully, acting on each node differently depending on its type. This is naturally a double-dispatch problem; the logic of ‘what is to be done’ is likely stateful and users should be free to define their own operations, yet each node defines ‘what is being acted on’. We enable this double dispatch by providing a base visitor class for the expression tree. + + + +`qiskit.circuit.classical.expr.ExprVisitor`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/visitors.py "view source code") + +Base class for visitors to the [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") tree. Subclasses should override whichever of the `visit_*` methods that they are able to handle, and should be organised such that non-existent methods will never be called. + +### visit\_binary + + + +`visit_binary(node, /)` + +**Return type** + +*\_T\_co* + +### visit\_cast + + + +`visit_cast(node, /)` + +**Return type** + +*\_T\_co* + +### visit\_generic + + + +`visit_generic(node, /)` + +**Return type** + +*\_T\_co* + +### visit\_unary + + + +`visit_unary(node, /)` + +**Return type** + +*\_T\_co* + +### visit\_value + + + +`visit_value(node, /)` + +**Return type** + +*\_T\_co* + +### visit\_var + + + +`visit_var(node, /)` + +**Return type** + +*\_T\_co* + +Consumers of the expression tree should subclass the visitor, and override the `visit_*` methods that they wish to handle. Any non-overridden methods will call [`visit_generic()`](#qiskit.circuit.classical.expr.ExprVisitor.visit_generic "qiskit.circuit.classical.expr.ExprVisitor.visit_generic"), which unless overridden will raise a `RuntimeError` to ensure that you are aware if new nodes have been added to the expression tree that you are not yet handling. + +For the convenience of simple visitors that only need to inspect the variables in an expression and not the general structure, the iterator method [`iter_vars()`](#qiskit.circuit.classical.expr.iter_vars "qiskit.circuit.classical.expr.iter_vars") is provided. + +### iter\_vars + + + +`qiskit.circuit.classical.expr.iter_vars(node)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/visitors.py "view source code") + +Get an iterator over the [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var") nodes referenced at any level in the given [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr"). + +**Examples** + +Print out the name of each [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") encountered: + +```python +from qiskit.circuit import ClassicalRegister +from qiskit.circuit.classical import expr + +cr1 = ClassicalRegister(3, "a") +cr2 = ClassicalRegister(3, "b") + +for node in expr.iter_vars(expr.bit_and(expr.bit_not(cr1), cr2)): + if isinstance(node.var, ClassicalRegister): + print(node.var.name) +``` + +**Return type** + +[*Iterator*](https://docs.python.org/3/library/typing.html#typing.Iterator "(in Python v3.12)")\[[*Var*](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var")] + +Two expressions can be compared for direct structural equality by using the built-in Python `==` operator. In general, though, one might want to compare two expressions slightly more semantically, allowing that the [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") nodes inside them are bound to different memory-location descriptions between two different circuits. In this case, one can use [`structurally_equivalent()`](#qiskit.circuit.classical.expr.structurally_equivalent "qiskit.circuit.classical.expr.structurally_equivalent") with two suitable “key” functions to do the comparison. + +### structurally\_equivalent + + + +`qiskit.circuit.classical.expr.structurally_equivalent(left, right, left_var_key=None, right_var_key=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/expr/visitors.py "view source code") + +Do these two expressions have exactly the same tree structure, up to some key function for the [`Var`](#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.expr.Var") objects? + +In other words, are these two expressions the exact same trees, except we compare the `Var.var` fields by calling the appropriate `*_var_key` function on them, and comparing that output for equality. This function does not allow any semantic “equivalences” such as asserting that `a == b` is equivalent to `b == a`; the evaluation order of the operands could, in general, cause such a statement to be false (consider hypothetical `extern` functions that access global state). + +There’s no requirements on the key functions, except that their outputs should have general `__eq__` methods. If a key function returns `None`, the variable will be used verbatim instead. + +**Parameters** + +* **left** ([*expr.Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr")) – one of the [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") nodes. +* **right** ([*expr.Expr*](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr")) – the other [`Expr`](#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.expr.Expr") node. +* **left\_var\_key** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*],* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – a callable whose output should be used when comparing `Var.var` attributes. If this argument is `None` or its output is `None` for a given variable in `left`, the variable will be used verbatim. +* **right\_var\_key** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*],* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – same as `left_var_key`, but used on the variables in `right` instead. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +**Examples** + +Comparing two expressions for structural equivalence, with no remapping of the variables. These are different because the different [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") instances compare differently: + +```python +>>> from qiskit.circuit import Clbit +>>> from qiskit.circuit.classical import expr +>>> left_bits = [Clbit(), Clbit()] +>>> right_bits = [Clbit(), Clbit()] +>>> left = expr.logic_and(expr.logic_not(left_bits[0]), left_bits[1]) +>>> right = expr.logic_and(expr.logic_not(right_bits[0]), right_bits[1]) +>>> expr.structurally_equivalent(left, right) +False +``` + +Comparing the same two expressions, but this time using mapping functions that associate the bits with simple indices: + +```python +>>> left_key = {var: i for i, var in enumerate(left_bits)}.get +>>> right_key = {var: i for i, var in enumerate(right_bits)}.get +>>> expr.structurally_equivalent(left, right, left_key, right_key) +True +``` + + + + + +## Typing + + + +`qiskit.circuit.classical.types` + +The type system of the expression tree is exposed through this module. This is inherently linked to the expression system in the [`expr`](#module-qiskit.circuit.classical.expr "qiskit.circuit.classical.expr") module, as most expressions can only be understood with the context of the types that they act on. + +All types inherit from an abstract base class: + + + +`qiskit.circuit.classical.types.Type`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/types.py "view source code") + +Root base class of all nodes in the type tree. The base case should never be instantiated directly. + +This must not be subclassed by users; subclasses form the internal data of the representation of expressions, and it does not make sense to add more outside of Qiskit library code. + +Types should be considered immutable objects, and you must not mutate them. It is permissible to reuse a [`Type`](#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type") that you take from another object without copying it, and generally this will be the best approach for performance. [`Type`](#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type") objects are designed to be small amounts of data, and it’s best to point to the same instance of the data where possible rather than heap-allocating a new version of the same thing. Where possible, the class constructors will return singleton instances to facilitate this. + +The two different types available are for Booleans (corresponding to [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") and the literals `True` and `False`), and unsigned integers (corresponding to [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") and Python integers). + + + +`final class qiskit.circuit.classical.types.Bool`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/types.py "view source code") + +The Boolean type. This has exactly two values: `True` and `False`. + + + +`final class qiskit.circuit.classical.types.Uint(width)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/types.py "view source code") + +An unsigned integer of fixed bit width. + +Note that [`Uint`](#qiskit.circuit.classical.types.Uint "qiskit.circuit.classical.types.Uint") defines a family of types parametrised by their width; it is not one single type, which may be slightly different to the ‘classical’ programming languages you are used to. + +There are some functions on these types exposed here as well. These are mostly expected to be used only in manipulations of the expression tree; users who are building expressions using the [user-facing construction interface](#circuit-classical-expressions-expr-construction) should not need to use these. + +The type system is equipped with a partial ordering, where $a < b$ is interpreted as “$a$ is a strict subtype of $b$”. Note that the partial ordering is a subset of the directed graph that describes the allowed explicit casting operations between types. The partial ordering defines when one type may be lossless directly interpreted as another. + +The low-level interface to querying the subtyping relationship is the [`order()`](#qiskit.circuit.classical.types.order "qiskit.circuit.classical.types.order") function. + +### order + + + +`qiskit.circuit.classical.types.order(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/ordering.py "view source code") + +Get the ordering relationship between the two types as an enumeration value. + +**Examples** + +Compare two [`Uint`](#qiskit.circuit.classical.types.Uint "qiskit.circuit.classical.types.Uint") types of different widths: + +```python +>>> from qiskit.circuit.classical import types +>>> types.order(types.Uint(8), types.Uint(16)) +Ordering.LESS +``` + +Compare two types that have no ordering between them: + +```python +>>> types.order(types.Uint(8), types.Bool()) +Ordering.NONE +``` + +**Return type** + +[*Ordering*](#qiskit.circuit.classical.types.Ordering "qiskit.circuit.classical.types.ordering.Ordering") + +The return value is an enumeration [`Ordering`](#qiskit.circuit.classical.types.Ordering "qiskit.circuit.classical.types.Ordering") that describes what, if any, subtyping relationship exists between the two types. + + + +`qiskit.circuit.classical.types.Ordering(value)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/ordering.py "view source code") + +Enumeration listing the possible relations between two types. Types only have a partial ordering, so it’s possible for two types to have no sub-typing relationship. + +Note that the sub-/supertyping relationship is not the same as whether a type can be explicitly cast from one to another. + +Some helper methods are then defined in terms of this low-level [`order()`](#qiskit.circuit.classical.types.order "qiskit.circuit.classical.types.order") primitive: + +### is\_subtype + + + +`qiskit.circuit.classical.types.is_subtype(left, right, /, strict=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/ordering.py "view source code") + +Does the relation $\text{left} \le \text{right}$ hold? If there is no ordering relation between the two types, then this returns `False`. If `strict`, then the equality is also forbidden. + +**Examples** + +Check if one type is a subclass of another: + +```python +>>> from qiskit.circuit.classical import types +>>> types.is_subtype(types.Uint(8), types.Uint(16)) +True +``` + +Check if one type is a strict subclass of another: + +```python +>>> types.is_subtype(types.Bool(), types.Bool()) +True +>>> types.is_subtype(types.Bool(), types.Bool(), strict=True) +False +``` + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_supertype + + + +`qiskit.circuit.classical.types.is_supertype(left, right, /, strict=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/ordering.py "view source code") + +Does the relation $\text{left} \ge \text{right}$ hold? If there is no ordering relation between the two types, then this returns `False`. If `strict`, then the equality is also forbidden. + +**Examples** + +Check if one type is a superclass of another: + +```python +>>> from qiskit.circuit.classical import types +>>> types.is_supertype(types.Uint(8), types.Uint(16)) +False +``` + +Check if one type is a strict superclass of another: + +```python +>>> types.is_supertype(types.Bool(), types.Bool()) +True +>>> types.is_supertype(types.Bool(), types.Bool(), strict=True) +False +``` + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### greater + + + +`qiskit.circuit.classical.types.greater(left, right, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classical/types/ordering.py "view source code") + +Get the greater of the two types, assuming that there is an ordering relation between them. Technically, this is a slightly restricted version of the concept of the ‘meet’ of the two types in that the return value must be one of the inputs. In practice in the type system there is no concept of a ‘sum’ type, so the ‘meet’ exists if and only if there is an ordering between the two types, and is equal to the greater of the two types. + +**Returns** + +The greater of the two types. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – if there is no ordering relation between the two types. + +**Return type** + +[*Type*](#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.types.Type") + +**Examples** + +Find the greater of two [`Uint`](#qiskit.circuit.classical.types.Uint "qiskit.circuit.classical.types.Uint") types: + +```python +>>> from qiskit.circuit.classical import types +>>> types.greater(types.Uint(8), types.Uint(16)) +types.Uint(16) +``` + diff --git a/docs/api/qiskit/0.46/circuit_library.md b/docs/api/qiskit/0.46/circuit_library.md new file mode 100644 index 00000000000..463777ab094 --- /dev/null +++ b/docs/api/qiskit/0.46/circuit_library.md @@ -0,0 +1,1292 @@ +--- +title: library +description: API reference for qiskit.circuit.library +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.circuit.library +--- + + + + + + + +# Circuit Library + + + +`qiskit.circuit.library` + +The circuit library is a collection of well-studied and valuable circuits, directives, and gates. We call them valuable for different reasons, for instance they can serve as building blocks for algorithms or they are circuits that we think are hard to simulate classically. + +Each element can be plugged into a circuit using the [`QuantumCircuit.append()`](qiskit.circuit.QuantumCircuit#append "qiskit.circuit.QuantumCircuit.append") method and so the circuit library allows users to program at higher levels of abstraction. For example, to append a multi-controlled CNOT: + +```python +from qiskit.circuit.library import MCXGate +gate = MCXGate(4) + +from qiskit import QuantumCircuit +circuit = QuantumCircuit(5) +circuit.append(gate, [0, 1, 4, 2, 3]) +circuit.draw('mpl') +``` + +![../\_images/circuit\_library-1.png](/images/api/qiskit/0.46/circuit_library-1.png) + +The library is organized in several sections. + +## Standard gates + +These operations are reversible unitary gates and they all subclass [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). As a consequence, they all have the methods [`to_matrix()`](qiskit.circuit.Gate#to_matrix "qiskit.circuit.Gate.to_matrix"), [`power()`](qiskit.circuit.Gate#power "qiskit.circuit.Gate.power"), and [`control()`](qiskit.circuit.Gate#control "qiskit.circuit.Gate.control"), which we can generally only apply to unitary operations. + +For example: + +```python +from qiskit.circuit.library import XGate +gate = XGate() +print(gate.to_matrix()) # X gate +print(gate.power(1/2).to_matrix()) # √X gate +print(gate.control(1).to_matrix()) # CX (controlled X) gate +``` + +```python +[[0.+0.j 1.+0.j] + [1.+0.j 0.+0.j]] +[[0.5+0.5j 0.5-0.5j] + [0.5-0.5j 0.5+0.5j]] +[[1.+0.j 0.+0.j 0.+0.j 0.+0.j] + [0.+0.j 0.+0.j 0.+0.j 1.+0.j] + [0.+0.j 0.+0.j 1.+0.j 0.+0.j] + [0.+0.j 1.+0.j 0.+0.j 0.+0.j]] +``` + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------- | +| [`C3XGate`](qiskit.circuit.library.C3XGate "qiskit.circuit.library.C3XGate")(\*args\[, \_force\_mutable]) | The X gate controlled on 3 qubits. | +| [`C3SXGate`](qiskit.circuit.library.C3SXGate "qiskit.circuit.library.C3SXGate")(\*args\[, \_force\_mutable]) | The 3-qubit controlled sqrt-X gate. | +| [`C4XGate`](qiskit.circuit.library.C4XGate "qiskit.circuit.library.C4XGate")(\*args\[, \_force\_mutable]) | The 4-qubit controlled X gate. | +| [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate")(\*args\[, \_force\_mutable]) | CCX gate, also known as Toffoli gate. | +| [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate")(\*args\[, \_force\_mutable]) | Double-CNOT gate. | +| [`CHGate`](qiskit.circuit.library.CHGate "qiskit.circuit.library.CHGate")(\*args\[, \_force\_mutable]) | Controlled-Hadamard gate. | +| [`CPhaseGate`](qiskit.circuit.library.CPhaseGate "qiskit.circuit.library.CPhaseGate")(theta\[, label, ctrl\_state, ...]) | Controlled-Phase gate. | +| [`CRXGate`](qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate")(theta\[, label, ctrl\_state, ...]) | Controlled-RX gate. | +| [`CRYGate`](qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate")(theta\[, label, ctrl\_state, ...]) | Controlled-RY gate. | +| [`CRZGate`](qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate")(theta\[, label, ctrl\_state, ...]) | Controlled-RZ gate. | +| [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate")(\*args\[, \_force\_mutable]) | Controlled-S gate. | +| [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate")(\*args\[, \_force\_mutable]) | Controlled-S^dagger gate. | +| [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate")(\*args\[, \_force\_mutable]) | Controlled-SWAP gate, also known as the Fredkin gate. | +| [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate")(\*args\[, \_force\_mutable]) | Controlled-√X gate. | +| [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate")(theta, phi, lam, gamma\[, label, ...]) | Controlled-U gate (4-parameter two-qubit gate). | +| [`CU1Gate`](qiskit.circuit.library.CU1Gate "qiskit.circuit.library.CU1Gate")(theta\[, label, ctrl\_state, ...]) | Controlled-U1 gate. | +| [`CU3Gate`](qiskit.circuit.library.CU3Gate "qiskit.circuit.library.CU3Gate")(theta, phi, lam\[, label, ...]) | Controlled-U3 gate (3-parameter two-qubit gate). | +| [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate")(\*args\[, \_force\_mutable]) | Controlled-X gate. | +| [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate")(\*args\[, \_force\_mutable]) | Controlled-Y gate. | +| [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate")(\*args\[, \_force\_mutable]) | Controlled-Z gate. | +| [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate")(\*args\[, \_force\_mutable]) | CCZ gate. | +| [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate")(\*args\[, \_force\_mutable]) | An echoed cross-resonance gate. | +| [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate")(\*args\[, \_force\_mutable]) | Single-qubit Hadamard gate. | +| [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate")(\*args\[, \_force\_mutable]) | Identity gate. | +| [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate")(num\_qubits, theta\[, label]) | MSGate has been deprecated. | +| [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate")(theta\[, label, duration, unit]) | Single-qubit rotation about the Z axis. | +| [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate")(\*args\[, \_force\_mutable]) | The simplified Toffoli gate, also referred to as Margolus gate. | +| [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate")(\*args\[, \_force\_mutable]) | The simplified 3-controlled Toffoli gate. | +| [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate")(theta, phi\[, label, duration, unit]) | Rotation θ around the cos(φ)x + sin(φ)y axis. | +| [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate")(theta\[, label, duration, unit]) | Single-qubit rotation about the X axis. | +| [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate")(theta\[, label, duration, unit]) | A parametric 2-qubit $X \otimes X$ interaction (rotation about XX). | +| [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate")(theta\[, label, duration, unit]) | Single-qubit rotation about the Y axis. | +| [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate")(theta\[, label, duration, unit]) | A parametric 2-qubit $Y \otimes Y$ interaction (rotation about YY). | +| [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate")(phi\[, label, duration, unit]) | Single-qubit rotation about the Z axis. | +| [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate")(theta\[, label, duration, unit]) | A parametric 2-qubit $Z \otimes Z$ interaction (rotation about ZZ). | +| [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate")(theta\[, label, duration, unit]) | A parametric 2-qubit $Z \otimes X$ interaction (rotation about ZX). | +| [`XXMinusYYGate`](qiskit.circuit.library.XXMinusYYGate "qiskit.circuit.library.XXMinusYYGate")(theta\[, beta, label, ...]) | XX-YY interaction gate. | +| [`XXPlusYYGate`](qiskit.circuit.library.XXPlusYYGate "qiskit.circuit.library.XXPlusYYGate")(theta\[, beta, label, duration, ...]) | XX+YY interaction gate. | +| [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate")(\*args\[, \_force\_mutable]) | Single qubit S gate (Z\*\*0.5). | +| [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate")(\*args\[, \_force\_mutable]) | Single qubit S-adjoint gate (\~Z\*\*0.5). | +| [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")(\*args\[, \_force\_mutable]) | The SWAP gate. | +| [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate")(\*args\[, \_force\_mutable]) | iSWAP gate. | +| [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate")(\*args\[, \_force\_mutable]) | The single-qubit Sqrt(X) gate ($\sqrt{X}$). | +| [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate")(\*args\[, \_force\_mutable]) | The inverse single-qubit Sqrt(X) gate. | +| [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate")(\*args\[, \_force\_mutable]) | Single qubit T gate (Z\*\*0.25). | +| [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate")(\*args\[, \_force\_mutable]) | Single qubit T-adjoint gate (\~Z\*\*0.25). | +| [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate")(theta, phi, lam\[, label, duration, unit]) | Generic single-qubit rotation gate with 3 Euler angles. | +| [`U1Gate`](qiskit.circuit.library.U1Gate "qiskit.circuit.library.U1Gate")(theta\[, label, duration, unit]) | Single-qubit rotation about the Z axis. | +| [`U2Gate`](qiskit.circuit.library.U2Gate "qiskit.circuit.library.U2Gate")(phi, lam\[, label, duration, unit]) | Single-qubit rotation about the X+Z axis. | +| [`U3Gate`](qiskit.circuit.library.U3Gate "qiskit.circuit.library.U3Gate")(theta, phi, lam\[, label, duration, unit]) | Generic single-qubit rotation gate with 3 Euler angles. | +| [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate")(\*args\[, \_force\_mutable]) | The single-qubit Pauli-X gate ($\sigma_x$). | +| [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate")(\*args\[, \_force\_mutable]) | The single-qubit Pauli-Y gate ($\sigma_y$). | +| [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate")(\*args\[, \_force\_mutable]) | The single-qubit Pauli-Z gate ($\sigma_z$). | +| [`GlobalPhaseGate`](qiskit.circuit.library.GlobalPhaseGate "qiskit.circuit.library.GlobalPhaseGate")(phase\[, label, duration, unit]) | The global phase gate ($e^{i\theta}$). | + +## Standard Directives + +Directives are operations to the quantum stack that are meant to be interpreted by the backend or the transpiler. In general, the transpiler or backend might optionally ignore them if there is no implementation for them. + +| | | +| --------------------------------------------------------------------------------------------------- | -------------------- | +| [`Barrier`](qiskit.circuit.library.Barrier "qiskit.circuit.library.Barrier")(num\_qubits\[, label]) | Barrier instruction. | + +## Standard Operations + +Operations are non-reversible changes in the quantum state of the circuit. + +| | | +| ------------------------------------------------------------------------------------------------------ | ----------------------------------------------- | +| [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure")(\[label, duration, unit]) | Quantum measurement in the computational basis. | +| [`Reset`](qiskit.circuit.library.Reset "qiskit.circuit.library.Reset")(\[label, duration, unit]) | Qubit reset. | + +## Generalized Gates + +These “gates” (many are [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") subclasses) allow to set the amount of qubits involved at instantiation time. + +```python +from qiskit.circuit.library import Diagonal + +diagonal = Diagonal([1, 1]) +print(diagonal.num_qubits) + +diagonal = Diagonal([1, 1, 1, 1]) +print(diagonal.num_qubits) +``` + +```python +1 +2 +``` + +| | | | | +| ------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------- | - | ----------------------------------- | +| [`Diagonal`](qiskit.circuit.library.Diagonal "qiskit.circuit.library.Diagonal")(diag) | Diagonal circuit. | | | +| [`DiagonalGate`](qiskit.circuit.library.DiagonalGate "qiskit.circuit.library.DiagonalGate")(diag) | Gate implementing a diagonal transformation. | | | +| [`MCMT`](qiskit.circuit.library.MCMT "qiskit.circuit.library.MCMT")(gate, num\_ctrl\_qubits, num\_target\_qubits) | The multi-controlled multi-target gate, for an arbitrary singly controlled target gate. | | | +| [`MCMTVChain`](qiskit.circuit.library.MCMTVChain "qiskit.circuit.library.MCMTVChain")(gate, num\_ctrl\_qubits, ...) | The MCMT implementation using the CCX V-chain. | | | +| [`Permutation`](qiskit.circuit.library.Permutation "qiskit.circuit.library.Permutation")(num\_qubits\[, pattern, seed]) | An n\_qubit circuit that permutes qubits. | | | +| [`PermutationGate`](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate")(pattern) | A gate that permutes qubits. | | | +| [`GMS`](qiskit.circuit.library.GMS "qiskit.circuit.library.GMS")(num\_qubits, theta) | Global Mølmer–Sørensen gate. | | | +| [`GR`](qiskit.circuit.library.GR "qiskit.circuit.library.GR")(num\_qubits, theta, phi) | Global R gate. | | | +| [`GRX`](qiskit.circuit.library.GRX "qiskit.circuit.library.GRX")(num\_qubits, theta) | Global RX gate. | | | +| [`GRY`](qiskit.circuit.library.GRY "qiskit.circuit.library.GRY")(num\_qubits, theta) | Global RY gate. | | | +| [`GRZ`](qiskit.circuit.library.GRZ "qiskit.circuit.library.GRZ")(num\_qubits, phi) | Global RZ gate. | | | +| [`MCPhaseGate`](qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate")(lam, num\_ctrl\_qubits\[, label, ...]) | Multi-controlled-Phase gate. | | | +| [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.MCXGate")(\[num\_ctrl\_qubits, label, ...]) | The general, multi-controlled X gate. | | | +| [`MCXGrayCode`](qiskit.circuit.library.MCXGrayCode "qiskit.circuit.library.MCXGrayCode")(\[num\_ctrl\_qubits, label, ...]) | Implement the multi-controlled X gate using the Gray code. | | | +| [`MCXRecursive`](qiskit.circuit.library.MCXRecursive "qiskit.circuit.library.MCXRecursive")(\[num\_ctrl\_qubits, label, ...]) | Implement the multi-controlled X gate using recursion. | | | +| [`MCXVChain`](qiskit.circuit.library.MCXVChain "qiskit.circuit.library.MCXVChain")(\[num\_ctrl\_qubits, dirty\_ancillas, ...]) | Implement the multi-controlled X gate using a V-chain of CX gates. | | | +| [`RVGate`](qiskit.circuit.library.RVGate "qiskit.circuit.library.RVGate")(v\_x, v\_y, v\_z\[, basis]) | Rotation around arbitrary rotation axis $v$ where \$ | v | \$ is angle of rotation in radians. | +| [`PauliGate`](qiskit.circuit.library.PauliGate "qiskit.circuit.library.PauliGate")(label) | A multi-qubit Pauli gate. | | | +| [`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction")(linear\[, validate\_input]) | A linear reversible circuit on n qubits. | | | +| [`Isometry`](qiskit.circuit.library.Isometry "qiskit.circuit.library.Isometry")(isometry, num\_ancillas\_zero, ...\[, ...]) | Decomposition of arbitrary isometries from $m$ to $n$ qubits. | | | +| [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate")(data\[, label, check\_input]) | Class quantum gates specified by a unitary matrix. | | | +| [`UCGate`](qiskit.circuit.library.UCGate "qiskit.circuit.library.UCGate")(gate\_list\[, up\_to\_diagonal]) | Uniformly controlled gate (also called multiplexed gate). | | | +| [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.UCPauliRotGate")(angle\_list, rot\_axis) | Uniformly controlled Pauli rotations. | | | +| [`UCRXGate`](qiskit.circuit.library.UCRXGate "qiskit.circuit.library.UCRXGate")(angle\_list) | Uniformly controlled Pauli-X rotations. | | | +| [`UCRYGate`](qiskit.circuit.library.UCRYGate "qiskit.circuit.library.UCRYGate")(angle\_list) | Uniformly controlled Pauli-Y rotations. | | | +| [`UCRZGate`](qiskit.circuit.library.UCRZGate "qiskit.circuit.library.UCRZGate")(angle\_list) | Uniformly controlled Pauli-Z rotations. | | | + +## Boolean Logic Circuits + +These are [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") subclasses that implement boolean logic operations, such as the logical or of a set of qubit states. + +| | | +| ------------------------------------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------- | +| [`AND`](qiskit.circuit.library.AND "qiskit.circuit.library.AND")(num\_variable\_qubits\[, flags, mcx\_mode]) | A circuit implementing the logical AND operation on a number of qubits. | +| [`OR`](qiskit.circuit.library.OR "qiskit.circuit.library.OR")(num\_variable\_qubits\[, flags, mcx\_mode]) | A circuit implementing the logical OR operation on a number of qubits. | +| [`XOR`](qiskit.circuit.library.XOR "qiskit.circuit.library.XOR")(num\_qubits\[, amount, seed]) | An n\_qubit circuit for bitwise xor-ing the input with some integer `amount`. | +| [`InnerProduct`](qiskit.circuit.library.InnerProduct "qiskit.circuit.library.InnerProduct")(num\_qubits) | A 2n-qubit Boolean function that computes the inner product of two n-qubit vectors over $F_2$. | + +## Basis Change Circuits + +These circuits allow basis transformations of the qubit states. For example, in the case of the Quantum Fourier Transform (QFT), it transforms between the computational basis and the Fourier basis. + +| | | +| ------------------------------------------------------------------------------------------------------------ | ---------------------------------- | +| [`QFT`](qiskit.circuit.library.QFT "qiskit.circuit.library.QFT")(\[num\_qubits, approximation\_degree, ...]) | Quantum Fourier Transform Circuit. | + +## Arithmetic Circuits + +These [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")s perform classical arithmetic, such as addition or multiplication. + +### Amplitude Functions + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------- | +| [`LinearAmplitudeFunction`](qiskit.circuit.library.LinearAmplitudeFunction "qiskit.circuit.library.LinearAmplitudeFunction")(num\_state\_qubits, ...) | A circuit implementing a (piecewise) linear function on qubit amplitudes. | + +### Functional Pauli Rotations + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------- | +| [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.FunctionalPauliRotations")(\[num\_state\_qubits, ...]) | Base class for functional Pauli rotations. | +| [`LinearPauliRotations`](qiskit.circuit.library.LinearPauliRotations "qiskit.circuit.library.LinearPauliRotations")(\[num\_state\_qubits, ...]) | Linearly-controlled X, Y or Z rotation. | +| [`PolynomialPauliRotations`](qiskit.circuit.library.PolynomialPauliRotations "qiskit.circuit.library.PolynomialPauliRotations")(\[num\_state\_qubits, ...]) | A circuit implementing polynomial Pauli rotations. | +| [`PiecewiseLinearPauliRotations`](qiskit.circuit.library.PiecewiseLinearPauliRotations "qiskit.circuit.library.PiecewiseLinearPauliRotations")(\[...]) | Piecewise-linearly-controlled Pauli rotations. | +| [`PiecewisePolynomialPauliRotations`](qiskit.circuit.library.PiecewisePolynomialPauliRotations "qiskit.circuit.library.PiecewisePolynomialPauliRotations")(\[...]) | Piecewise-polynomially-controlled Pauli rotations. | +| [`PiecewiseChebyshev`](qiskit.circuit.library.PiecewiseChebyshev "qiskit.circuit.library.PiecewiseChebyshev")(f\_x\[, degree, ...]) | Piecewise Chebyshev approximation to an input function. | + +### Adders + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------- | +| [`DraperQFTAdder`](qiskit.circuit.library.DraperQFTAdder "qiskit.circuit.library.DraperQFTAdder")(num\_state\_qubits\[, kind, name]) | A circuit that uses QFT to perform in-place addition on two qubit registers. | +| [`CDKMRippleCarryAdder`](qiskit.circuit.library.CDKMRippleCarryAdder "qiskit.circuit.library.CDKMRippleCarryAdder")(num\_state\_qubits\[, ...]) | A ripple-carry circuit to perform in-place addition on two qubit registers. | +| [`VBERippleCarryAdder`](qiskit.circuit.library.VBERippleCarryAdder "qiskit.circuit.library.VBERippleCarryAdder")(num\_state\_qubits\[, ...]) | The VBE ripple carry adder \[1]. | +| [`WeightedAdder`](qiskit.circuit.library.WeightedAdder "qiskit.circuit.library.WeightedAdder")(\[num\_state\_qubits, weights, name]) | A circuit to compute the weighted sum of qubit registers. | + +### Multipliers + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | +| [`HRSCumulativeMultiplier`](qiskit.circuit.library.HRSCumulativeMultiplier "qiskit.circuit.library.HRSCumulativeMultiplier")(num\_state\_qubits\[, ...]) | A multiplication circuit to store product of two input registers out-of-place. | +| [`RGQFTMultiplier`](qiskit.circuit.library.RGQFTMultiplier "qiskit.circuit.library.RGQFTMultiplier")(num\_state\_qubits\[, ...]) | A QFT multiplication circuit to store product of two input registers out-of-place. | + +### Comparators + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------- | ------------------- | +| [`IntegerComparator`](qiskit.circuit.library.IntegerComparator "qiskit.circuit.library.IntegerComparator")(\[num\_state\_qubits, value, ...]) | Integer Comparator. | + +### Functions on binary variables + +| | | +| --------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------- | +| [`QuadraticForm`](qiskit.circuit.library.QuadraticForm "qiskit.circuit.library.QuadraticForm")(\[num\_result\_qubits, ...]) | Implements a quadratic form on binary variables encoded in qubit registers. | + +### Other arithmetic functions + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------- | ---------------- | +| [`ExactReciprocal`](qiskit.circuit.library.ExactReciprocal "qiskit.circuit.library.ExactReciprocal")(num\_state\_qubits, scaling\[, ...]) | Exact reciprocal | + +## Particular Quantum Circuits + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------ | +| [`FourierChecking`](qiskit.circuit.library.FourierChecking "qiskit.circuit.library.FourierChecking")(f, g) | Fourier checking circuit. | +| [`GraphState`](qiskit.circuit.library.GraphState "qiskit.circuit.library.GraphState")(adjacency\_matrix) | Circuit to prepare a graph state. | +| [`HiddenLinearFunction`](qiskit.circuit.library.HiddenLinearFunction "qiskit.circuit.library.HiddenLinearFunction")(adjacency\_matrix) | Circuit to solve the hidden linear function problem. | +| [`IQP`](qiskit.circuit.library.IQP "qiskit.circuit.library.IQP")(interactions) | Instantaneous quantum polynomial (IQP) circuit. | +| [`QuantumVolume`](qiskit.circuit.library.QuantumVolume "qiskit.circuit.library.QuantumVolume")(num\_qubits\[, depth, seed, ...]) | A quantum volume model circuit. | +| [`PhaseEstimation`](qiskit.circuit.library.PhaseEstimation "qiskit.circuit.library.PhaseEstimation")(num\_evaluation\_qubits, unitary) | Phase Estimation circuit. | +| [`GroverOperator`](qiskit.circuit.library.GroverOperator "qiskit.circuit.library.GroverOperator")(oracle\[, state\_preparation, ...]) | The Grover operator. | +| [`PhaseOracle`](qiskit.circuit.library.PhaseOracle "qiskit.circuit.library.PhaseOracle")(expression\[, synthesizer, var\_order]) | Phase Oracle. | +| [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz")(\[operators, reps, ...]) | The evolved operator ansatz. | +| [`PauliEvolutionGate`](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate")(operator\[, time, label, ...]) | Time-evolution of an operator consisting of Paulis. | +| [`HamiltonianGate`](qiskit.circuit.library.HamiltonianGate "qiskit.circuit.library.HamiltonianGate")(data, time\[, label]) | Class for representing evolution by a Hamiltonian operator as a gate. | +| [`UnitaryOverlap`](qiskit.circuit.library.UnitaryOverlap "qiskit.circuit.library.UnitaryOverlap")(unitary1, unitary2\[, ...]) | Circuit that returns the overlap between two unitaries $U_2^{\dag} U_1$. | + +## N-local circuits + +These `BlueprintCircuit` subclasses are used as parameterized models (a.k.a. ansatzes or variational forms) in variational algorithms. They are heavily used in near-term algorithms in e.g. Chemistry, Physics or Optimization. + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------- | +| [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.NLocal")(\[num\_qubits, rotation\_blocks, ...]) | The n-local circuit class. | +| [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.TwoLocal")(\[num\_qubits, rotation\_blocks, ...]) | The two-local circuit. | +| [`PauliTwoDesign`](qiskit.circuit.library.PauliTwoDesign "qiskit.circuit.library.PauliTwoDesign")(\[num\_qubits, reps, seed, ...]) | The Pauli Two-Design ansatz. | +| [`RealAmplitudes`](qiskit.circuit.library.RealAmplitudes "qiskit.circuit.library.RealAmplitudes")(\[num\_qubits, entanglement, ...]) | The real-amplitudes 2-local circuit. | +| [`EfficientSU2`](qiskit.circuit.library.EfficientSU2 "qiskit.circuit.library.EfficientSU2")(\[num\_qubits, su2\_gates, ...]) | The hardware efficient SU(2) 2-local circuit. | +| [`ExcitationPreserving`](qiskit.circuit.library.ExcitationPreserving "qiskit.circuit.library.ExcitationPreserving")(\[num\_qubits, mode, ...]) | The heuristic excitation-preserving wave function ansatz. | +| [`QAOAAnsatz`](qiskit.circuit.library.QAOAAnsatz "qiskit.circuit.library.QAOAAnsatz")(\[cost\_operator, reps, ...]) | A generalized QAOA quantum circuit with a support of custom initial states and mixers. | + +## Data encoding circuits + +These `BlueprintCircuit` encode classical data in quantum states and are used as feature maps for classification. + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------ | +| [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.PauliFeatureMap")(\[feature\_dimension, reps, ...]) | The Pauli Expansion circuit. | +| [`ZFeatureMap`](qiskit.circuit.library.ZFeatureMap "qiskit.circuit.library.ZFeatureMap")(feature\_dimension\[, reps, ...]) | The first order Pauli Z-evolution circuit. | +| [`ZZFeatureMap`](qiskit.circuit.library.ZZFeatureMap "qiskit.circuit.library.ZZFeatureMap")(feature\_dimension\[, reps, ...]) | Second-order Pauli-Z evolution circuit. | +| [`StatePreparation`](qiskit.circuit.library.StatePreparation "qiskit.circuit.library.StatePreparation")(params\[, num\_qubits, ...]) | Complex amplitude state preparation. | +| [`Initialize`](qiskit.circuit.library.Initialize "qiskit.circuit.library.Initialize")(params\[, num\_qubits, normalize]) | Complex amplitude initialization. | + +## Template circuits + +Templates are functions that return circuits that compute the identity. They are used at circuit optimization where matching part of the template allows the compiler to replace the match with the inverse of the remainder from the template. + +In this example, the identity constant in a template is checked: + +```python +from qiskit.circuit.library.templates import template_nct_4b_1 +from qiskit.quantum_info import Operator +import numpy as np + +template = template_nct_4b_1() + +identity = np.identity(2 ** len(template.qubits), dtype=complex) +data = Operator(template).data +np.allclose(data, identity) # True, template_nct_4b_1 is the identity +``` + +### NCT (Not-CNOT-Toffoli) template circuits + +Template circuits for [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"), [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"), and [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate") (Toffoli) gates. + +**Reference:** Maslov, D. and Dueck, G. W. and Miller, D. M., Techniques for the synthesis of reversible Toffoli networks, 2007 [http://dx.doi.org/10.1145/1278349.1278355](http://dx.doi.org/10.1145/1278349.1278355) + +### template\_nct\_2a\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_2a_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_2a_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_2a\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_2a_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_2a_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_2a\_3 + + + +`qiskit.circuit.library.templates.nct.template_nct_2a_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_2a_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_4a\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_4a_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_4a_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_4a\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_4a_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_4a_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_4a\_3 + + + +`qiskit.circuit.library.templates.nct.template_nct_4a_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_4a_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_4b\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_4b_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_4b_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_4b\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_4b_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_4b_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_5a\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_5a_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_5a_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_5a\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_5a_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_5a_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_5a\_3 + + + +`qiskit.circuit.library.templates.nct.template_nct_5a_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_5a_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_5a\_4 + + + +`qiskit.circuit.library.templates.nct.template_nct_5a_4()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_5a_4.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_6a\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_6a_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_6a_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_6a\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_6a_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_6a_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_6a\_3 + + + +`qiskit.circuit.library.templates.nct.template_nct_6a_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_6a_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_6a\_4 + + + +`qiskit.circuit.library.templates.nct.template_nct_6a_4()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_6a_4.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_6b\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_6b_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_6b_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_6b\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_6b_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_6b_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_6c\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_6c_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_6c_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_7a\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_7a_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_7a_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_7b\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_7b_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_7b_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_7c\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_7c_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_7c_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_7d\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_7d_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_7d_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_7e\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_7e_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_7e_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9a\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_9a_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9a_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_3 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_4 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_4()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_4.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_5 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_5()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_5.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_6 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_6()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_6.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_7 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_7()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_7.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_8 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_8()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_8.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_9 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_9()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_9.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_10 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_10()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_10.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_11 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_11()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_11.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9c\_12 + + + +`qiskit.circuit.library.templates.nct.template_nct_9c_12()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9c_12.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_1 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_2 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_3 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_4 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_4()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_4.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_5 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_5()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_5.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_6 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_6()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_6.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_7 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_7()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_7.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_8 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_8()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_8.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_9 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_9()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_9.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### template\_nct\_9d\_10 + + + +`qiskit.circuit.library.templates.nct.template_nct_9d_10()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/nct/template_nct_9d_10.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### Clifford template circuits + +Template circuits over Clifford gates. + +### clifford\_2\_1 + + + +`qiskit.circuit.library.clifford_2_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_2_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_2\_2 + + + +`qiskit.circuit.library.clifford_2_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_2_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_2\_3 + + + +`qiskit.circuit.library.clifford_2_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_2_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_2\_4 + + + +`qiskit.circuit.library.clifford_2_4()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_2_4.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_3\_1 + + + +`qiskit.circuit.library.clifford_3_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_3_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_4\_1 + + + +`qiskit.circuit.library.clifford_4_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_4_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_4\_2 + + + +`qiskit.circuit.library.clifford_4_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_4_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_4\_3 + + + +`qiskit.circuit.library.clifford_4_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_4_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_4\_4 + + + +`qiskit.circuit.library.clifford_4_4()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_4_4.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_5\_1 + + + +`qiskit.circuit.library.clifford_5_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_5_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_6\_1 + + + +`qiskit.circuit.library.clifford_6_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_6_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_6\_2 + + + +`qiskit.circuit.library.clifford_6_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_6_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_6\_3 + + + +`qiskit.circuit.library.clifford_6_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_6_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_6\_4 + + + +`qiskit.circuit.library.clifford_6_4()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_6_4.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_6\_5 + + + +`qiskit.circuit.library.clifford_6_5()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_6_5.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_8\_1 + + + +`qiskit.circuit.library.clifford_8_1()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_8_1.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_8\_2 + + + +`qiskit.circuit.library.clifford_8_2()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_8_2.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### clifford\_8\_3 + + + +`qiskit.circuit.library.clifford_8_3()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/clifford/clifford_8_3.py "view source code") + +**Returns** + +template as a quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### RZXGate template circuits + +Template circuits with [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate"). + +### rzx\_yz + + + +`qiskit.circuit.library.rzx_yz(theta=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/rzx/rzx_yz.py "view source code") + +Template for CX - RYGate - CX. + +### rzx\_xz + + + +`qiskit.circuit.library.rzx_xz(theta=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/rzx/rzx_xz.py "view source code") + +Template for CX - RXGate - CX. + +### rzx\_cy + + + +`qiskit.circuit.library.rzx_cy(theta=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/rzx/rzx_cy.py "view source code") + +Template for CX - RYGate - CX. + +### rzx\_zz1 + + + +`qiskit.circuit.library.rzx_zz1(theta=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/rzx/rzx_zz1.py "view source code") + +Template for CX - RZGate - CX. + +### rzx\_zz2 + + + +`qiskit.circuit.library.rzx_zz2(theta=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/rzx/rzx_zz2.py "view source code") + +Template for CX - RZGate - CX. + +### rzx\_zz3 + + + +`qiskit.circuit.library.rzx_zz3(theta=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/templates/rzx/rzx_zz3.py "view source code") + +Template for CX - RZGate - CX. + diff --git a/docs/api/qiskit/0.46/circuit_singleton.md b/docs/api/qiskit/0.46/circuit_singleton.md new file mode 100644 index 00000000000..cd7dceddb72 --- /dev/null +++ b/docs/api/qiskit/0.46/circuit_singleton.md @@ -0,0 +1,210 @@ +--- +title: singleton +description: API reference for qiskit.circuit.singleton +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.circuit.singleton +--- + + + + + + + +# Singleton instructions + + + +`qiskit.circuit.singleton` + +The machinery in this module is for defining subclasses of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") and [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") that preferentially return a shared immutable singleton instance when instantiated. Taking the example of [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"), the final user-facing result is that: + +* There is a regular class called `XGate`, which derives from [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). +* Doing something like `XGate(label="my_gate")` produces an object whose type is exactly `XGate`, and all the mutability works completely as expected; all the methods resolve to exactly those defined by [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"), [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), or parents. +* Doing `XGate()` produces a singleton object whose type is a synthetic `_SingletonXGate` class, which derives [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") but overrides [`__setattr__()`](https://docs.python.org/3/reference/datamodel.html#object.__setattr__ "(in Python v3.12)") to make itself immutable. The object itself has precisely the same instance attributes as `XGate()` would have if there was no singleton handling. This object will return itself under [`copy()`](https://docs.python.org/3/library/copy.html#copy.copy "(in Python v3.12)"), [`deepcopy()`](https://docs.python.org/3/library/copy.html#copy.deepcopy "(in Python v3.12)") and roundtrip through [`pickle`](https://docs.python.org/3/library/pickle.html#module-pickle "(in Python v3.12)"). + +The same can be true for, for example, [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure"), except that it’s a subclass of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") only, and not [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"). + + + The classes in this module are for advanced use, because they are closely entwined with the heart of Qiskit’s data model for circuits. + + +From a library-author perspective, the minimum that is needed to enhance a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") or [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") with this behaviour is to inherit from [`SingletonGate`](#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") ([`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction")) instead of [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") ([`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction")), and for the `__init__` method to have defaults for all of its arguments (these will be the state of the singleton instance). For example: + +```python +class XGate(SingletonGate): + def __init__(self, label=None): + super().__init__("x", 1, [], label=label) + +assert XGate() is XGate() +``` + +## Interface + +The public classes correspond to the standard classes [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") and [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), respectively, and are subclasses of these. + + + +`qiskit.circuit.singleton.SingletonInstruction(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/singleton.py "view source code") + +A base class to use for [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") objects that by default are singleton instances. + +This class should be used for instruction classes that have fixed definitions and do not contain any unique state. The canonical example of something like this is [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure") which has an immutable definition and any instance of [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure") is the same. Using singleton instructions as a base class for these types of gate classes provides a large advantage in the memory footprint of multiple instructions. + +The exception to be aware of with this class though are the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") attributes [`label`](qiskit.circuit.Instruction#label "qiskit.circuit.Instruction.label"), [`condition`](qiskit.circuit.Instruction#condition "qiskit.circuit.Instruction.condition"), [`duration`](qiskit.circuit.Instruction#duration "qiskit.circuit.Instruction.duration"), and [`unit`](qiskit.circuit.Instruction#unit "qiskit.circuit.Instruction.unit") which can be set differently for specific instances of gates. For [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") usage to be sound setting these attributes is not available and they can only be set at creation time, or on an object that has been specifically made mutable using [`to_mutable()`](qiskit.circuit.Instruction#to_mutable "qiskit.circuit.Instruction.to_mutable"). If any of these attributes are used during creation, then instead of using a single shared global instance of the same gate a new separate instance will be created. + + + +`qiskit.circuit.singleton.SingletonGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/singleton.py "view source code") + +A base class to use for [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") objects that by default are singleton instances. + +This class is very similar to [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction"), except implies unitary [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") semantics as well. The same caveats around setting attributes in that class apply here as well. + + + +`qiskit.circuit.singleton.SingletonControlledGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/singleton.py "view source code") + +A base class to use for [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") objects that by default are singleton instances + +This class is very similar to [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction"), except implies unitary [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") semantics as well. The same caveats around setting attributes in that class apply here as well. + +When inheriting from one of these classes, the produced class will have an eagerly created singleton instance that will be returned whenever the class is constructed with arguments that have been defined to be singletons. Typically this will be the defaults. These instances are immutable; attempts to modify their properties will raise [`TypeError`](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)"). + +*All* subclasses of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") have a [`mutable`](qiskit.circuit.Instruction#mutable "qiskit.circuit.Instruction.mutable") property. For most instructions this is `True`, while for the singleton instances it is `False`. One can use the [`to_mutable()`](qiskit.circuit.Instruction#to_mutable "qiskit.circuit.Instruction.to_mutable") method to get a version of the instruction that is owned and safe to mutate. + +The singleton instances are not exact instances of their base class; they are special subclasses that cannot construct new objects. This means that: + +```python +type(XGate()) is not XGate +``` + +You should not rely on [`type`](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") having an exact value; use [`isinstance()`](https://docs.python.org/3/library/functions.html#isinstance "(in Python v3.12)") instead for type checking. If you need to reliably retrieve the base class from an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), see the [`Instruction.base_class`](qiskit.circuit.Instruction#base_class "qiskit.circuit.Instruction.base_class") attribute; singleton instances set this correctly. For most cases in using Qiskit, [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") is a more suitable determiner of what an instruction “means” in a circuit. + +### Deriving new singletons + +The simplest example of deriving a new singleton instruction is simply to inherit from the correct base and supply an [`__init__()`](https://docs.python.org/3/reference/datamodel.html#object.__init__ "(in Python v3.12)") method that has immutable defaults for any arguments. For example: + +```python +from qiskit.circuit.singleton import SingletonInstruction + +class MyInstruction(SingletonInstruction): + def __init__(self, label=None): + super().__init__("my_instruction", 1, 0, label=label) + +assert MyInstruction() is MyInstruction() +assert MyInstruction(label="some label") is not MyInstruction() +assert MyInstruction(label="some label").mutable +``` + +The singleton instance will use all the constructor’s defaults. + +You can also derive from an instruction that is itself a singleton. The singleton nature of the class will be inherited, though the singleton instances of the two classes will be different: + +```python +class MyOtherInstruction(MyInstruction): + pass + +assert MyOtherInstruction() is MyOtherInstruction() +assert MyOtherInstruction() is not MyInstruction() +``` + +If for some reason you want to derive from [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction"), or one of the related or subclasses but *do not* want the default singleton instance to be created, such as if you are defining a new abstract base class, you can set the keyword argument `create_default_singleton=False` in the class definition: + +```python +class NotASingleton(SingletonInstruction, create_default_singleton=False): + def __init__(self): + return super().__init__("my_mutable", 1, 0, []) + +assert NotASingleton() is not NotASingleton() +``` + +If your constructor does not have defaults for all its arguments, you must set `create_default_singleton=False`. + +Subclasses of [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") and the other associated classes can control how their constructor’s arguments are interpreted, in order to help the singleton machinery return the singleton even in the case than an optional argument is explicitly set to its default. + +### \_singleton\_lookup\_key + + + +`static SingletonInstruction._singleton_lookup_key(*_args, **_kwargs)` + +Given the arguments to the constructor, return a key tuple that identifies the singleton instance to retrieve, or `None` if the arguments imply that a mutable object must be created. + +For performance, as a special case, this method will not be called if the class constructor was given zero arguments (e.g. the construction `XGate()` will not call this method, but `XGate(label=None)` will), and the default singleton will immediately be returned. + +This static method can (and probably should) be overridden by subclasses. The derived signature should match the class’s `__init__`; this method should then examine the arguments to determine whether it requires mutability, or what the cache key (if any) should be. + +The function should return either `None` or valid `dict` key (i.e. hashable and implements equality). Returning `None` means that the created instance must be mutable. No further singleton-based processing will be done, and the class creation will proceed as if there was no singleton handling. Otherwise, the returned key can be anything hashable and no special meaning is ascribed to it. Whenever this method returns the same key, the same singleton instance will be returned. We suggest that you use a tuple of the values of all arguments that can be set while maintaining the singleton nature. + +Only keys that match the default arguments or arguments given to `additional_singletons` at class-creation time will actually return singletons; other values will return a standard mutable instance. + + + The singleton machinery will handle an unhashable return from this function gracefully by returning a mutable instance. Subclasses should ensure that their key is hashable in the happy path, but they do not need to manually verify that the user-supplied arguments are hashable. For example, it’s safe to implement this as: + + ```python + @staticmethod + def _singleton_lookup_key(*args, **kwargs): + return None if kwargs else args + ``` + + even though a user might give some unhashable type as one of the `args`. + + +This is set by all Qiskit standard-library gates such that the `label` and similar keyword arguments are ignored in the key calculation if they are their defaults, or a mutable instance is returned if they are not. + +You can also specify other combinations of constructor arguments to produce singleton instances for, using the `additional_singletons` argument in the class definition. This takes an iterable of `(args, kwargs)` tuples, and will build singletons equivalent to `cls(*args, **kwargs)`. You do not need to handle the case of the default arguments with this. For example, given a class definition: + +```python +class MySingleton(SingletonGate, additional_singletons=[((2,), {"label": "two"})]): + def __init__(self, n=1, label=None): + super().__init__("my", n, [], label=label) + + @staticmethod + def _singleton_lookup_key(n=1, label=None): + return (n, label) +``` + +there will be two singleton instances instantiated. One corresponds to `n=1` and `label=None`, and the other to `n=2` and `label="two"`. Whenever `MySingleton` is constructed with arguments consistent with one of those two cases, the relevant singleton will be returned. For example: + +```python +assert MySingleton() is MySingleton(1, label=None) +assert MySingleton(2, "two") is MySingleton(n=2, label="two") +``` + +The case of the class being instantiated with zero arguments is handled specially to allow an absolute fast-path for inner-loop performance (although the general machinery is not desperately slow anyway). + +## Implementation + + + This section is primarily developer documentation for the code; none of the machinery described here is public, and it is not safe to inherit from any of it directly. + + +There are several moving parts to tackle here. The behaviour of having `XGate()` return some singleton object that is an (inexact) instance of [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") but *without* calling `__init__` requires us to override [`type.__call__`](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)"). This means that [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") must have a metaclass that defines `__call__` to return the singleton instance. + +Next, we need to ensure that there *is* a singleton instance for `XGate()` to return. This can be done dynamically on each call (i.e. check if the instance exists and create it if not), but since we also want that instance to be very special, it’s easier to hook in and create it during the definition of the `XGate` type object. This also has the advantage that we do not need to make the singleton object pickleable; we only need to specify where to retrieve it from during the unpickle, because the creation of the base type object will recreate the singleton. + +We want the singleton instance to: + +* be immutable; it should reject all attempts to mutate itself. +* have exactly the same state as an `XGate()` would have had if there was no singleton handling. + +We do this in a three-step procedure: + +1. Before creating any singletons, we separately define the overrides needed to make an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") and a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") immutable. This is `_SingletonInstructionOverrides` and the other `_*Overrides` classes. +2. While we are creating the `XGate` type object, we dynamically *also* create a subclass of it that has the immutable overrides in its method-resolution order in the correct place. These override the standard methods / properties that are defined on the mutable gate (we do not attempt to override any cases where the type object we are creating has extra inplace methods). +3. We can’t instantiate this new subclass, because when it calls `XGate.__init__`, it will attempt to set some attributes, and these will be rejected by immutability. Instead, we first create a completely regular `XGate` instance, and then we dynamically change its type to the singleton class, freezing it. + +We could do this entirely within the metaclass machinery, but that would require `XGate` to be defined as something like: + +```python +class XGate(Gate, metaclass=_SingletonMeta, overrides=_SingletonGateOverrides): ... +``` + +which is super inconvenient (or we’d have to have `_SingletonMeta` do a bunch of fragile introspection). Instead, we use the [`abc.ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)")/[`abc.ABCMeta`](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)") pattern of defining a concrete middle class ([`SingletonGate`](#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") in the [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") case) that sets the metaclass, selects the overrides to be applied, and has an [`__init_subclass__()`](https://docs.python.org/3/reference/datamodel.html#object.__init_subclass__ "(in Python v3.12)") that applies the singleton-subclass-creation steps above. The overrides are in separate classes so that *mutable* [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") instances do not have them in their own method-resolution orders; doing this is easier to implement, but requires all the setters and checkers to dance around at runtime trying to validate whether mutating the instance is allowed. + +Finally, to actually build all this machinery up, the base is `_SingletonMeta`, which is a metaclass compatible with any metaclass of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"). This defines the [`__call__()`](https://docs.python.org/3/reference/datamodel.html#object.__call__ "(in Python v3.12)") machinery that overrides [`type.__call__`](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") to return the singleton instances. The other component of it is its [`__new__()`](https://docs.python.org/3/reference/datamodel.html#object.__new__ "(in Python v3.12)"), which is called (non-trivially) during the creation of [`SingletonGate`](#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") and [`SingletonInstruction`](#qiskit.circuit.singleton.SingletonInstruction "qiskit.circuit.singleton.SingletonInstruction") with its `overrides` keyword argument set to define the `__init_subclass__` of those classes with the above properties. We use the metaclass to add this method dynamically, because the [`__init_subclass__()`](https://docs.python.org/3/reference/datamodel.html#object.__init_subclass__ "(in Python v3.12)") machinery wants to be abstract, closing over the `overrides` and the base class, but still able to call [`super`](https://docs.python.org/3/library/functions.html#super "(in Python v3.12)"). It’s more convenient to do this dynamically, closing over the desired class variable and using the two-argument form of [`super`](https://docs.python.org/3/library/functions.html#super "(in Python v3.12)"), since the zero-argument form does magic introspection based on where its containing function was defined. + +Handling multiple singletons requires storing the initialization arguments in some form, to allow the [`to_mutable()`](qiskit.circuit.Instruction#to_mutable "qiskit.circuit.Instruction.to_mutable") method and pickling to be defined. We do this as a lookup dictionary on the singleton *type object*. This is logically an instance attribute, but because we need to dynamically switch in the dynamic \_Singleton type onto an instance of the base type, that gets rather complex; either we have to require that the base already has an instance dictionary, or we risk breaking the `__slots__` layout during the switch. Since the singletons have lifetimes that last until garbage collection of their base class’s type object, we can fake out this instance dictionary using a type-object dictionary that maps instance pointers to the data we want to store. An alternative would be to build a new type object for each individual singleton that closes over (or stores) the initializer arguments, but type objects are quite heavy and the principle is largely same anyway. + diff --git a/docs/api/qiskit/0.46/classicalfunction.md b/docs/api/qiskit/0.46/classicalfunction.md new file mode 100644 index 00000000000..affc59df4fe --- /dev/null +++ b/docs/api/qiskit/0.46/classicalfunction.md @@ -0,0 +1,84 @@ +--- +title: classicalfunction +description: API reference for qiskit.circuit.classicalfunction +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.circuit.classicalfunction +--- + + + + + + + +# ClassicalFunction compiler + + + +`qiskit.circuit.classicalfunction` + +## Overview + +The classical function compiler provides the necessary tools to map a classical potentially irreversible functions into quantum circuits. Below is a simple example of how to synthesize a simple boolean function defined using Python into a QuantumCircuit: + +> ```python +> from qiskit.circuit.classicalfunction import classical_function +> from qiskit.circuit.classicalfunction.types import Int1 +> +> @classical_function +> def grover_oracle(a: Int1, b: Int1, c: Int1, d: Int1) -> Int1: +> return (not a and b and not c and d) +> +> quantum_circuit = grover_oracle.synth(registerless=False) +> quantum_circuit.draw('text') +> +> a: ──o── +> │ +> b: ──■── +> │ +> c: ──o── +> │ +> d: ──■── +> ┌─┴─┐ +> return: ┤ X ├ +> └───┘ +> ``` + +Following Qiskit’s little-endian bit ordering convention, the left-most bit (`a`) is the most significant bit and the right-most bit (`d`) is the least significant bit. + +## Supplementary Information + +### Tweedledum + +Tweedledum is a C++-17 header-only library that implements a large set of reversible (and quantum) synthesis, optimization, and mapping algorithms. The classical function compiler relies on it and its dependencies to both represent logic networks and synthesize them into quantum circuits. + +### ClassicalFunction data types + +At the moment, the only type supported by the classical\_function compilers is `qiskit.circuit.classicalfunction.types.Int1`. The classical function function to parse *must* include type hints (just `Int1` for now). The resulting gate will be a gate in the size of the sum of all the parameters and the return. + +The type `Int1` means the classical function will only operate at bit level. + +## ClassicalFunction compiler API + + + +### classical\_function + +Decorator for a classical function that returns a ClassicalFunction object. + +### ClassicalFunction + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------- | +| [`ClassicalFunction`](qiskit.circuit.classicalfunction.ClassicalFunction "qiskit.circuit.classicalfunction.ClassicalFunction")(source\[, name]) | Represent a classical function and its logic network. | +| [`BooleanExpression`](qiskit.circuit.classicalfunction.BooleanExpression "qiskit.circuit.classicalfunction.BooleanExpression")(expression\[, name, var\_order]) | The Boolean Expression gate. | + +### Exceptions + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | +| [`ClassicalFunctionCompilerTypeError`](qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError "qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError")(\*message) | ClassicalFunction compiler type error. | +| [`ClassicalFunctionParseError`](qiskit.circuit.classicalfunction.ClassicalFunctionParseError "qiskit.circuit.classicalfunction.ClassicalFunctionParseError")(\*message) | ClassicalFunction compiler parse error. | +| [`ClassicalFunctionCompilerTypeError`](qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError "qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError")(\*message) | ClassicalFunction compiler type error. | + diff --git a/docs/api/qiskit/0.46/compiler.md b/docs/api/qiskit/0.46/compiler.md new file mode 100644 index 00000000000..d4b64eb6edd --- /dev/null +++ b/docs/api/qiskit/0.46/compiler.md @@ -0,0 +1,310 @@ +--- +title: compiler +description: API reference for qiskit.compiler +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.compiler +--- + + + + + + + +# Compilation Routines + + + +`qiskit.compiler` + +## Circuit and Pulse Compilation Functions + +### assemble + + + +`qiskit.compiler.assemble(experiments, backend=None, qobj_id=None, qobj_header=None, shots=None, memory=False, seed_simulator=None, qubit_lo_freq=None, meas_lo_freq=None, qubit_lo_range=None, meas_lo_range=None, schedule_los=None, meas_level=MeasLevel.CLASSIFIED, meas_return=MeasReturnType.AVERAGE, meas_map=None, memory_slot_size=100, rep_time=None, rep_delay=None, parameter_binds=None, parametric_pulses=None, init_qubits=True, **run_config)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/compiler/assembler.py "view source code") + +Assemble a list of circuits or pulse schedules into a `Qobj`. + +This function serializes the payloads, which could be either circuits or schedules, to create `Qobj` “experiments”. It further annotates the experiment payload with header and configurations. + +NOTE: Backend.options is not used within assemble. The required values (previously given by backend.set\_options) should be manually extracted from options and supplied directly when calling. + +**Parameters** + +* **experiments** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*] |* [*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")*] |* [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")*]*) – Circuit(s) or pulse schedule(s) to execute + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *| None*) – If set, some runtime options are automatically grabbed from `backend.configuration()` and `backend.defaults()`. If any other option is explicitly set (e.g., `rep_time`), it will override the backend’s. If any other options is set in the run\_config, it will also override the backend’s. + +* **qobj\_id** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – String identifier to annotate the `Qobj` + +* **qobj\_header** ([*QobjHeader*](qiskit.qobj.QobjHeader "qiskit.qobj.common.QobjHeader") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)") *| None*) – User input that will be inserted in `Qobj` header, and will also be copied to the corresponding Result header. Headers do not affect the run. + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Number of repetitions of each circuit, for sampling. Default: 1024 or `max_shots` from the backend configuration, whichever is smaller + +* **memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, per-shot measurement bitstrings are returned as well (provided the backend supports it). For OpenPulse jobs, only measurement level 2 supports this option. + +* **seed\_simulator** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Random seed to control sampling, for when backend is a simulator + +* **qubit\_lo\_freq** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – List of job level qubit drive LO frequencies in Hz. Overridden by `schedule_los` if specified. Must have length `n_qubits.` + +* **meas\_lo\_freq** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – List of measurement LO frequencies in Hz. Overridden by `schedule_los` if specified. Must have length `n_qubits.` + +* **qubit\_lo\_range** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – List of job level drive LO ranges each of form `[range_min, range_max]` in Hz. Used to validate `qubit_lo_freq`. Must have length `n_qubits.` + +* **meas\_lo\_range** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – List of job level measurement LO ranges each of form `[range_min, range_max]` in Hz. Used to validate `meas_lo_freq`. Must have length `n_qubits.` + +* **schedule\_los** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[PulseChannel,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | LoConfig] |* [*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[PulseChannel,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | LoConfig | None*) – Experiment level (ie circuit or schedule) LO frequency configurations for qubit drive and measurement channels. These values override the job level values from `default_qubit_los` and `default_meas_los`. Frequencies are in Hz. Settable for OpenQASM 2 and pulse jobs. + +* **meas\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| MeasLevel*) – Set the appropriate level of the measurement output for pulse experiments. + +* **meas\_return** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| MeasReturnType*) – + + Level of measurement data for the backend to return. + + **For `meas_level` 0 and 1:** + + * `single` returns information from every shot. + * `avg` returns average measurement output (averaged over number of shots). + +* **meas\_map** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit")*]] | None*) – List of lists, containing qubits that must be measured together. + +* **memory\_slot\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Size of each memory slot if the output is Level 0. + +* **rep\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time per program execution in seconds. Must be from the list provided by the backend (`backend.configuration().rep_times`). Defaults to the first entry. + +* **rep\_delay** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Delay between programs in seconds. Only supported on certain backends (if `backend.configuration().dynamic_reprate_enabled=True`). If supported, `rep_delay` will be used instead of `rep_time` and must be from the range supplied by the backend (`backend.configuration().rep_delay_range`). Default is given by `backend.configuration().default_rep_delay`. + +* **parameter\_binds** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – List of Parameter bindings over which the set of experiments will be executed. Each list element (bind) should be of the form \{Parameter1: value1, Parameter2: value2, …}. All binds will be executed across all experiments; e.g., if parameter\_binds is a length-n list, and there are m experiments, a total of m x n experiments will be run (one for each experiment/bind pair). + +* **parametric\_pulses** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – + + A list of pulse shapes which are supported internally on the backend. Example: + + ```python + ['gaussian', 'constant'] + ``` + +* **init\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reset the qubits to the ground state for each shot. Default: `True`. + +* **\*\*run\_config** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")) – Extra arguments used to configure the run (e.g., for Aer configurable backends). Refer to the backend documentation for details on these arguments. + +**Returns** + +A `Qobj` that can be run on a backend. Depending on the type of input, this will be either a `QasmQobj` or a `PulseQobj`. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input cannot be interpreted as either circuits or schedules + +**Return type** + +[*QasmQobj*](qiskit.qobj.QasmQobj "qiskit.qobj.qasm_qobj.QasmQobj") | [*PulseQobj*](qiskit.qobj.PulseQobj "qiskit.qobj.pulse_qobj.PulseQobj") + +### schedule + + + +`qiskit.compiler.schedule(circuits, backend=None, inst_map=None, meas_map=None, dt=None, method=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/compiler/scheduler.py "view source code") + +Schedule a circuit to a pulse `Schedule`, using the backend, according to any specified methods. Supported methods are documented in `qiskit.scheduler.schedule_circuit`. + +**Parameters** + +* **circuits** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*]*) – The quantum circuit or circuits to translate +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *| None*) – A backend instance, which contains hardware-specific data required for scheduling +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.instruction_schedule_map.InstructionScheduleMap") *| None*) – Mapping of circuit operations to pulse schedules. If `None`, defaults to the `backend`’s `instruction_schedule_map` +* **meas\_map** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – List of sets of qubits that must be measured together. If `None`, defaults to the `backend`’s `meas_map` +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The output sample rate of backend control electronics. For scheduled circuits which contain time information, dt is required. If not provided, it will be obtained from the backend configuration +* **method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – Optionally specify a particular scheduling method + +**Returns** + +A pulse `Schedule` that implements the input circuit + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If `inst_map` and `meas_map` are not passed and `backend` is not passed + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")] + +### transpile + + + +`qiskit.compiler.transpile(circuits, backend=None, basis_gates=None, inst_map=None, coupling_map=None, backend_properties=None, initial_layout=None, layout_method=None, routing_method=None, translation_method=None, scheduling_method=None, instruction_durations=None, dt=None, approximation_degree=1.0, timing_constraints=None, seed_transpiler=None, optimization_level=None, callback=None, output_name=None, unitary_synthesis_method='default', unitary_synthesis_plugin_config=None, target=None, hls_config=None, init_method=None, optimization_method=None, ignore_backend_supplied_default_methods=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/compiler/transpiler.py "view source code") + +Transpile one or more circuits, according to some desired transpilation targets. + +Transpilation is potentially done in parallel using multiprocessing when `circuits` is a list with > 1 [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object depending on the local environment and configuration. + +**Parameters** + +* **circuits** (*\_CircuitT*) – Circuit(s) to transpile + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *| None*) – If set, the transpiler will compile the input circuit to this target device. If any other option is explicitly set (e.g., `coupling_map`), it will override the backend’s. + +* **basis\_gates** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – List of basis gate names to unroll to (e.g: `['u1', 'u2', 'u3', 'cx']`). If `None`, do not unroll. + +* **inst\_map** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.instruction_schedule_map.InstructionScheduleMap")*] | None*) – Mapping of unrolled gates to pulse schedules. If this is not provided, transpiler tries to get from the backend. If any user defined calibration is found in the map and this is used in a circuit, transpiler attaches the custom gate definition to the circuit. This enables one to flexibly override the low-level instruction implementation. This feature is available iff the backend supports the pulse gate experiment. + +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.coupling.CouplingMap") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – + + Directed coupling map (perhaps custom) to target in mapping. If the coupling map is symmetric, both directions need to be specified. + + Multiple formats are supported: + + 1. `CouplingMap` instance + 2. List, must be given as an adjacency matrix, where each entry specifies all directed two-qubit interactions supported by backend, e.g: `[[0, 1], [0, 3], [1, 2], [1, 5], [2, 5], [4, 1], [5, 3]]` + +* **backend\_properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.backendproperties.BackendProperties") *| None*) – properties returned by a backend, including information on gate errors, readout errors, qubit coherence times, etc. Find a backend that provides this information with: `backend.properties()` + +* **initial\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.layout.Layout") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)") *| None*) – + + Initial position of virtual qubits on physical qubits. If this layout makes the circuit compatible with the coupling\_map constraints, it will be used. The final layout is not guaranteed to be the same, as the transpiler may permute qubits through swaps or other means. Multiple formats are supported: + + 1. `Layout` instance + + 2. Dict \* virtual to physical: + + ```python + {qr[0]: 0, + qr[1]: 3, + qr[2]: 5} + ``` + + * physical to virtual: + + ```python + {0: qr[0], + 3: qr[1], + 5: qr[2]} + ``` + + 3. List + + * virtual to physical: + + ```python + [0, 3, 5] # virtual qubits are ordered (in addition to named) + ``` + + * physical to virtual: + + ```python + [qr[0], None, None, qr[1], None, qr[2]] + ``` + +* **layout\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of layout selection pass (‘trivial’, ‘dense’, ‘noise\_adaptive’, ‘sabre’). This can also be the external plugin name to use for the `layout` stage. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"layout"` for the `stage_name` argument. + +* **routing\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of routing pass (‘basic’, ‘lookahead’, ‘stochastic’, ‘sabre’, ‘none’). Note This can also be the external plugin name to use for the `routing` stage. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"routing"` for the `stage_name` argument. + +* **translation\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of translation pass (‘unroller’, ‘translator’, ‘synthesis’) This can also be the external plugin name to use for the `translation` stage. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"translation"` for the `stage_name` argument. + +* **scheduling\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of scheduling pass. \* `'as_soon_as_possible'`: Schedule instructions greedily, as early as possible on a qubit resource. (alias: `'asap'`) \* `'as_late_as_possible'`: Schedule instructions late, i.e. keeping qubits in the ground state when possible. (alias: `'alap'`) If `None`, no scheduling will be done. This can also be the external plugin name to use for the `scheduling` stage. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"scheduling"` for the `stage_name` argument. + +* **instruction\_durations** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None,* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None]] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] |* [*InstructionDurations*](qiskit.transpiler.InstructionDurations "qiskit.transpiler.instruction_durations.InstructionDurations") *| None*) – Durations of instructions. Applicable only if scheduling\_method is specified. The gate lengths defined in `backend.properties` are used as default. They are overwritten if this `instruction_durations` is specified. The format of `instruction_durations` must be as follows. The instruction\_durations must be given as a list of tuples \[(instruction\_name, qubits, duration, unit), …]. | \[(‘cx’, \[0, 1], 12.3, ‘ns’), (‘u3’, \[0], 4.56, ‘ns’)] | \[(‘cx’, \[0, 1], 1000), (‘u3’, \[0], 300)] If unit is omitted, the default is ‘dt’, which is a sample time depending on backend. If the time unit is ‘dt’, the duration must be an integer. + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Backend sample time (resolution) in seconds. If `None` (default), `backend.configuration().dt` is used. + +* **approximation\_degree** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – heuristic dial used for circuit approximation (1.0=no approximation, 0.0=maximal approximation) + +* **timing\_constraints** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – + + An optional control hardware restriction on instruction time resolution. A quantum computer backend may report a set of restrictions, namely: + + * granularity: An integer value representing minimum pulse gate resolution in units of `dt`. A user-defined pulse gate should have duration of a multiple of this granularity value. + * min\_length: An integer value representing minimum pulse gate length in units of `dt`. A user-defined pulse gate should be longer than this length. + * pulse\_alignment: An integer value representing a time resolution of gate instruction starting time. Gate instruction should start at time which is a multiple of the alignment value. + * acquire\_alignment: An integer value representing a time resolution of measure instruction starting time. Measure instruction should start at time which is a multiple of the alignment value. + + This information will be provided by the backend configuration. If the backend doesn’t have any restriction on the instruction time allocation, then `timing_constraints` is None and no adjustment will be performed. + +* **seed\_transpiler** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Sets random seed for the stochastic parts of the transpiler + +* **optimization\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – + + How much optimization to perform on the circuits. Higher levels generate more optimized circuits, at the expense of longer transpilation time. + + * 0: no optimization + * 1: light optimization + * 2: heavy optimization + * 3: even heavier optimization + + If `None`, level 1 will be chosen as default. + +* **callback** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[BasePass,* [*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*PropertySet*](qiskit.passmanager.PropertySet "qiskit.passmanager.compilation_status.PropertySet")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – + + A callback function that will be called after each pass execution. The function will be called with 5 keyword arguments, | `pass_`: the pass being run. | `dag`: the dag output of the pass. | `time`: the time to execute the pass. | `property_set`: the property set. | `count`: the index for the pass execution. The exact arguments passed expose the internals of the pass manager, and are subject to change as the pass manager internals change. If you intend to reuse a callback function over multiple releases, be sure to check that the arguments being passed are the same. To use the callback feature, define a function that will take in kwargs dict and access the variables. For example: + + ```python + def callback_func(**kwargs): + pass_ = kwargs['pass_'] + dag = kwargs['dag'] + time = kwargs['time'] + property_set = kwargs['property_set'] + count = kwargs['count'] + ... + transpile(circ, callback=callback_func) + ``` + +* **output\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – A list with strings to identify the output circuits. The length of the list should be exactly the length of the `circuits` parameter. + +* **unitary\_synthesis\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the unitary synthesis method to use. By default `'default'` is used. You can see a list of installed plugins with [`unitary_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names"). + +* **unitary\_synthesis\_plugin\_config** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – An optional configuration dictionary that will be passed directly to the unitary synthesis plugin. By default this setting will have no effect as the default unitary synthesis method does not take custom configuration. This should only be necessary when a unitary synthesis plugin is specified with the `unitary_synthesis` argument. As this is custom for each unitary synthesis plugin refer to the plugin documentation for how to use this option. + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.target.Target") *| None*) – A backend transpiler target. Normally this is specified as part of the `backend` argument, but if you have manually constructed a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object you can specify it manually here. This will override the target from `backend`. + +* **hls\_config** (*HLSConfig | None*) – An optional configuration class `HLSConfig` that will be passed directly to `HighLevelSynthesis` transformation pass. This configuration class allows to specify for various high-level objects the lists of synthesis algorithms and their parameters. + +* **init\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The plugin name to use for the `init` stage. By default an external plugin is not used. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"init"` for the stage name argument. + +* **optimization\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The plugin name to use for the `optimization` stage. By default an external plugin is not used. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"optimization"` for the `stage_name` argument. + +* **ignore\_backend\_supplied\_default\_methods** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `True` any default methods specified by a backend will be ignored. Some backends specify alternative default methods to support custom compilation target-specific passes/plugins which support backend-specific compilation techniques. If you’d prefer that these defaults were not used this option is used to disable those backend-specific defaults. + +**Returns** + +The transpiled circuit(s). + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – in case of bad inputs to transpiler (like conflicting parameters) or errors in passes + +**Return type** + +*\_CircuitT* + +### sequence + + + +`qiskit.compiler.sequence(scheduled_circuits, backend=None, inst_map=None, meas_map=None, dt=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/compiler/sequencer.py "view source code") + +Schedule a scheduled circuit to a pulse `Schedule`, using the backend. + +**Parameters** + +* **scheduled\_circuits** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*]*) – Scheduled circuit(s) to be translated +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *| None*) – A backend instance, which contains hardware-specific data required for scheduling +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.instruction_schedule_map.InstructionScheduleMap") *| None*) – Mapping of circuit operations to pulse schedules. If `None`, defaults to the `backend`’s `instruction_schedule_map` +* **meas\_map** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – List of sets of qubits that must be measured together. If `None`, defaults to the `backend`’s `meas_map` +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The output sample rate of backend control electronics. For scheduled circuits which contain time information, dt is required. If not provided, it will be obtained from the backend configuration + +**Returns** + +A pulse `Schedule` that implements the input circuit + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If `inst_map` and `meas_map` are not passed and `backend` is not passed + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")] + diff --git a/docs/api/qiskit/0.46/converters.md b/docs/api/qiskit/0.46/converters.md new file mode 100644 index 00000000000..bf6bd7e0ff7 --- /dev/null +++ b/docs/api/qiskit/0.46/converters.md @@ -0,0 +1,310 @@ +--- +title: converters +description: API reference for qiskit.converters +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.converters +--- + + + + + + + +# Circuit Converters + + + +`qiskit.converters` + +### circuit\_to\_dag + + + +`qiskit.converters.circuit_to_dag(circuit, copy_operations=True, *, qubit_order=None, clbit_order=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/circuit_to_dag.py "view source code") + +Build a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – the input circuit. +* **copy\_operations** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Deep copy the operation objects in the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") for the output [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit"). This should only be set to `False` if the input [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") will not be used anymore as the operations in the output [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") will be shared instances and modifications to operations in the [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") will be reflected in the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") (and vice versa). +* **qubit\_order** (*Iterable\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*] or None*) – the order that the qubits should be indexed in the output DAG. Defaults to the same order as in the circuit. +* **clbit\_order** (*Iterable\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*] or None*) – the order that the clbits should be indexed in the output DAG. Defaults to the same order as in the circuit. + +**Returns** + +the DAG representing the input circuit. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if the `qubit_order` or `clbit_order` parameters do not match the bits in the circuit. + +**Example** + +```python +from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit +from qiskit.dagcircuit import DAGCircuit +from qiskit.converters import circuit_to_dag + +q = QuantumRegister(3, 'q') +c = ClassicalRegister(3, 'c') +circ = QuantumCircuit(q, c) +circ.h(q[0]) +circ.cx(q[0], q[1]) +circ.measure(q[0], c[0]) +circ.rz(0.5, q[1]).c_if(c, 2) +dag = circuit_to_dag(circ) +``` + +### dag\_to\_circuit + + + +`qiskit.converters.dag_to_circuit(dag, copy_operations=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/dag_to_circuit.py "view source code") + +Build a `QuantumCircuit` object from a `DAGCircuit`. + +**Parameters** + +* **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the input dag. +* **copy\_operations** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Deep copy the operation objects in the [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") for the output [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). This should only be set to `False` if the input [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") will not be used anymore as the operations in the output [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") will be shared instances and modifications to operations in the [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") will be reflected in the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") (and vice versa). + +**Returns** + +the circuit representing the input dag. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Example** + +```python +from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit +from qiskit.dagcircuit import DAGCircuit +from qiskit.converters import circuit_to_dag +from qiskit.circuit.library.standard_gates import CHGate, U2Gate, CXGate +from qiskit.converters import dag_to_circuit + +q = QuantumRegister(3, 'q') +c = ClassicalRegister(3, 'c') +circ = QuantumCircuit(q, c) +circ.h(q[0]) +circ.cx(q[0], q[1]) +circ.measure(q[0], c[0]) +circ.rz(0.5, q[1]).c_if(c, 2) +dag = circuit_to_dag(circ) +circuit = dag_to_circuit(dag) +circuit.draw('mpl') +``` + +![../\_images/converters-1.png](/images/api/qiskit/0.46/converters-1.png) + +### circuit\_to\_instruction + + + +`qiskit.converters.circuit_to_instruction(circuit, parameter_map=None, equivalence_library=None, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/circuit_to_instruction.py "view source code") + +Build an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +The instruction is anonymous (not tied to a named quantum register), and so can be inserted into another circuit. The instruction will have the same string name as the circuit. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – the input circuit. +* **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – For parameterized circuits, a mapping from parameters in the circuit to parameters to be used in the instruction. If None, existing circuit parameters will also parameterize the instruction. +* **equivalence\_library** ([*EquivalenceLibrary*](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary")) – Optional equivalence library where the converted instruction will be registered. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional instruction label. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if parameter\_map is not compatible with circuit + +**Returns** + +an instruction equivalent to the action of the input circuit. Upon decomposition, this instruction will yield the components comprising the original circuit. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Example** + +```python +from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit +from qiskit.converters import circuit_to_instruction + +q = QuantumRegister(3, 'q') +c = ClassicalRegister(3, 'c') +circ = QuantumCircuit(q, c) +circ.h(q[0]) +circ.cx(q[0], q[1]) +circ.measure(q[0], c[0]) +circ.rz(0.5, q[1]).c_if(c, 2) +circuit_to_instruction(circ) +``` + +### circuit\_to\_gate + + + +`qiskit.converters.circuit_to_gate(circuit, parameter_map=None, equivalence_library=None, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/circuit_to_gate.py "view source code") + +Build a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +The gate is anonymous (not tied to a named quantum register), and so can be inserted into another circuit. The gate will have the same string name as the circuit. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – the input circuit. +* **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – For parameterized circuits, a mapping from parameters in the circuit to parameters to be used in the gate. If None, existing circuit parameters will also parameterize the Gate. +* **equivalence\_library** ([*EquivalenceLibrary*](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary")) – Optional equivalence library where the converted gate will be registered. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional gate label. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if circuit is non-unitary or if parameter\_map is not compatible with circuit + +**Returns** + +a Gate equivalent to the action of the input circuit. Upon decomposition, this gate will yield the components comprising the original circuit. + +**Return type** + +[Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") + +### ast\_to\_dag + + + +`qiskit.converters.ast_to_dag(ast)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/ast_to_dag.py "view source code") + +Build a `DAGCircuit` object from an AST `Node` object. + + + The function `qiskit.converters.ast_to_dag.ast_to_dag()` is deprecated as of qiskit 0.46. It will be removed in the 1.0.0 release. Instead use the qiskit.qasm2.dump() or qiskit.qasm2.dumps() function + + +**Parameters** + +**ast** (*Program*) – a Program Node of an AST (parser’s output) + +**Returns** + +the DAG representing an OpenQASM’s AST + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the AST is malformed. + +**Example** + +```python +from qiskit.converters import ast_to_dag +from qiskit import qasm, QuantumCircuit, ClassicalRegister, QuantumRegister + +q = QuantumRegister(3, 'q') +c = ClassicalRegister(3, 'c') +circ = QuantumCircuit(q, c) +circ.h(q[0]) +circ.cx(q[0], q[1]) +circ.measure(q[0], c[0]) +circ.rz(0.5, q[1]).c_if(c, 2) +qasm_str = circ.qasm() +ast = qasm.Qasm(data=qasm_str).parse() +dag = ast_to_dag(ast) +``` + +### dagdependency\_to\_circuit + + + +`qiskit.converters.dagdependency_to_circuit(dagdependency)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/dagdependency_to_circuit.py "view source code") + +Build a `QuantumCircuit` object from a `DAGDependency`. + +**Parameters** + +**dagdependency** ([*DAGDependency*](qiskit.dagcircuit.DAGDependency "qiskit.dagcircuit.DAGDependency")) – the input dag. + +**Returns** + +the circuit representing the input dag dependency. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### circuit\_to\_dagdependency + + + +`qiskit.converters.circuit_to_dagdependency(circuit, create_preds_and_succs=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/circuit_to_dagdependency.py "view source code") + +Build a `DAGDependency` object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – the input circuit. +* **create\_preds\_and\_succs** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to construct lists of predecessors and successors for every node. + +**Returns** + +the DAG representing the input circuit as a dag dependency. + +**Return type** + +[DAGDependency](qiskit.dagcircuit.DAGDependency "qiskit.dagcircuit.DAGDependency") + +### dag\_to\_dagdependency + + + +`qiskit.converters.dag_to_dagdependency(dag, create_preds_and_succs=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/dag_to_dagdependency.py "view source code") + +Build a `DAGDependency` object from a `DAGCircuit`. + +**Parameters** + +* **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the input dag. +* **create\_preds\_and\_succs** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to construct lists of predecessors and successors for every node. + +**Returns** + +the DAG representing the input circuit as a dag dependency. + +**Return type** + +[DAGDependency](qiskit.dagcircuit.DAGDependency "qiskit.dagcircuit.DAGDependency") + +### dagdependency\_to\_dag + + + +`qiskit.converters.dagdependency_to_dag(dagdependency)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/converters/dagdependency_to_dag.py "view source code") + +Build a `DAGCircuit` object from a `DAGDependency`. + +**Parameters** + +**dependency** (*dag*) – the input dag. + +**Returns** + +the DAG representing the input circuit. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + diff --git a/docs/api/qiskit/0.46/dagcircuit.md b/docs/api/qiskit/0.46/dagcircuit.md new file mode 100644 index 00000000000..1df38534736 --- /dev/null +++ b/docs/api/qiskit/0.46/dagcircuit.md @@ -0,0 +1,54 @@ +--- +title: dagcircuit +description: API reference for qiskit.dagcircuit +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.dagcircuit +--- + + + + + + + +# DAG Circuits + + + +`qiskit.dagcircuit` + +## Circuits as Directed Acyclic Graphs + +| | | +| ----------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------- | +| [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")() | Quantum circuit as a directed acyclic graph. | +| [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.DAGNode")(\[nid]) | Parent class for DAGOpNode, DAGInNode, and DAGOutNode. | +| [`DAGOpNode`](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")(op\[, qargs, cargs, dag]) | Object to represent an Instruction at a node in the DAGCircuit. | +| [`DAGInNode`](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")(wire) | Object to represent an incoming wire node in the DAGCircuit. | +| [`DAGOutNode`](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")(wire) | Object to represent an outgoing wire node in the DAGCircuit. | +| [`DAGDepNode`](qiskit.dagcircuit.DAGDepNode "qiskit.dagcircuit.DAGDepNode")(\[type, op, name, qargs, cargs, ...]) | Object to represent the information at a node in the DAGDependency(). | +| [`DAGDependency`](qiskit.dagcircuit.DAGDependency "qiskit.dagcircuit.DAGDependency")() | Object to represent a quantum circuit as a Directed Acyclic Graph (DAG) via operation dependencies (i.e. | + +## Exceptions + +### DAGCircuitError + + + +`qiskit.dagcircuit.DAGCircuitError(*msg)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/exceptions.py "view source code") + +Base class for errors raised by the DAGCircuit object. + +Set the error message. + +### DAGDependencyError + + + +`qiskit.dagcircuit.DAGDependencyError(*msg)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/exceptions.py "view source code") + +Base class for errors raised by the DAGDependency object. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/exceptions.md b/docs/api/qiskit/0.46/exceptions.md new file mode 100644 index 00000000000..983b3da06c8 --- /dev/null +++ b/docs/api/qiskit/0.46/exceptions.md @@ -0,0 +1,72 @@ +--- +title: exceptions +description: API reference for qiskit.exceptions +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.exceptions +--- + + + + + + + +# Top-level exceptions + + + +`qiskit.exceptions` + +All Qiskit-related errors raised by Qiskit are subclasses of the base: + +### QiskitError + + + +`qiskit.exceptions.QiskitError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/exceptions.py "view source code") + +Base class for errors raised by Qiskit. + +Set the error message. + + + Errors that are just general programming errors, such as incorrect typing, may still raise standard Python errors such as `TypeError`. [`QiskitError`](#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") is generally for errors raised in usage that is particular to Qiskit. + + +Many of the Qiskit subpackages define their own more granular error, to help in catching only the subset of errors you care about. For example, [`qiskit.circuit`](circuit#module-qiskit.circuit "qiskit.circuit") almost exclusively uses [`CircuitError`](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError"), while both [`QASM2ExportError`](qasm2#qiskit.qasm2.QASM2ExportError "qiskit.qasm2.QASM2ExportError") and [`QASM2ParseError`](qasm2#qiskit.qasm2.QASM2ParseError "qiskit.qasm2.QASM2ParseError") derive from [`QASM2Error`](qasm2#qiskit.qasm2.QASM2Error "qiskit.qasm2.QASM2Error") in [`qiskit.qasm2`](qasm2#module-qiskit.qasm2 "qiskit.qasm2"), which is in turn a type of [`QiskitError`](#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError"). + +Qiskit has several optional features that depend on other packages that are not required for a minimal install. You can read more about those, and ways to check for their presence, in [`qiskit.utils.optionals`](utils#module-qiskit.utils.optionals "qiskit.utils.optionals"). Trying to use a feature that requires an optional extra will raise a particular error, which subclasses both [`QiskitError`](#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") and the Python built-in `ImportError`. + +### MissingOptionalLibraryError + + + +`qiskit.exceptions.MissingOptionalLibraryError(libname, name, pip_install=None, msg=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/exceptions.py "view source code") + +Raised when an optional library is missing. + +Set the error message. :param libname: Name of missing library :param name: Name of class, function, module that uses this library :param pip\_install: pip install command, if any :param msg: Descriptive message, if any + +Two more uncommon errors relate to failures in reading user-configuration files, or specifying a filename that cannot be used: + +### QiskitUserConfigError + + + +`qiskit.exceptions.QiskitUserConfigError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/exceptions.py "view source code") + +Raised when an error is encountered reading a user config file. + +Set the error message. + +### InvalidFileError + + + +`qiskit.exceptions.InvalidFileError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/exceptions.py "view source code") + +Raised when the file provided is not valid for the specific task. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/execute.md b/docs/api/qiskit/0.46/execute.md new file mode 100644 index 00000000000..963a49fe490 --- /dev/null +++ b/docs/api/qiskit/0.46/execute.md @@ -0,0 +1,183 @@ +--- +title: execute_function +description: API reference for qiskit.execute_function +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.execute_function +--- + + + + + + + +# Executing Experiments + + + +`qiskit.execute_function` + +### execute + + + +`qiskit.execute_function.execute(experiments, backend, basis_gates=None, coupling_map=None, backend_properties=None, initial_layout=None, seed_transpiler=None, optimization_level=None, pass_manager=None, shots=None, memory=None, seed_simulator=None, default_qubit_los=None, default_meas_los=None, qubit_lo_range=None, meas_lo_range=None, schedule_los=None, meas_level=None, meas_return=None, memory_slots=None, memory_slot_size=None, rep_time=None, rep_delay=None, parameter_binds=None, schedule_circuit=False, inst_map=None, meas_map=None, scheduling_method=None, init_qubits=None, **run_config)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/execute_function.py "view source code") + +Execute a list of [`qiskit.circuit.QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") or [`qiskit.pulse.Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") on a backend. + +The execution is asynchronous, and a handle to a job instance is returned. + + + The function `qiskit.execute_function.execute()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function combines `transpile` and `backend.run`, which is covered by `Sampler` [`primitives`](primitives#module-qiskit.primitives "qiskit.primitives"). Alternatively, you can also run [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") followed by `backend.run()`. + + +**Parameters** + +* **experiments** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] or* [*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule")*]*) – Circuit(s) or pulse schedule(s) to execute + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – Backend to execute circuits on. Transpiler options are automatically grabbed from backend.configuration() and backend.properties(). If any other option is explicitly set (e.g. coupling\_map), it will override the backend’s. + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – List of basis gate names to unroll to. e.g: `['u1', 'u2', 'u3', 'cx']`. If `None`, do not unroll. + +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – + + Coupling map (perhaps custom) to target in mapping. Multiple formats are supported: + + 1. [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") instance + 2. `list`: must be given as an adjacency matrix, where each entry specifies all two-qubit interactions supported by backend e.g: `[[0, 1], [0, 3], [1, 2], [1, 5], [2, 5], [4, 1], [5, 3]]` + +* **backend\_properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – Properties returned by a backend, including information on gate errors, readout errors, qubit coherence times, etc. Find a backend that provides this information with: `backend.properties()` + +* **initial\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout") *or*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – + + Initial position of virtual qubits on physical qubits. If this layout makes the circuit compatible with the coupling\_map constraints, it will be used. The final layout is not guaranteed to be the same, as the transpiler may permute qubits through swaps or other means. + + Multiple formats are supported: + + 1. [`qiskit.transpiler.Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") instance + + 2. `dict`: + + * virtual to physical: + + ```python + {qr[0]: 0, + qr[1]: 3, + qr[2]: 5} + ``` + + * physical to virtual: + + ```python + {0: qr[0], + 3: qr[1], + 5: qr[2]} + ``` + + 3. `list`: + + * virtual to physical: + + ```python + [0, 3, 5] # virtual qubits are ordered (in addition to named) + ``` + + * physical to virtual: + + ```python + [qr[0], None, None, qr[1], None, qr[2]] + ``` + +* **seed\_transpiler** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Sets random seed for the stochastic parts of the transpiler + +* **optimization\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – + + How much optimization to perform on the circuits. Higher levels generate more optimized circuits, at the expense of longer transpilation time. + + * 0: no optimization + * 1: light optimization + * 2: heavy optimization + * 3: even heavier optimization + + If None, level 1 will be chosen as default. + +* **pass\_manager** ([*PassManager*](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager")) – The pass manager to use during transpilation. If this arg is present, auto-selection of pass manager based on the transpile options will be turned off and this pass manager will be used directly. + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of repetitions of each circuit, for sampling. Default: 1024 + +* **memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, per-shot measurement bitstrings are returned as well (provided the backend supports it). For OpenPulse jobs, only measurement level 2 supports this option. Default: False + +* **seed\_simulator** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Random seed to control sampling, for when backend is a simulator + +* **default\_qubit\_los** (*Optional\[List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – List of job level qubit drive LO frequencies in Hz. Overridden by `schedule_los` if specified. Must have length `n_qubits`. + +* **default\_meas\_los** (*Optional\[List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – List of job level measurement LO frequencies in Hz. Overridden by `schedule_los` if specified. Must have length `n_qubits`. + +* **qubit\_lo\_range** (*Optional\[List\[List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]]*) – List of job level drive LO ranges each of form `[range_min, range_max]` in Hz. Used to validate `qubit_lo_freq`. Must have length `n_qubits`. + +* **meas\_lo\_range** (*Optional\[List\[List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]]*) – List of job level measurement LO ranges each of form `[range_min, range_max]` in Hz. Used to validate `meas_lo_freq`. Must have length `n_qubits`. + +* **schedule\_los** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – + + Experiment level (ie circuit or schedule) LO frequency configurations for qubit drive and measurement channels. These values override the job level values from `default_qubit_los` and `default_meas_los`. Frequencies are in Hz. Settable for qasm and pulse jobs. + + If a single LO config or dict is used, the values are set at job level. If a list is used, the list must be the size of the number of experiments in the job, except in the case of a single experiment. In this case, a frequency sweep will be assumed and one experiment will be created for every list entry. + + Not every channel is required to be specified. If not specified, the backend default value will be used. + +* **meas\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or MeasLevel*) – Set the appropriate level of the measurement output for pulse experiments. + +* **meas\_return** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or MeasReturn*) – Level of measurement data for the backend to return For `meas_level` 0 and 1: `"single"` returns information from every shot. `"avg"` returns average measurement output (averaged over number of shots). + +* **memory\_slots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of classical memory slots used in this job. + +* **memory\_slot\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Size of each memory slot if the output is Level 0. + +* **rep\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time per program execution in seconds. Must be from the list provided by the backend (`backend.configuration().rep_times`). Defaults to the first entry. + +* **rep\_delay** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Delay between programs in seconds. Only supported on certain backends (`backend.configuration().dynamic_reprate_enabled` ). If supported, `rep_delay` will be used instead of `rep_time` and must be from the range supplied by the backend (`backend.configuration().rep_delay_range`). Default is given by `backend.configuration().default_rep_delay`. + +* **parameter\_binds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*]*) – List of Parameter bindings over which the set of experiments will be executed. Each list element (bind) should be of the form `{Parameter1: value1, Parameter2: value2, ...}`. All binds will be executed across all experiments, e.g. if parameter\_binds is a length-$n$ list, and there are $m$ experiments, a total of $m \times n$ experiments will be run (one for each experiment/bind pair). + +* **schedule\_circuit** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, `experiments` will be converted to [`qiskit.pulse.Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects prior to execution. + +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap")) – Mapping of circuit operations to pulse schedules. If None, defaults to the `instruction_schedule_map` of `backend`. + +* **meas\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*))*) – List of sets of qubits that must be measured together. If None, defaults to the `meas_map` of `backend`. + +* **scheduling\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*)*) – Optionally specify a particular scheduling method. + +* **init\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reset the qubits to the ground state for each shot. Default: `True`. + +* **run\_config** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Extra arguments used to configure the run (e.g. for Aer configurable backends). Refer to the backend documentation for details on these arguments. Note: for now, these keyword arguments will both be copied to the Qobj config, and passed to backend.run() + +**Returns** + +returns job instance derived from Job + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the execution cannot be interpreted as either circuits or schedules + +**Example** + +Construct a 5-qubit GHZ circuit and execute 4321 shots on a backend. + +```python +from qiskit import QuantumCircuit, execute, BasicAer + +backend = BasicAer.get_backend('qasm_simulator') + +qc = QuantumCircuit(5, 5) +qc.h(0) +qc.cx(0, range(1, 5)) +qc.measure_all() + +job = execute(qc, backend, shots=4321) +``` + diff --git a/docs/api/qiskit/0.46/extensions.md b/docs/api/qiskit/0.46/extensions.md new file mode 100644 index 00000000000..edc82a15983 --- /dev/null +++ b/docs/api/qiskit/0.46/extensions.md @@ -0,0 +1,50 @@ +--- +title: extensions +description: API reference for qiskit.extensions +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.extensions +--- + + + + + + + +# Quantum Circuit Extensions + + + +`qiskit.extensions` + +## Unitary Extensions + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------- | --------------------- | +| [`SingleQubitUnitary`](qiskit.extensions.SingleQubitUnitary "qiskit.extensions.SingleQubitUnitary")(unitary\_matrix\[, mode, ...]) | Single-qubit unitary. | + +## Simulator Extensions + +| | | +| ----------------------------------------------------------------------------------------------------------------- | ------------------------------- | +| [`Snapshot`](qiskit.extensions.Snapshot "qiskit.extensions.Snapshot")(label\[, snapshot\_type, num\_qubits, ...]) | Simulator snapshot instruction. | + +## Exceptions + +The additional gates in this module will tend to raise a custom exception when they encounter problems. + +### ExtensionError + + + +`qiskit.extensions.ExtensionError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/extensions/exceptions.py "view source code") + +Base class for errors raised by extensions module. + +Set the error message. + + + The class `qiskit.extensions.exceptions.ExtensionError` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. + + diff --git a/docs/api/qiskit/0.46/index.md b/docs/api/qiskit/0.46/index.md new file mode 100644 index 00000000000..bf7f3e9df70 --- /dev/null +++ b/docs/api/qiskit/0.46/index.md @@ -0,0 +1,64 @@ +--- +title: qiskit +description: API reference for qiskit +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit +--- + + + +# API Reference + +* [Quantum Circuits (`qiskit.circuit`)](circuit) +* [Circuit Library (`qiskit.circuit.library`)](circuit_library) +* [Classical expressions (`qiskit.circuit.classical`)](circuit_classical) +* [Singleton instructions (`qiskit.circuit.singleton`)](circuit_singleton) +* [Compilation Routines (`qiskit.compiler`)](compiler) +* [Executing Experiments (`qiskit.execute_function`)](execute) +* [Visualizations (`qiskit.visualization`)](visualization) +* [ClassicalFunction compiler (`qiskit.circuit.classicalfunction`)](classicalfunction) +* [Circuit Converters (`qiskit.converters`)](converters) +* [Circuit and Schedule Assembler (`qiskit.assembler`)](assembler) +* [DAG Circuits (`qiskit.dagcircuit`)](dagcircuit) +* [Quantum Circuit Extensions (`qiskit.extensions`)](extensions) +* [Passmanager (`qiskit.passmanager`)](passmanager) +* [Providers Interface (`qiskit.providers`)](providers) +* [Writing a New Provider](providers#writing-a-new-provider) +* [Migrating between Backend API Versions](providers#migrating-between-backend-api-versions) +* [BasicAer: Python-based Simulators (`qiskit.providers.basicaer`)](providers_basicaer) +* [BasicProvider: Python-based Simulators (`qiskit.providers.basic_provider`)](providers_basic_provider) +* [Fake Provider (`qiskit.providers.fake_provider`)](providers_fake_provider) +* [Backend Objects (`qiskit.providers.models`)](providers_models) +* [Pulse (`qiskit.pulse`)](pulse) +* [Circuit Scheduler (`qiskit.scheduler`)](scheduler) +* [Circuit Synthesis (`qiskit.synthesis`)](synthesis) +* [Primitives (`qiskit.primitives`)](primitives) +* [OpenQASM 2 (`qiskit.qasm2`)](qasm2) +* [OpenQASM 3 (`qiskit.qasm3`)](qasm3) +* [Qasm (`qiskit.qasm`)](qasm) +* [Qobj (`qiskit.qobj`)](qobj) +* [QPY serialization (`qiskit.qpy`)](qpy) +* [Quantum Information (`qiskit.quantum_info`)](quantum_info) +* [Experiment Results (`qiskit.result`)](result) +* [Qiskit Tools (`qiskit.tools`)](tools) +* [Jupyter Tools (`qiskit.tools.jupyter`)](tools_jupyter) +* [Transpiler (`qiskit.transpiler`)](transpiler) +* [Transpiler Passes (`qiskit.transpiler.passes`)](transpiler_passes) +* [Preset Passmanagers (`qiskit.transpiler.preset_passmanagers`)](transpiler_preset) +* [Transpiler Stage Plugin Interface (`qiskit.transpiler.preset_passmanagers.plugin`)](transpiler_plugins) +* [Synthesis Plugins (`qiskit.transpiler.passes.synthesis.plugin`)](transpiler_synthesis_plugins) +* [Built-in Transpiler Synthesis Plugins](transpiler_builtin_plugins) +* [Utilities (`qiskit.utils`)](utils) +* [Measurement Mitigation Utils (`qiskit.utils.mitigation`)](utils_mitigation) +* [Top-level exceptions (`qiskit.exceptions`)](exceptions) + +## Deprecated Modules + + + These modules are going to be removed in Qiskit 1.0. Consider pinning `qiskit~=0.45` in your dependencies if you need them. + + +* [Algorithms (`qiskit.algorithms`)](algorithms) +* [Operators (`qiskit.opflow`)](opflow) + diff --git a/docs/api/qiskit/0.46/opflow.md b/docs/api/qiskit/0.46/opflow.md new file mode 100644 index 00000000000..b4f9e0a0651 --- /dev/null +++ b/docs/api/qiskit/0.46/opflow.md @@ -0,0 +1,214 @@ +--- +title: opflow +description: API reference for qiskit.opflow +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow +--- + + + + + + + +# Operators + + + +`qiskit.opflow` + + + The [`qiskit.opflow`](#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +Operators and State functions are the building blocks of Quantum Algorithms. + +A library for Quantum Algorithms & Applications is more than a collection of algorithms wrapped in Python functions. It needs to provide tools to make writing algorithms simple and easy. This is the layer of modules between the circuits and algorithms, providing the language and computational primitives for QA\&A research. + +We call this layer the Operator Flow. It works by unifying computation with theory through the common language of functions and operators, in a way which preserves physical intuition and programming freedom. In the Operator Flow, we construct functions over binary variables, manipulate those functions with operators, and evaluate properties of these functions with measurements. + +The Operator Flow is meant to serve as a lingua franca between the theory and implementation of Quantum Algorithms & Applications. Meaning, the ultimate goal is that when theorists speak their theory in the Operator Flow, they are speaking valid implementation, and when the engineers speak their implementation in the Operator Flow, they are speaking valid physical formalism. To be successful, it must be fast and physically formal enough for theorists to find it easier and more natural than hacking Matlab or NumPy, and the engineers must find it straightforward enough that they can learn it as a typical software library, and learn the physics naturally and effortlessly as they learn the code. There can never be a point where we say “below this level this is all hacked out, don’t come down here, stay in the interface layer above.” It all must be clear and learnable. + +Before getting into the details of the code, it’s important to note that three mathematical concepts unpin the Operator Flow. We derive most of the inspiration for the code structure from [John Watrous’s formalism](https://cs.uwaterloo.ca/~watrous/TQI/) (but do not follow it exactly), so it may be worthwhile to review Chapters I and II, which are free online, if you feel the concepts are not clicking. + +1\. An n-qubit State function is a complex function over n binary variables, which we will often refer to as *n-qubit binary strings*. For example, the traditional quantum “zero state” is a 1-qubit state function, with a definition of f(0) = 1 and f(1) = 0. + +2\. An n-qubit Operator is a linear function taking n-qubit state functions to n-qubit state functions. For example, the Pauli X Operator is defined by f(Zero) = One and f(One) = Zero. Equivalently, an Operator can be defined as a complex function over two n-qubit binary strings, and it is sometimes convenient to picture things this way. By this definition, our Pauli X can be defined by its typical matrix elements, f(0, 0) = 0, f(1, 0) = 1, f(0, 1) = 1, f(1, 1) = 0. + +3\. An n-qubit Measurement is a functional taking n-qubit State functions to complex values. For example, a Pauli Z Measurement can be defined by f(Zero) = 0 and f(One) = 1. + + + While every effort has been made to make programming the Operator Flow similar to mathematical notation, in some places our hands are tied by the design of Python. In particular, when using mathematical operators such as `+` and `^` (tensor product), beware that these follow [Python operator precedence rules](https://docs.python.org/3/reference/expressions.html#operator-precedence). For example, `I^X + X^I` will actually be interpreted as `I ^ (X+X) ^ I == 2 * I^X^I`. In these cases, you should use extra parentheses, like `(I ^ X) + (X ^ I)`, or use the relevant method calls. + + +Below, you’ll find a base class for all Operators, some convenience immutable global variables which simplify Operator construction, and two groups of submodules: Operators and Converters. + +## Operator Base Class + +The OperatorBase serves as the base class for all Operators, State functions and measurements, and enforces the presence and consistency of methods to manipulate these objects conveniently. + +| | | +| --------------------------------------------------------------------------- | --------------------------------------------------------------------------------- | +| [`OperatorBase`](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")() | Deprecated: A base class for all Operators: PrimitiveOps, StateFns, ListOps, etc. | + + + +## Operator Globals + +The `operator_globals` is a set of immutable Operator instances that are convenient building blocks to reach for while working with the Operator flow. + +**One qubit Pauli operators:** + +`X`, `Y`, `Z`, `I` + +**Clifford+T, and some other common non-parameterized gates:** + +`CX`, `S`, `H`, `T`, `Swap`, `CZ` + +**One qubit states:** + +`Zero`, `One`, `Plus`, `Minus` + +## Submodules + +### Operators + +The Operators submodules include the PrimitiveOp, ListOp, and StateFn class groups which represent the primary Operator modules. + +| | | +| --------------------------------------------------------------------------------------------------------------- | --------------------------------------------------- | +| [`primitive_ops`](qiskit.opflow.primitive_ops#module-qiskit.opflow.primitive_ops "qiskit.opflow.primitive_ops") | Primitive Operators (qiskit.opflow\.primitive\_ops) | +| [`list_ops`](qiskit.opflow.list_ops#module-qiskit.opflow.list_ops "qiskit.opflow.list_ops") | List Operators (qiskit.opflow\.list\_ops) | +| [`state_fns`](qiskit.opflow.state_fns#module-qiskit.opflow.state_fns "qiskit.opflow.state_fns") | State Functions (qiskit.opflow\.state\_fns) | + +### Converters + +The Converter submodules include objects which manipulate Operators, usually recursing over an Operator structure and changing certain Operators’ representation. For example, the [`PauliExpectation`](qiskit.opflow.expectations.PauliExpectation "qiskit.opflow.expectations.PauliExpectation") traverses an Operator structure, and replaces all of the [`OperatorStateFn`](qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.OperatorStateFn") measurements containing non-diagonal Pauli terms into diagonalizing circuits following by [`OperatorStateFn`](qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.OperatorStateFn") measurement containing only diagonal Paulis. + +| | | +| ----------------------------------------------------------------------------------------------------------- | ----------------------------------------------- | +| [`converters`](qiskit.opflow.converters#module-qiskit.opflow.converters "qiskit.opflow.converters") | Converters (qiskit.opflow\.converters) | +| [`evolutions`](qiskit.opflow.evolutions#module-qiskit.opflow.evolutions "qiskit.opflow.evolutions") | Operator Evolutions (qiskit.opflow\.evolutions) | +| [`expectations`](qiskit.opflow.expectations#module-qiskit.opflow.expectations "qiskit.opflow.expectations") | Expectations (qiskit.opflow\.expectations) | +| [`gradients`](qiskit.opflow.gradients#module-qiskit.opflow.gradients "qiskit.opflow.gradients") | Gradients (qiskit.opflow\.gradients) | + +## Utility functions + +### commutator + + + +`qiskit.opflow.commutator(op_a, op_b)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/utils.py "view source code") + +Deprecated: Compute commutator of op\_a and op\_b. + +$$ +AB - BA. +$$ + + + The function `qiskit.opflow.utils.commutator()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **op\_a** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator A +* **op\_b** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator B + +**Returns** + +the commutator + +**Return type** + +[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") + +### anti\_commutator + + + +`qiskit.opflow.anti_commutator(op_a, op_b)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/utils.py "view source code") + +Deprecated: Compute anti-commutator of op\_a and op\_b. + +$$ +AB + BA. +$$ + + + The function `qiskit.opflow.utils.anti_commutator()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **op\_a** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator A +* **op\_b** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator B + +**Returns** + +the anti-commutator + +**Return type** + +[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") + +### double\_commutator + + + +`qiskit.opflow.double_commutator(op_a, op_b, op_c, sign=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/utils.py "view source code") + +Deprecated: Compute symmetric double commutator of op\_a, op\_b and op\_c. See McWeeny chapter 13.6 Equation of motion methods (page 479) + +If sign is False, it returns + +$$ +[[A, B], C]/2 + [A, [B, C]]/2 += (2ABC + 2CBA - BAC - CAB - ACB - BCA)/2. +$$ + +If sign is True, it returns + +$$ +\lbrace[A, B], C\rbrace/2 + \lbrace A, [B, C]\rbrace/2 += (2ABC - 2CBA - BAC + CAB - ACB + BCA)/2. + + +$$ + + + The function `qiskit.opflow.utils.double_commutator()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **op\_a** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator A +* **op\_b** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator B +* **op\_c** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator C +* **sign** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – False anti-commutes, True commutes + +**Returns** + +the double commutator + +**Return type** + +[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") + +## Exceptions + +### OpflowError + + + +`qiskit.opflow.OpflowError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/exceptions.py "view source code") + +Deprecated: For Opflow specific errors. + +Set the error message. + + + The class `qiskit.opflow.exceptions.OpflowError` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + diff --git a/docs/api/qiskit/0.46/passmanager.md b/docs/api/qiskit/0.46/passmanager.md new file mode 100644 index 00000000000..d50b5df0a65 --- /dev/null +++ b/docs/api/qiskit/0.46/passmanager.md @@ -0,0 +1,173 @@ +--- +title: passmanager +description: API reference for qiskit.passmanager +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.passmanager +--- + + + + + + + +# Passmanager + + + +`qiskit.passmanager` + +## Overview + +The Qiskit pass manager is somewhat inspired by the [LLVM compiler](https://llvm.org/), but it is designed to take a Python object as an input instead of plain source code. + +The pass manager converts the input Python object into an intermediate representation (IR), and it can be optimized and get lowered with a variety of transformations over multiple passes. The pass manager framework may employ multiple IRs with interleaved conversion passes, depending on the context of the optimization. + + + Currently there is no actual use/design of multiple IRs in the builtin Qiskit pass managers. The implementation of the `passmanager` module is agnostic to actual IR types (i.e. no strict type check is performed), and the pass manager works as long as the IR implements all methods required by subsequent passes. A concrete design for the use of multiple IRs might be provided in the future release. + + +The passes may consume the hardware constraints that the Qiskit backend may provide. Finally, the IR is converted back to some Python object. Note that the input type and output type are not necessarily the same. + +Compilation in the pass manager is a chain of `Task` executions that take an IR and output a new IR with some optimization or data analysis. An atomic task is a *pass* which is a subclass of [`GenericPass`](qiskit.passmanager.GenericPass "qiskit.passmanager.GenericPass") that implements a `run()` method that performs some work on the received IR. A set of passes may form a *flow controller*, which is a subclass of [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.BaseController"), which can implement arbitrary compilation-state-dependent logic for deciding which pass will get run next. Passes share intermediate data via the [`PropertySet`](qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") object which is a free-form dictionary. A pass can populate the property set dictionary during the task execution. A flow controller can also consume the property set to control the pass execution, but this access must be read-only. The property set is portable and handed over from pass to pass at execution. In addition to the property set, tasks also receive a [`WorkflowStatus`](qiskit.passmanager.WorkflowStatus "qiskit.passmanager.WorkflowStatus") data structure. This object is initialized when the pass manager is run and handed over to underlying tasks. The status is updated after every pass is run, and contains information about the pipeline state (number of passes run, failure state, and so on) as opposed to the [`PropertySet`](qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet"), which contains information about the IR being optimized. + +A pass manager is a wrapper of the flow controller, with responsibilities of + +* Scheduling optimization tasks, +* Converting an input Python object to a particular Qiskit IR, +* Initializing a property set and workflow status, +* Running scheduled tasks to apply a series of transformations to the IR, +* Converting the IR back to an output Python object. + +This indicates that the flow controller itself is type-agnostic, and a developer must implement a subclass of the [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.BasePassManager") to manage the data conversion steps. This *veil of ignorance* allows us to choose the most efficient data representation for a particular pass manager task, while we can reuse the flow control machinery for different input and output types. + +A single flow controller always takes a single IR object, and returns a single IR object. Parallelism for multiple input objects is supported by the [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.BasePassManager") by broadcasting the flow controller via the `qiskit.tools.parallel_map()` function. + +## Examples + +We look into a toy optimization task, namely, preparing a row of numbers and remove a digit if the number is five. Such task might be easily done by converting the input numbers into string. We use the pass manager framework here, putting the efficiency aside for a moment to learn how to build a custom Qiskit compiler. + +```python +from qiskit.passmanager import BasePassManager, GenericPass, ConditionalController + +class ToyPassManager(BasePassManager): + + def _passmanager_frontend(self, input_program: int, **kwargs) -> str: + return str(input_program) + + def _passmanager_backend(self, passmanager_ir: str, in_program: int, **kwargs) -> int: + return int(passmanager_ir) +``` + +This pass manager inputs and outputs an integer number, while performing the optimization tasks on a string data. Hence, input, IR, output type are integer, string, integer, respectively. The `_passmanager_frontend()` method defines the conversion from the input data to IR, and `_passmanager_backend()` defines the conversion from the IR to output data. The pass manager backend is also given an `in_program` parameter that contains the original `input_program` to the front end, for referencing any original metadata of the input program for the final conversion. + +Next, we implement a pass that removes a digit when the number is five. + +```python +class RemoveFive(GenericPass): + + def run(self, passmanager_ir: str): + return passmanager_ir.replace("5", "") + +task = RemoveFive() +``` + +Finally, we instantiate a pass manager and schedule the task with it. Running the pass manager with random row of numbers returns new numbers that don’t contain five. + +```python +pm = ToyPassManager() +pm.append(task) + +pm.run([123456789, 45654, 36785554]) +``` + +Output: + +```python +[12346789, 464, 36784] +``` + +Now we consider the case of conditional execution. We avoid execution of the “remove five” task when the input number is six digits or less. Such control can be implemented by a flow controller. We start from an analysis pass that provides the flow controller with information about the number of digits. + +```python +class CountDigits(GenericPass): + + def run(self, passmanager_ir: str): + self.property_set["ndigits"] = len(passmanager_ir) + +analysis_task = CountDigits() +``` + +Then, we wrap the remove five task with the [`ConditionalController`](qiskit.passmanager.ConditionalController "qiskit.passmanager.ConditionalController") that runs the stored tasks only when the condition is met. + +```python +def digit_condition(property_set): + # Return True when condition is met. + return property_set["ndigits"] > 6 + +conditional_task = ConditionalController( + tasks=[RemoveFive()], + condition=digit_condition, +) +``` + +As before, we schedule these passes with the pass manager and run. + +```python +pm = ToyPassManager() +pm.append(analysis_task) +pm.append(conditional_task) + +pm.run([123456789, 45654, 36785554]) +``` + +Output: + +```python +[12346789, 45654, 36784] +``` + +The “remove five” task is triggered only for the first and third input values, which have more than six digits. + +With the pass manager framework, a developer can flexibly customize the optimization task by combining multiple passes and flow controllers. See details for following class API documentations. + +## Interface + +### Base classes + +| | | +| ---------------------------------------------------------------------------------------------------------------------- | ----------------------------------------- | +| [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.BasePassManager")(\[tasks, max\_iteration]) | Pass manager base class. | +| [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.BaseController")(\[options]) | Base class of controller. | +| [`GenericPass`](qiskit.passmanager.GenericPass "qiskit.passmanager.GenericPass")() | Base class of a single pass manager task. | + +### Flow controllers + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------- | +| [`FlowController`](qiskit.passmanager.FlowController "qiskit.passmanager.FlowController")(\[options]) | A legacy factory for other flow controllers. | +| [`FlowControllerLinear`](qiskit.passmanager.FlowControllerLinear "qiskit.passmanager.FlowControllerLinear")(\[tasks, options]) | A standard flow controller that runs tasks one after the other. | +| [`ConditionalController`](qiskit.passmanager.ConditionalController "qiskit.passmanager.ConditionalController")(\[tasks, condition, ...]) | A flow controller runs the pipeline once if the condition is true, or does nothing if the condition is false. | +| [`DoWhileController`](qiskit.passmanager.DoWhileController "qiskit.passmanager.DoWhileController")(\[tasks, do\_while, options]) | Run the given tasks in a loop until the `do_while` condition on the property set becomes `False`. | + +### Compilation state + +| | | +| -------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------- | +| [`PropertySet`](qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") | A default dictionary-like object. | +| [`WorkflowStatus`](qiskit.passmanager.WorkflowStatus "qiskit.passmanager.WorkflowStatus")(\[count, completed\_passes, ...]) | Collection of compilation status of workflow, i.e. pass manager run. | +| [`PassManagerState`](qiskit.passmanager.PassManagerState "qiskit.passmanager.PassManagerState")(workflow\_status, property\_set) | A portable container object that pass manager tasks communicate through generator. | + +### Exceptions + +### PassManagerError + + + +`qiskit.passmanager.PassManagerError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/exceptions.py "view source code") + +Pass manager error. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/primitives.md b/docs/api/qiskit/0.46/primitives.md new file mode 100644 index 00000000000..dc91d1f7812 --- /dev/null +++ b/docs/api/qiskit/0.46/primitives.md @@ -0,0 +1,146 @@ +--- +title: primitives +description: API reference for qiskit.primitives +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.primitives +--- + + + + + + + + + +# Primitives + + + +`qiskit.primitives` + +## Overview of Estimator + +Estimator class estimates expectation values of quantum circuits and observables. + +An estimator is initialized with an empty parameter set. The estimator is used to create a [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.JobV1"), via the [`qiskit.primitives.Estimator.run()`](qiskit.primitives.Estimator#run "qiskit.primitives.Estimator.run") method. This method is called with the following parameters + +* quantum circuits ($\psi_i(\theta)$): list of (parameterized) quantum circuits (a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects). +* observables ($H_j$): a list of [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") objects. +* parameter values ($\theta_k$): list of sets of values to be bound to the parameters of the quantum circuits (list of list of float). + +The method returns a [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.JobV1") object, calling [`qiskit.providers.JobV1.result()`](qiskit.providers.JobV1#result "qiskit.providers.JobV1.result") yields the a list of expectation values plus optional metadata like confidence intervals for the estimation. + +$$ +\langle\psi_i(\theta_k)|H_j|\psi_i(\theta_k)\rangle +$$ + +Here is an example of how the estimator is used. + +```python +from qiskit.primitives import Estimator +from qiskit.circuit.library import RealAmplitudes +from qiskit.quantum_info import SparsePauliOp + +psi1 = RealAmplitudes(num_qubits=2, reps=2) +psi2 = RealAmplitudes(num_qubits=2, reps=3) + +H1 = SparsePauliOp.from_list([("II", 1), ("IZ", 2), ("XI", 3)]) +H2 = SparsePauliOp.from_list([("IZ", 1)]) +H3 = SparsePauliOp.from_list([("ZI", 1), ("ZZ", 1)]) + +theta1 = [0, 1, 1, 2, 3, 5] +theta2 = [0, 1, 1, 2, 3, 5, 8, 13] +theta3 = [1, 2, 3, 4, 5, 6] + +estimator = Estimator() + +# calculate [ ] +job = estimator.run([psi1], [H1], [theta1]) +job_result = job.result() # It will block until the job finishes. +print(f"The primitive-job finished with result {job_result}")) + +# calculate [ , +# , +# ] +job2 = estimator.run([psi1, psi2, psi1], [H1, H2, H3], [theta1, theta2, theta3]) +job_result = job2.result() +print(f"The primitive-job finished with result {job_result}") +``` + + + +## Overview of Sampler + +Sampler class calculates probabilities or quasi-probabilities of bitstrings from quantum circuits. + +A sampler is initialized with an empty parameter set. The sampler is used to create a [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.JobV1"), via the [`qiskit.primitives.Sampler.run()`](qiskit.primitives.Sampler#run "qiskit.primitives.Sampler.run") method. This method is called with the following parameters + +* quantum circuits ($\psi_i(\theta)$): list of (parameterized) quantum circuits. (a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects) +* parameter values ($\theta_k$): list of sets of parameter values to be bound to the parameters of the quantum circuits. (list of list of float) + +The method returns a [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.JobV1") object, calling [`qiskit.providers.JobV1.result()`](qiskit.providers.JobV1#result "qiskit.providers.JobV1.result") yields a [`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.SamplerResult") object, which contains probabilities or quasi-probabilities of bitstrings, plus optional metadata like error bars in the samples. + +Here is an example of how sampler is used. + +```python +from qiskit.primitives import Sampler +from qiskit import QuantumCircuit +from qiskit.circuit.library import RealAmplitudes + +# a Bell circuit +bell = QuantumCircuit(2) +bell.h(0) +bell.cx(0, 1) +bell.measure_all() + +# two parameterized circuits +pqc = RealAmplitudes(num_qubits=2, reps=2) +pqc.measure_all() +pqc2 = RealAmplitudes(num_qubits=2, reps=3) +pqc2.measure_all() + +theta1 = [0, 1, 1, 2, 3, 5] +theta2 = [0, 1, 2, 3, 4, 5, 6, 7] + +# initialization of the sampler +sampler = Sampler() + +# Sampler runs a job on the Bell circuit +job = sampler.run(circuits=[bell], parameter_values=[[]], parameters=[[]]) +job_result = job.result() +print([q.binary_probabilities() for q in job_result.quasi_dists]) + +# Sampler runs a job on the parameterized circuits +job2 = sampler.run( + circuits=[pqc, pqc2], + parameter_values=[theta1, theta2], + parameters=[pqc.parameters, pqc2.parameters]) +job_result = job2.result() +print([q.binary_probabilities() for q in job_result.quasi_dists]) +``` + +## Estimator + +| | | +| ----------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------- | +| [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")(\*\[, options]) | Estimator base class. | +| [`Estimator`](qiskit.primitives.Estimator "qiskit.primitives.Estimator")(\*\[, options]) | Reference implementation of [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator"). | +| [`BackendEstimator`](qiskit.primitives.BackendEstimator "qiskit.primitives.BackendEstimator")(backend\[, options, ...]) | Evaluates expectation value using Pauli rotation gates. | + +## Sampler + +| | | +| ----------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")(\*\[, options]) | Sampler base class | +| [`Sampler`](qiskit.primitives.Sampler "qiskit.primitives.Sampler")(\*\[, options]) | Sampler class. | +| [`BackendSampler`](qiskit.primitives.BackendSampler "qiskit.primitives.BackendSampler")(backend\[, options, ...]) | A [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") implementation that provides an interface for leveraging the sampler interface from any backend. | + +## Results + +| | | +| ------------------------------------------------------------------------------------------------------------ | -------------------- | +| [`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.EstimatorResult")(values, metadata) | Result of Estimator. | +| [`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.SamplerResult")(quasi\_dists, metadata) | Result of Sampler. | + diff --git a/docs/api/qiskit/0.46/providers.md b/docs/api/qiskit/0.46/providers.md new file mode 100644 index 00000000000..eeee0fc05fb --- /dev/null +++ b/docs/api/qiskit/0.46/providers.md @@ -0,0 +1,509 @@ +--- +title: providers +description: API reference for qiskit.providers +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.providers +--- + + + + + + + +# Providers Interface + + + +`qiskit.providers` + +This module contains the classes used to build external providers for Terra. A provider is anything that provides an external service to Terra. The typical example of this is a Backend provider which provides [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") objects which can be used for executing [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and/or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects. This module contains the abstract classes which are used to define the interface between a provider and terra. + +## Version Support + +Each providers interface abstract class is individually versioned. When we need to make a change to an interface a new abstract class will be created to define the new interface. These interface changes are not guaranteed to be backwards compatible between versions. + +### Version Changes + +Each minor version release of qiskit-terra **may** increment the version of any providers interface a single version number. It will be an aggregate of all the interface changes for that release on that interface. + +### Version Support Policy + +To enable providers to have time to adjust to changes in this interface Terra will support multiple versions of each class at once. Given the nature of one version per release the version deprecation policy is a bit more conservative than the standard deprecation policy. Terra will support a provider interface version for a minimum of 3 minor releases or the first release after 6 months from the release that introduced a version, whichever is longer, prior to a potential deprecation. After that the standard deprecation policy will apply to that interface version. This will give providers and users sufficient time to adapt to potential breaking changes in the interface. So for example lets say in 0.19.0 `BackendV2` is introduced and in the 3 months after the release of 0.19.0 we release 0.20.0, 0.21.0, and 0.22.0, then 7 months after 0.19.0 we release 0.23.0. In 0.23.0 we can deprecate BackendV2, and it needs to still be supported and can’t be removed until the deprecation policy completes. + +It’s worth pointing out that Terra’s version support policy doesn’t mean providers themselves will have the same support story, they can (and arguably should) update to newer versions as soon as they can, the support window is just for Terra’s supported versions. Part of this lengthy window prior to deprecation is to give providers enough time to do their own deprecation of a potential end user impacting change in a user facing part of the interface prior to bumping their version. For example, let’s say we changed the signature to `Backend.run()` in `BackendV34` in a backwards incompatible way. Before Aer could update its [`AerSimulator`](https://qiskit.org/ecosystem/aer/stubs/qiskit_aer.AerSimulator.html#qiskit_aer.AerSimulator "(in Qiskit Aer v0.13.1)") class to be based on version 34 they’d need to deprecate the old signature prior to switching over. The changeover for Aer is not guaranteed to be lockstep with Terra so we need to ensure there is a sufficient amount of time for Aer to complete its deprecation cycle prior to removing version 33 (ie making version 34 mandatory/the minimum version). + +## Abstract Classes + +### Provider + +| | | +| --------------------------------------------------------------------------- | ------------------------------------------------------------- | +| [`Provider`](qiskit.providers.Provider "qiskit.providers.Provider")() | Base common type for all versioned Provider abstract classes. | +| [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.ProviderV1")() | Base class for a Backend Provider. | + +### Backend + +| | | +| --------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend")() | Base common type for all versioned Backend abstract classes. | +| [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1")(configuration\[, provider]) | Abstract class for Backends | +| [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2")(\[provider, name, description, ...]) | Abstract class for Backends | +| [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties")(\[t1, t2, frequency]) | A representation of the properties of a qubit on a backend. | +| [`BackendV2Converter`](qiskit.providers.BackendV2Converter "qiskit.providers.BackendV2Converter")(backend\[, name\_mapping, ...]) | A converter class that takes a [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") instance and wraps it in a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") interface. | +| [`convert_to_target`](qiskit.providers.convert_to_target "qiskit.providers.convert_to_target")(configuration\[, ...]) | Uses configuration, properties and pulse defaults to construct and return Target class. | + +### Options + +| | | +| ---------------------------------------------------------------------------- | ------------------- | +| [`Options`](qiskit.providers.Options "qiskit.providers.Options")(\*\*kwargs) | Base options object | + +### Job + +| | | +| ---------------------------------------------------------------------------------------- | -------------------------------------------------------- | +| [`Job`](qiskit.providers.Job "qiskit.providers.Job")() | Base common type for all versioned Job abstract classes. | +| [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.JobV1")(backend, job\_id, \*\*kwargs) | Class to handle jobs | + +### Job Status + +| | | +| ----------------------------------------------------------------------------- | ------------------------------------- | +| [`JobStatus`](qiskit.providers.JobStatus "qiskit.providers.JobStatus")(value) | Class for job status enumerated type. | + +### Exceptions + +### QiskitBackendNotFoundError + + + +`qiskit.providers.QiskitBackendNotFoundError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/exceptions.py "view source code") + +Base class for errors raised while looking for a backend. + +Set the error message. + +### BackendPropertyError + + + +`qiskit.providers.BackendPropertyError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/exceptions.py "view source code") + +Base class for errors raised while looking for a backend property. + +Set the error message. + +### JobError + + + +`qiskit.providers.JobError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/exceptions.py "view source code") + +Base class for errors raised by Jobs. + +Set the error message. + +### JobTimeoutError + + + +`qiskit.providers.JobTimeoutError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/exceptions.py "view source code") + +Base class for timeout errors raised by jobs. + +Set the error message. + +### BackendConfigurationError + + + +`qiskit.providers.BackendConfigurationError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/exceptions.py "view source code") + +Base class for errors raised by the BackendConfiguration. + +Set the error message. + +# Writing a New Provider + +If you have a quantum device or simulator that you would like to integrate with Qiskit you will need to write a provider. A provider will provide Terra with a method to get available [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") objects. The [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") object provides both information describing a backend and its operation for the [`transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler") so that circuits can be compiled to something that is optimized and can execute on the backend. It also provides the [`run()`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method which can run the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects and/or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects. This enables users and other Qiskit APIs, such as [`execute()`](execute#qiskit.execute_function.execute "qiskit.execute_function.execute") and higher level algorithms in [`qiskit.algorithms`](algorithms#module-qiskit.algorithms "qiskit.algorithms"), to get results from executing circuits on devices in a standard fashion regardless of how the backend is implemented. At a high level the basic steps for writing a provider are: + +> * Implement a [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.ProviderV1") subclass that handles access to the backend(s). +> +> * Implement a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") subclass and its [`run()`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method. +> +> * Add any custom gates for the backend’s basis to the session [`EquivalenceLibrary`](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary") instance. +> +> * Implement a [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.JobV1") subclass that handles interacting with a running job. + +For a simple example of a provider, see the [qiskit-aqt-provider](https://github.com/Qiskit-Partners/qiskit-aqt-provider) + + + +## Provider + +A provider class serves a single purpose: to get backend objects that enable executing circuits on a device or simulator. The expectation is that any required credentials and/or authentication will be handled in the initialization of a provider object. The provider object will then provide a list of backends, and methods to filter and acquire backends (using the provided credentials if required). An example provider class looks like: + +```python +from qiskit.providers import ProviderV1 as Provider +from qiskit.providers.providerutils import filter_backends + +from .backend import MyBackend + +class MyProvider(Provider): + + def __init__(self, token=None): + super().__init__() + self.token = token + self.backends = [MyBackend(provider=self)] + + def backends(self, name=None, **kwargs): + if name: + backends = [ + backend for backend in backends if backend.name() == name] + return filter_backends(backends, filters=filters, **kwargs) +``` + +Ensure that any necessary information for authentication (if required) are present in the class and that the backends method matches the required interface. The rest is up to the specific provider on how to implement. + + + +## Backend + +The backend classes are the core to the provider. These classes are what provide the interface between Qiskit and the hardware or simulator that will execute circuits. This includes providing the necessary information to describe a backend to the compiler so that it can embed and optimize any circuit for the backend. There are 4 required things in every backend object: a [`target`](qiskit.providers.BackendV2#target "qiskit.providers.BackendV2.target") property to define the model of the backend for the compiler, a [`max_circuits`](qiskit.providers.BackendV2#max_circuits "qiskit.providers.BackendV2.max_circuits") property to define a limit on the number of circuits the backend can execute in a single batch job (if there is no limit `None` can be used), a [`run()`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method to accept job submissions, and a [`_default_options`](qiskit.providers.BackendV2#_default_options "qiskit.providers.BackendV2._default_options") method to define the user configurable options and their default values. For example, a minimum working example would be something like: + +```python +from qiskit.providers import BackendV2 as Backend +from qiskit.transpiler import Target +from qiskit.providers import Options +from qiskit.circuit import Parameter, Measure +from qiskit.circuit.library import PhaseGate, SXGate, UGate, CXGate, IGate + + +class Mybackend(Backend): + + def __init__(self): + super().__init__() + + # Create Target + self._target = Target("Target for My Backend") + # Instead of None for this and below instructions you can define + # a qiskit.transpiler.InstructionProperties object to define properties + # for an instruction. + lam = Parameter("λ") + p_props = {(qubit,): None for qubit in range(5)} + self._target.add_instruction(PhaseGate(lam), p_props) + sx_props = {(qubit,): None for qubit in range(5)} + self._target.add_instruction(SXGate(), sx_props) + phi = Parameter("φ") + theta = Parameter("ϴ") + u_props = {(qubit,): None for qubit in range(5)} + self._target.add_instruction(UGate(theta, phi, lam), u_props) + cx_props = {edge: None for edge in [(0, 1), (1, 2), (2, 3), (3, 4)]} + self._target.add_instruction(CXGate(), cx_props) + meas_props = {(qubit,): None for qubit in range(5)} + self._target.add_instruction(Measure(), meas_props) + id_props = {(qubit,): None for qubit in range(5)} + self._target.add_instruction(IGate(), id_props) + + # Set option validators + self.options.set_validator("shots", (1, 4096)) + self.options.set_validator("memory", bool) + + @property + def target(self): + return self._target + + @property + def max_circuits(self): + return 1024 + + @classmethod + def _default_options(cls): + return Options(shots=1024, memory=False) + + def run(circuits, **kwargs): + # serialize circuits submit to backend and create a job + for kwarg in kwargs: + if not hasattr(kwarg, self.options): + warnings.warn( + "Option %s is not used by this backend" % kwarg, + UserWarning, stacklevel=2) + options = { + 'shots': kwargs.get('shots', self.options.shots), + 'memory': kwargs.get('memory', self.options.shots), + } + job_json = convert_to_wire_format(circuit, options) + job_handle = submit_to_backend(job_jsonb) + return MyJob(self. job_handle, job_json, circuit) +``` + +### Transpiler Interface + +The key piece of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") object is how it describes itself to the compiler. This is handled with the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") class which defines a model of a backend for the transpiler. A backend object will need to return a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object from the [`target`](qiskit.providers.BackendV2#target "qiskit.providers.BackendV2.target") attribute which the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function will use as its model of a backend target for compilation. + + + +#### Custom Basis Gates + +1. If your backend doesn’t use gates in the Qiskit circuit library ([`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library")) you can integrate support for this into your provider. The basic method for doing this is first to define a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") subclass for each custom gate in the basis set. For example: + + ```python + import numpy as np + + from qiskit.circuit import Gate + from qiskit.circuit import QuantumCircuit + + class SYGate(Gate): + def __init__(self, label=None): + super().__init__("sy", 1, [], label=label) + + def _define(self): + qc = QuantumCircuit(1) + q.ry(np.pi / 2, 0) + self.definition = qc + ``` + + The key thing to ensure is that for any custom gates in your Backend’s basis set your custom gate’s name attribute (the first param on `super().__init__()` in the `__init__` definition above) does not conflict with the name of any other gates. The name attribute is what is used to identify the gate in the basis set for the transpiler. If there is a conflict the transpiler will not know which gate to use. + +2. Add the custom gate to the target for your backend. This can be done with the [`Target.add_instruction()`](qiskit.transpiler.Target#add_instruction "qiskit.transpiler.Target.add_instruction") method. You’ll need to add an instance of `SYGate` and its parameters to the target so the transpiler knows it exists. For example, assuming this is part of your [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") implementation for your backend: + + ```python + from qiskit.transpiler import InstructionProperties + + sy_props = { + (0,): InstructionProperties(duration=2.3e-6, error=0.0002) + (1,): InstructionProperties(duration=2.1e-6, error=0.0001) + (2,): InstructionProperties(duration=2.5e-6, error=0.0003) + (3,): InstructionProperties(duration=2.2e-6, error=0.0004) + } + self.target.add_instruction(SYGate(), sy_props) + ``` + + The keys in `sy_props` define the qubits where the backend `SYGate` can be used on, and the values define the properties of `SYGate` on that qubit. For multiqubit gates the tuple keys contain all qubit combinations the gate works on (order is significant, i.e. `(0, 1)` is different from `(1, 0)`). + +3. After you’ve defined the custom gates to use for the backend’s basis set then you need to add equivalence rules to the standard equivalence library so that the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function and [`transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler") module can convert an arbitrary circuit using the custom basis set. This can be done by defining equivalent circuits, in terms of the custom gate, for standard gates. Typically if you can convert from a [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") (if your basis doesn’t include a standard 2 qubit gate) and some commonly used single qubit rotation gates like the [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate") and [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate") that should be sufficient for the transpiler to translate any circuit into the custom basis gates. But, the more equivalence rules that are defined from standard gates to your basis the more efficient translation from an arbitrary circuit to the target basis will be (although not always, and there is a diminishing margin of return). + + For example, if you were to add some rules for the above custom `SYGate` we could define the [`U2Gate`](qiskit.circuit.library.U2Gate "qiskit.circuit.library.U2Gate") and [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate"): + + ```python + from qiskit.circuit.equivalence_library import SessionEquivalenceLibrary + from qiskit.circuit.library import HGate + from qiskit.circuit.library import ZGate + from qiskit.circuit.library import RZGate + from qiskit.circuit.library import U2Gate + + + # H => Z SY + q = qiskit.QuantumRegister(1, "q") + def_sy_h = qiskit.QuantumCircuit(q) + def_sy_h.append(ZGate(), [q[0]], []) + def_sy_h.append(SYGate(), [q[0]], []) + SessionEquivalenceLibrary.add_equivalence( + HGate(), def_sy_h) + + # u2 => Z SY Z + phi = qiskit.circuit.Parameter('phi') + lam = qiskit.circuit.Parameter('lambda') + q = qiskit.QuantumRegister(1, "q") + def_sy_u2 = qiskit.QuantumCircuit(q) + def_sy_u2.append(RZGate(lam), [q[0]], []) + def_sy_u2.append(SYGate(), [q[0]], []) + def_sy_u2.append(RZGate(phi), [q[0]], []) + SessionEquivalenceLibrary.add_equivalence( + U2Gate(phi, lam), def_sy_u2) + ``` + + You will want this to be run on import so that as soon as the provider’s package is imported it will be run. This will ensure that any time the [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator") pass is run with the custom gates the equivalence rules are defined. + + It’s also worth noting that depending on the basis you’re using, some optimization passes in the transpiler, such as [`Optimize1qGatesDecomposition`](qiskit.transpiler.passes.Optimize1qGatesDecomposition "qiskit.transpiler.passes.Optimize1qGatesDecomposition"), may not be able to operate with your custom basis. For our `SYGate` example, the [`Optimize1qGatesDecomposition`](qiskit.transpiler.passes.Optimize1qGatesDecomposition "qiskit.transpiler.passes.Optimize1qGatesDecomposition") will not be able to simplify runs of single qubit gates into the SY basis. This is because the `OneQubitEulerDecomposer` class does not know how to work in the SY basis. To solve this the `SYGate` class would need to be added to Qiskit and `OneQubitEulerDecomposer` updated to support decomposing to the `SYGate`. Longer term that is likely a better direction for custom basis gates and contributing the definitions and support in the transpiler will ensure that it continues to be well supported by Qiskit moving forward. + + + +#### Custom Transpiler Passes + +The transpiler supports the ability for backends to provide custom transpiler stage implementations to facilitate hardware specific optimizations and circuit transformations. Currently there are two stages supported, `get_translation_stage_plugin()` and `get_scheduling_stage_plugin()` which allow a backend to specify string plugin names to be used as the default translation and scheduling stages, respectively. These hook points in a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") class can be used if your backend has requirements for compilation that are not met by the current backend/[`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") interface. Please also consider submitting a Github issue describing your use case as there is interest in improving these interfaces to be able to describe more hardware architectures in greater depth. + +To leverage these hook points you just need to add the methods to your [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") implementation and have them return a string plugin name. For example: + +```python +class Mybackend(BackendV2): + + def get_scheduling_stage_plugin(self): + return "SpecialDD" + + def get_translation_stage_plugin(self): + return "BasisTranslatorWithCustom1qOptimization" +``` + +This snippet of a backend implementation will now have the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function use the `SpecialDD` plugin for the scheduling stage and the `BasisTranslatorWithCustom1qOptimization` plugin for the translation stage by default when the target is set to `Mybackend`. Note that users may override these choices by explicitly selecting a different plugin name. For this interface to work though transpiler stage plugins must be implemented for the returned plugin name. You can refer to [`qiskit.transpiler.preset_passmanagers.plugin`](transpiler_plugins#module-qiskit.transpiler.preset_passmanagers.plugin "qiskit.transpiler.preset_passmanagers.plugin") module documentation for details on how to implement plugins. The typical expectation is that if your backend requires custom passes as part of a compilation stage the provider package will include the transpiler stage plugins that use those passes. However, this is not required and any valid method (from a built-in method or external plugin) can be used. + +This way if these two compilation steps are **required** for running or providing efficient output on `Mybackend` the transpiler will be able to perform these custom steps without any manual user input. + +### Run Method + +Of key importance is the [`run()`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method, which is used to actually submit circuits to a device or simulator. The run method handles submitting the circuits to the backend to be executed and returning a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. Depending on the type of backend this typically involves serializing the circuit object into the API format used by a backend. For example, on IBMQ backends from the `qiskit-ibmq-provider` package this involves converting from a quantum circuit and options into a [qobj](https://arxiv.org/abs/1809.03452) JSON payload and submitting that to the IBM Quantum API. Since every backend interface is different (and in the case of the local simulators serialization may not be needed) it is expected that the backend’s [`run`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method will handle this conversion. + +An example run method would be something like: + +```python +def run(self, circuits. **kwargs): + for kwarg in kwargs: + if not hasattr(kwarg, self.options): + warnings.warn( + "Option %s is not used by this backend" % kwarg, + UserWarning, stacklevel=2) + options = { + 'shots': kwargs.get('shots', self.options.shots) + 'memory': kwargs.get('memory', self.options.shots), + } + job_json = convert_to_wire_format(circuit, options) + job_handle = submit_to_backend(job_jsonb) + return MyJob(self. job_handle, job_json, circuit) +``` + + + +### Options + +There are often several options for a backend that control how a circuit is run. The typical example of this is something like the number of `shots` which is how many times the circuit is to be executed. The options available for a backend are defined using an [`Options`](qiskit.providers.Options "qiskit.providers.Options") object. This object is initially created by the [`_default_options`](qiskit.providers.BackendV2#_default_options "qiskit.providers.BackendV2._default_options") method of a Backend class. The default options returns an initialized [`Options`](qiskit.providers.Options "qiskit.providers.Options") object with all the default values for all the options a backend supports. For example, if the backend supports only supports `shots` the [`_default_options`](qiskit.providers.BackendV2#_default_options "qiskit.providers.BackendV2._default_options") method would look like: + +```python +@classmethod +def _default_options(cls): + return Options(shots=1024) +``` + +You can also set validators on an [`Options`](qiskit.providers.Options "qiskit.providers.Options") object to provide limits and validation on user provided values based on what’s acceptable for your backend. For example, if the `"shots"` option defined above can be set to any value between 1 and 4096 you can set the validator on the options object for you backend with: + +```python +self.options.set_validator("shots", (1, 4096)) +``` + +you can refer to the [`set_validator()`](qiskit.providers.Options#set_validator "qiskit.providers.Options.set_validator") documentation for a full list of validation options. + + + +## Job + +The output from the [`run`](qiskit.providers.BackendV2#run "qiskit.providers.BackendV2.run") method is a [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.JobV1") object. Each provider is expected to implement a custom job subclass that defines the behavior for the provider. There are 2 types of jobs depending on the backend’s execution method, either a sync or async. By default jobs are considered async and the expectation is that it represents a handle to the async execution of the circuits submitted with `Backend.run()`. An async job object provides users the ability to query the status of the execution, cancel a running job, and block until the execution is finished. The [`result`](qiskit.providers.JobV1#result "qiskit.providers.JobV1.result") is the primary user facing method which will block until the execution is complete and then will return a [`Result`](qiskit.result.Result "qiskit.result.Result") object with results of the job. + +For some backends (mainly local simulators) the execution of circuits is a synchronous operation and there is no need to return a handle to a running job elsewhere. For sync jobs its expected that the [`run`](qiskit.providers.BackendV1#run "qiskit.providers.BackendV1.run") method on the backend will block until a [`Result`](qiskit.result.Result "qiskit.result.Result") object is generated and the sync job will return with that inner [`Result`](qiskit.result.Result "qiskit.result.Result") object. + +An example job class for an async API based backend would look something like: + +```python +from qiskit.providers import JobV1 as Job +from qiskit.providers import JobError +from qiskit.providers import JobTimeoutError +from qiskit.providers.jobstatus import JobStatus +from qiskit.result import Result + + +class MyJob(Job): + def __init__(self, backend, job_id, job_json, circuits): + super().__init__(backend, job_id) + self._backend = backend + self.job_json = job_json + self.circuits = circuits + + def _wait_for_result(self, timeout=None, wait=5): + start_time = time.time() + result = None + while True: + elapsed = time.time() - start_time + if timeout and elapsed >= timeout: + raise JobTimeoutError('Timed out waiting for result') + result = get_job_status(self._job_id) + if result['status'] == 'complete': + break + if result['status'] == 'error': + raise JobError('Job error') + time.sleep(wait) + return result + + def result(self, timeout=None, wait=5): + result = self._wait_for_result(timeout, wait) + results = [{'success': True, 'shots': len(result['counts']), + 'data': result['counts']}] + return Result.from_dict({ + 'results': results, + 'backend_name': self._backend.configuration().backend_name, + 'backend_version': self._backend.configuration().backend_version, + 'job_id': self._job_id, + 'qobj_id': ', '.join(x.name for x in self.circuits), + 'success': True, + }) + + def status(self): + result = get_job_status(self._job_id) + if result['status'] == 'running': + status = JobStatus.RUNNING + elif result['status'] == 'complete': + status = JobStatus.DONE + else: + status = JobStatus.ERROR + return status + +def submit(self): + raise NotImplementedError +``` + +and for a sync job: + +```python +class MySyncJob(Job): + _async = False + + def __init__(self, backend, job_id, result): + super().__init__(backend, job_id) + self._result = result + + def submit(self): + return + + def result(self): + return self._result + + def status(self): + return JobStatus.DONE +``` + +## Primitives + +While not directly part of the provider interface, the [`qiskit.primitives`](primitives#module-qiskit.primitives "qiskit.primitives") module is tightly coupled with providers. Specifically the primitive interfaces, such as [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") and [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator"), are designed to enable provider implementations to provide custom implementations which are optimized for the provider’s backends. This can include customizations like circuit transformations, additional pre- and post-processing, batching, caching, error mitigation, etc. The concept of the [`qiskit.primitives`](primitives#module-qiskit.primitives "qiskit.primitives") module is to explicitly enable this as the primitive objects are higher level abstractions to produce processed higher level outputs (such as probability distributions and expectation values) that abstract away the mechanics of getting the best result efficiently, to concentrate on higher level applications using these outputs. + +For example, if your backends were well suited to leverage [mthree](https://github.com/Qiskit-Partners/mthree/) measurement mitigation to improve the quality of the results, you could implement a provider-specific [`Sampler`](qiskit.primitives.Sampler "qiskit.primitives.Sampler") implementation that leverages the `M3Mitigation` class internally to run the circuits and return quasi-probabilities directly from mthree in the result. Doing this would enable algorithms from [`qiskit.algorithms`](algorithms#module-qiskit.algorithms "qiskit.algorithms") to get the best results with mitigation applied directly from your backends. You can refer to the documentation in [`qiskit.primitives`](primitives#module-qiskit.primitives "qiskit.primitives") on how to write custom implementations. Also the built-in implementations: [`Sampler`](qiskit.primitives.Sampler "qiskit.primitives.Sampler"), [`Estimator`](qiskit.primitives.Estimator "qiskit.primitives.Estimator"), [`BackendSampler`](qiskit.primitives.BackendSampler "qiskit.primitives.BackendSampler"), and [`BackendEstimator`](qiskit.primitives.BackendEstimator "qiskit.primitives.BackendEstimator") can serve as references/models on how to implement these as well. + +# Migrating between Backend API Versions + + + +## BackendV1 -> BackendV2 + +The [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") class re-defined user access for most properties of a backend to make them work with native Qiskit data structures and have flatter access patterns. However this means when using a provider that upgrades from [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") to [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") existing access patterns will need to be adjusted. It is expected for existing providers to deprecate the old access where possible to provide a graceful migration, but eventually users will need to adjust code. The biggest change to adapt to in [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") is that most of the information accessible about a backend is contained in its [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object and the backend’s attributes often query its [`target`](qiskit.providers.BackendV2#target "qiskit.providers.BackendV2.target") attribute to return information, however in many cases the attributes only provide a subset of information the target can contain. For example, `backend.coupling_map` returns a [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") constructed from the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") accessible in the [`target`](qiskit.providers.BackendV2#target "qiskit.providers.BackendV2.target") attribute, however the target may contain instructions that operate on more than two qubits (which can’t be represented in a [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) or has instructions that only operate on a subset of qubits (or two qubit links for a two qubit instruction) which won’t be detailed in the full coupling map returned by [`coupling_map`](qiskit.providers.BackendV2#coupling_map "qiskit.providers.BackendV2.coupling_map"). So depending on your use case it might be necessary to look deeper than just the equivalent access with [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2"). + +Below is a table of example access patterns in [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") and the new form with [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2"): + +| [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") | [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") | Notes | +| ---------------------------------------------------------------------- | ---------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `backend.configuration().n_qubits` | `backend.num_qubits` | | +| `backend.configuration().coupling_map` | `backend.coupling_map` | The return from [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") is a [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object. while in [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") it is an edge list. Also this is just a view of the information contained in `backend.target` which may only be a subset of the information contained in [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object. | +| `backend.configuration().backend_name` | `backend.name` | | +| `backend.configuration().backend_version` | `backend.backend_version` | The [`version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version") attribute represents the version of the abstract [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") interface the object implements while [`backend_version`](qiskit.providers.BackendV2#backend_version "qiskit.providers.BackendV2.backend_version") is metadata about the version of the backend itself. | +| `backend.configuration().basis_gates` | `backend.operation_names` | The [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") return is a list of operation names contained in the `backend.target` attribute. The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") may contain more information that can be expressed by this list of names. For example, that some operations only work on a subset of qubits or that some names implement the same gate with different parameters. | +| `backend.configuration().dt` | `backend.dt` | | +| `backend.configuration().dtm` | `backend.dtm` | | +| `backend.configuration().max_experiments` | `backend.max_circuits` | | +| `backend.configuration().online_date` | `backend.online_date` | | +| `InstructionDurations.from_backend(backend)` | `backend.instruction_durations` | | +| `backend.defaults().instruction_schedule_map` | `backend.instruction_schedule_map` | | +| `backend.properties().t1(0)` | `backend.qubit_properties(0).t1` | | +| `backend.properties().t2(0)` | `backend.qubit_properties(0).t2` | | +| `backend.properties().frequency(0)` | `backend.qubit_properties(0).frequency` | | +| `backend.properties().readout_error(0)` | `backend.target["measure"][(0,)].error` | In [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") the error rate for the [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure") operation on a given qubit is used to model the readout error. However a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") can implement multiple measurement types and list them separately in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"). | +| `backend.properties().readout_length(0)` | `backend.target["measure"][(0,)].duration` | In [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") the duration for the [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure") operation on a given qubit is used to model the readout length. However, a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") can implement multiple measurement types and list them separately in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"). | + +There is also a [`BackendV2Converter`](qiskit.providers.BackendV2Converter "qiskit.providers.BackendV2Converter") class available that enables you to wrap a [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") object with a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") interface. + diff --git a/docs/api/qiskit/0.46/providers_basic_provider.md b/docs/api/qiskit/0.46/providers_basic_provider.md new file mode 100644 index 00000000000..df53414332b --- /dev/null +++ b/docs/api/qiskit/0.46/providers_basic_provider.md @@ -0,0 +1,52 @@ +--- +title: basic_provider +description: API reference for qiskit.providers.basic_provider +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.providers.basic_provider +--- + + + + + + + +# BasicProvider: Python-based Simulators + + + +`qiskit.providers.basic_provider` + +A module of Python-based quantum simulators. Simulators can be accessed via the BasicProvider provider, e.g.: + +```python +from qiskit.providers.basic_provider import BasicProvider + +backend = BasicProvider().get_backend('basic_simulator') +``` + +## Simulators + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------- | +| [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator")(\[provider, target]) | Python implementation of a basic (non-efficient) quantum simulator. | + +## Provider + +| | | +| ------------------------------------------------------------------------------------------------------------------ | ----------------------------- | +| [`BasicProvider`](qiskit.providers.basic_provider.BasicProvider "qiskit.providers.basic_provider.BasicProvider")() | Provider for test simulators. | + +## Job Class + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------- | +| [`BasicProviderJob`](qiskit.providers.basic_provider.BasicProviderJob "qiskit.providers.basic_provider.BasicProviderJob")(backend, job\_id, result) | BasicProviderJob class. | + +## Exceptions + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------ | --------------------------------------------------- | +| [`BasicProviderError`](qiskit.providers.basic_provider.BasicProviderError "qiskit.providers.basic_provider.BasicProviderError")(\*message) | Base class for errors raised by the Basic Provider. | + diff --git a/docs/api/qiskit/0.46/providers_basicaer.md b/docs/api/qiskit/0.46/providers_basicaer.md new file mode 100644 index 00000000000..086ed85ad18 --- /dev/null +++ b/docs/api/qiskit/0.46/providers_basicaer.md @@ -0,0 +1,58 @@ +--- +title: basicaer +description: API reference for qiskit.providers.basicaer +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.providers.basicaer +--- + + + + + + + +# BasicAer: Python-based Simulators + + + +`qiskit.providers.basicaer` + + + The [`qiskit.providers.basicaer`](#module-qiskit.providers.basicaer "qiskit.providers.basicaer") module is deprecated as of Qiskit 0.46 and will be removed in Qiskit 1.0. Its functionality has been replaced by the new [`qiskit.providers.basic_provider`](providers_basic_provider#module-qiskit.providers.basic_provider "qiskit.providers.basic_provider") module and the [`qiskit.quantum_info`](quantum_info#module-qiskit.quantum_info "qiskit.quantum_info") module. + + +A module of Python-based quantum simulators. Simulators are accessed via the BasicAer provider, e.g.: + +```python +from qiskit import BasicAer + +backend = BasicAer.get_backend('qasm_simulator') +``` + +## Simulators + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------- | +| [`QasmSimulatorPy`](qiskit.providers.basicaer.QasmSimulatorPy "qiskit.providers.basicaer.QasmSimulatorPy")(\[configuration, provider]) | Python implementation of an OpenQASM 2 simulator. | +| [`StatevectorSimulatorPy`](qiskit.providers.basicaer.StatevectorSimulatorPy "qiskit.providers.basicaer.StatevectorSimulatorPy")(\[configuration, provider]) | Python statevector simulator. | +| [`UnitarySimulatorPy`](qiskit.providers.basicaer.UnitarySimulatorPy "qiskit.providers.basicaer.UnitarySimulatorPy")(\[configuration, provider]) | Python implementation of a unitary simulator. | + +## Provider + +| | | +| --------------------------------------------------------------------------------------------------------------- | -------------------------------- | +| [`BasicAerProvider`](qiskit.providers.basicaer.BasicAerProvider "qiskit.providers.basicaer.BasicAerProvider")() | Provider for Basic Aer backends. | + +## Job Class + +| | | +| ------------------------------------------------------------------------------------------------------------------------ | ------------------ | +| [`BasicAerJob`](qiskit.providers.basicaer.BasicAerJob "qiskit.providers.basicaer.BasicAerJob")(backend, job\_id, result) | BasicAerJob class. | + +## Exceptions + +| | | +| --------------------------------------------------------------------------------------------------------------- | ------------------------------------------ | +| [`BasicAerError`](qiskit.providers.basicaer.BasicAerError "qiskit.providers.basicaer.BasicAerError")(\*message) | Base class for errors raised by Basic Aer. | + diff --git a/docs/api/qiskit/0.46/providers_fake_provider.md b/docs/api/qiskit/0.46/providers_fake_provider.md new file mode 100644 index 00000000000..e03e312b370 --- /dev/null +++ b/docs/api/qiskit/0.46/providers_fake_provider.md @@ -0,0 +1,265 @@ +--- +title: fake_provider +description: API reference for qiskit.providers.fake_provider +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.providers.fake_provider +--- + + + + + + + +# Fake Provider + + + +`qiskit.providers.fake_provider` + +## Overview + +The fake provider module contains fake providers, fake backends and other simulated backend implementations. The fake backends are built to mimic the behaviors of IBM Quantum systems using system snapshots. The system snapshots contain important information about the quantum system such as coupling map, basis gates, qubit properties (T1, T2, error rate, etc.) which are useful for testing the transpiler and performing noisy simulation of the system. + +## Example Usage + +Here is an example of using a fake backend for transpilation and simulation. + +```python +from qiskit import QuantumCircuit +from qiskit.providers.fake_provider import FakeManilaV2 +from qiskit import transpile +from qiskit.tools.visualization import plot_histogram + + +# Get a fake backend from the fake provider +backend = FakeManilaV2() + +# Create a simple circuit +circuit = QuantumCircuit(3) +circuit.h(0) +circuit.cx(0,1) +circuit.cx(0,2) +circuit.measure_all() +circuit.draw('mpl') + +# Transpile the ideal circuit to a circuit that can be directly executed by the backend +transpiled_circuit = transpile(circuit, backend) +transpiled_circuit.draw('mpl') + +# Run the transpiled circuit using the simulated fake backend +job = backend.run(transpiled_circuit) +counts = job.result().get_counts() +plot_histogram(counts) +``` + +![../\_images/providers\_fake\_provider-1\_00.png](/images/api/qiskit/0.46/providers_fake_provider-1_00.png) + +![../\_images/providers\_fake\_provider-1\_01.png](/images/api/qiskit/0.46/providers_fake_provider-1_01.png) + +![../\_images/providers\_fake\_provider-1\_02.png](/images/api/qiskit/0.46/providers_fake_provider-1_02.png) + + + Please note that the simulation is done using a noise model generated from system snapshots obtained in the past (sometimes a few years ago) and the results are not representative of the latest behaviours of the real quantum system which the fake backend is mimicking. If you want to run noisy simulations to compare with the real quantum system, please follow steps below to generate a simulator mimics a real quantum system with the latest calibration results. + + ```python + from qiskit.providers.ibmq import IBMQ + from qiskit_aer import AerSimulator + + # get a real backend from a real provider + provider = IBMQ.load_account() + backend = provider.get_backend('ibmq_manila') + + # generate a simulator that mimics the real quantum system with the latest calibration results + backend_sim = AerSimulator.from_backend(backend) + ``` + + +## Fake Providers + +Fake providers provide access to a list of fake backends. + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------ | +| [`FakeProviderForBackendV2`](qiskit.providers.fake_provider.FakeProviderForBackendV2 "qiskit.providers.fake_provider.FakeProviderForBackendV2")() | Fake provider containing fake V2 backends. | +| [`FakeProvider`](qiskit.providers.fake_provider.FakeProvider "qiskit.providers.fake_provider.FakeProvider")() | Fake provider containing fake V1 backends. | + +## Fake Backends + +### Fake V2 Backends + +Fake V2 backends are fake backends with IBM Quantum systems snapshots implemented with [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") interface. They are all subclasses of [`FakeBackendV2`](qiskit.providers.fake_provider.FakeBackendV2 "qiskit.providers.fake_provider.FakeBackendV2"). + +| | | +| ------------------------------------------------------------------------------------------------------------------------------- | ------------------------------- | +| [`FakeAlmadenV2`](qiskit.providers.fake_provider.FakeAlmadenV2 "qiskit.providers.fake_provider.FakeAlmadenV2")() | A fake Almaden V2 backend. | +| [`FakeArmonkV2`](qiskit.providers.fake_provider.FakeArmonkV2 "qiskit.providers.fake_provider.FakeArmonkV2")() | A fake 1 qubit backend. | +| [`FakeAthensV2`](qiskit.providers.fake_provider.FakeAthensV2 "qiskit.providers.fake_provider.FakeAthensV2")() | A fake 5 qubit backend. | +| [`FakeAuckland`](qiskit.providers.fake_provider.FakeAuckland "qiskit.providers.fake_provider.FakeAuckland")() | A fake 27 qubit backend. | +| [`FakeBelemV2`](qiskit.providers.fake_provider.FakeBelemV2 "qiskit.providers.fake_provider.FakeBelemV2")() | A fake 5 qubit backend. | +| [`FakeBoeblingenV2`](qiskit.providers.fake_provider.FakeBoeblingenV2 "qiskit.providers.fake_provider.FakeBoeblingenV2")() | A fake Boeblingen V2 backend. | +| [`FakeBogotaV2`](qiskit.providers.fake_provider.FakeBogotaV2 "qiskit.providers.fake_provider.FakeBogotaV2")() | A fake 5 qubit backend. | +| [`FakeBrooklynV2`](qiskit.providers.fake_provider.FakeBrooklynV2 "qiskit.providers.fake_provider.FakeBrooklynV2")() | A fake Brooklyn V2 backend. | +| [`FakeBurlingtonV2`](qiskit.providers.fake_provider.FakeBurlingtonV2 "qiskit.providers.fake_provider.FakeBurlingtonV2")() | A fake 5 qubit backend. | +| [`FakeCairoV2`](qiskit.providers.fake_provider.FakeCairoV2 "qiskit.providers.fake_provider.FakeCairoV2")() | A fake 27 qubit backend. | +| [`FakeCambridgeV2`](qiskit.providers.fake_provider.FakeCambridgeV2 "qiskit.providers.fake_provider.FakeCambridgeV2")() | A fake Cambridge backend. | +| [`FakeCasablancaV2`](qiskit.providers.fake_provider.FakeCasablancaV2 "qiskit.providers.fake_provider.FakeCasablancaV2")() | A fake 7 qubit backend. | +| [`FakeEssexV2`](qiskit.providers.fake_provider.FakeEssexV2 "qiskit.providers.fake_provider.FakeEssexV2")() | A fake 5 qubit backend. | +| [`FakeGeneva`](qiskit.providers.fake_provider.FakeGeneva "qiskit.providers.fake_provider.FakeGeneva")() | A fake 27 qubit backend. | +| [`FakeGuadalupeV2`](qiskit.providers.fake_provider.FakeGuadalupeV2 "qiskit.providers.fake_provider.FakeGuadalupeV2")() | A fake 16 qubit backend. | +| [`FakeHanoiV2`](qiskit.providers.fake_provider.FakeHanoiV2 "qiskit.providers.fake_provider.FakeHanoiV2")() | A fake 27 qubit backend. | +| [`FakeJakartaV2`](qiskit.providers.fake_provider.FakeJakartaV2 "qiskit.providers.fake_provider.FakeJakartaV2")() | A fake 7 qubit V2 backend. | +| [`FakeJohannesburgV2`](qiskit.providers.fake_provider.FakeJohannesburgV2 "qiskit.providers.fake_provider.FakeJohannesburgV2")() | A fake Johannesburg V2 backend. | +| [`FakeKolkataV2`](qiskit.providers.fake_provider.FakeKolkataV2 "qiskit.providers.fake_provider.FakeKolkataV2")() | A fake 27 qubit backend. | +| [`FakeLagosV2`](qiskit.providers.fake_provider.FakeLagosV2 "qiskit.providers.fake_provider.FakeLagosV2")() | A fake 7 qubit backend. | +| [`FakeLimaV2`](qiskit.providers.fake_provider.FakeLimaV2 "qiskit.providers.fake_provider.FakeLimaV2")() | A fake 5 qubit backend. | +| [`FakeLondonV2`](qiskit.providers.fake_provider.FakeLondonV2 "qiskit.providers.fake_provider.FakeLondonV2")() | A fake 5 qubit backend. | +| [`FakeManhattanV2`](qiskit.providers.fake_provider.FakeManhattanV2 "qiskit.providers.fake_provider.FakeManhattanV2")() | A fake Manhattan backend. | +| [`FakeManilaV2`](qiskit.providers.fake_provider.FakeManilaV2 "qiskit.providers.fake_provider.FakeManilaV2")() | A fake 5 qubit backend. | +| [`FakeMelbourneV2`](qiskit.providers.fake_provider.FakeMelbourneV2 "qiskit.providers.fake_provider.FakeMelbourneV2")() | A fake 14 qubit backend. | +| [`FakeMontrealV2`](qiskit.providers.fake_provider.FakeMontrealV2 "qiskit.providers.fake_provider.FakeMontrealV2")() | A fake 27 qubit backend. | +| [`FakeMumbaiV2`](qiskit.providers.fake_provider.FakeMumbaiV2 "qiskit.providers.fake_provider.FakeMumbaiV2")() | A fake 27 qubit backend. | +| [`FakeNairobiV2`](qiskit.providers.fake_provider.FakeNairobiV2 "qiskit.providers.fake_provider.FakeNairobiV2")() | A fake 7 qubit backend. | +| [`FakeOslo`](qiskit.providers.fake_provider.FakeOslo "qiskit.providers.fake_provider.FakeOslo")() | A fake 7 qubit backend. | +| [`FakeOurenseV2`](qiskit.providers.fake_provider.FakeOurenseV2 "qiskit.providers.fake_provider.FakeOurenseV2")() | A fake 5 qubit backend. | +| [`FakeParisV2`](qiskit.providers.fake_provider.FakeParisV2 "qiskit.providers.fake_provider.FakeParisV2")() | A fake Paris backend. | +| [`FakePerth`](qiskit.providers.fake_provider.FakePerth "qiskit.providers.fake_provider.FakePerth")() | A fake 7 qubit backend. | +| [`FakePrague`](qiskit.providers.fake_provider.FakePrague "qiskit.providers.fake_provider.FakePrague")() | A fake 33 qubit backend. | +| [`FakePoughkeepsieV2`](qiskit.providers.fake_provider.FakePoughkeepsieV2 "qiskit.providers.fake_provider.FakePoughkeepsieV2")() | A fake Poughkeepsie backend. | +| [`FakeQuitoV2`](qiskit.providers.fake_provider.FakeQuitoV2 "qiskit.providers.fake_provider.FakeQuitoV2")() | A fake 5 qubit backend. | +| [`FakeRochesterV2`](qiskit.providers.fake_provider.FakeRochesterV2 "qiskit.providers.fake_provider.FakeRochesterV2")() | A fake Rochester backend. | +| [`FakeRomeV2`](qiskit.providers.fake_provider.FakeRomeV2 "qiskit.providers.fake_provider.FakeRomeV2")() | A fake 5 qubit backend. | +| [`FakeSantiagoV2`](qiskit.providers.fake_provider.FakeSantiagoV2 "qiskit.providers.fake_provider.FakeSantiagoV2")() | A fake Santiago backend. | +| [`FakeSherbrooke`](qiskit.providers.fake_provider.FakeSherbrooke "qiskit.providers.fake_provider.FakeSherbrooke")() | A fake 127 qubit backend. | +| [`FakeSingaporeV2`](qiskit.providers.fake_provider.FakeSingaporeV2 "qiskit.providers.fake_provider.FakeSingaporeV2")() | A fake Singapore backend. | +| [`FakeSydneyV2`](qiskit.providers.fake_provider.FakeSydneyV2 "qiskit.providers.fake_provider.FakeSydneyV2")() | A fake 27 qubit backend. | +| [`FakeTorontoV2`](qiskit.providers.fake_provider.FakeTorontoV2 "qiskit.providers.fake_provider.FakeTorontoV2")() | A fake 27 qubit backend. | +| [`FakeValenciaV2`](qiskit.providers.fake_provider.FakeValenciaV2 "qiskit.providers.fake_provider.FakeValenciaV2")() | A fake 5 qubit backend. | +| [`FakeVigoV2`](qiskit.providers.fake_provider.FakeVigoV2 "qiskit.providers.fake_provider.FakeVigoV2")() | A fake 5 qubit backend. | +| [`FakeWashingtonV2`](qiskit.providers.fake_provider.FakeWashingtonV2 "qiskit.providers.fake_provider.FakeWashingtonV2")() | A fake 127 qubit backend. | +| [`FakeYorktownV2`](qiskit.providers.fake_provider.FakeYorktownV2 "qiskit.providers.fake_provider.FakeYorktownV2")() | A fake 5 qubit backend. | + +### Fake V1 Backends + +Fake V1 backends are fake backends with IBM Quantum systems snapshots implemented with [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.backend.BackendV1") interface. + +| | | +| ------------------------------------------------------------------------------------------------------------------------- | ---------------------------- | +| [`FakeAlmaden`](qiskit.providers.fake_provider.FakeAlmaden "qiskit.providers.fake_provider.FakeAlmaden")() | A fake Almaden backend. | +| [`FakeArmonk`](qiskit.providers.fake_provider.FakeArmonk "qiskit.providers.fake_provider.FakeArmonk")() | A fake 1 qubit backend. | +| [`FakeAthens`](qiskit.providers.fake_provider.FakeAthens "qiskit.providers.fake_provider.FakeAthens")() | A fake 5 qubit backend. | +| [`FakeBelem`](qiskit.providers.fake_provider.FakeBelem "qiskit.providers.fake_provider.FakeBelem")() | A fake 5 qubit backend. | +| [`FakeBoeblingen`](qiskit.providers.fake_provider.FakeBoeblingen "qiskit.providers.fake_provider.FakeBoeblingen")() | A fake Boeblingen backend. | +| [`FakeBogota`](qiskit.providers.fake_provider.FakeBogota "qiskit.providers.fake_provider.FakeBogota")() | A fake 5 qubit backend. | +| [`FakeBrooklyn`](qiskit.providers.fake_provider.FakeBrooklyn "qiskit.providers.fake_provider.FakeBrooklyn")() | A fake Brooklyn backend. | +| [`FakeBurlington`](qiskit.providers.fake_provider.FakeBurlington "qiskit.providers.fake_provider.FakeBurlington")() | A fake 5 qubit backend. | +| [`FakeCairo`](qiskit.providers.fake_provider.FakeCairo "qiskit.providers.fake_provider.FakeCairo")() | A fake 27 qubit backend. | +| [`FakeCambridge`](qiskit.providers.fake_provider.FakeCambridge "qiskit.providers.fake_provider.FakeCambridge")() | A fake Cambridge backend. | +| [`FakeCasablanca`](qiskit.providers.fake_provider.FakeCasablanca "qiskit.providers.fake_provider.FakeCasablanca")() | A fake 7 qubit backend. | +| [`FakeEssex`](qiskit.providers.fake_provider.FakeEssex "qiskit.providers.fake_provider.FakeEssex")() | A fake 5 qubit backend. | +| [`FakeGuadalupe`](qiskit.providers.fake_provider.FakeGuadalupe "qiskit.providers.fake_provider.FakeGuadalupe")() | A fake 16 qubit backend. | +| [`FakeHanoi`](qiskit.providers.fake_provider.FakeHanoi "qiskit.providers.fake_provider.FakeHanoi")() | A fake 27 qubit backend. | +| [`FakeJakarta`](qiskit.providers.fake_provider.FakeJakarta "qiskit.providers.fake_provider.FakeJakarta")() | A fake 7 qubit backend. | +| [`FakeJohannesburg`](qiskit.providers.fake_provider.FakeJohannesburg "qiskit.providers.fake_provider.FakeJohannesburg")() | A fake Johannesburg backend. | +| [`FakeKolkata`](qiskit.providers.fake_provider.FakeKolkata "qiskit.providers.fake_provider.FakeKolkata")() | A fake 27 qubit backend. | +| [`FakeLagos`](qiskit.providers.fake_provider.FakeLagos "qiskit.providers.fake_provider.FakeLagos")() | A fake 7 qubit backend. | +| [`FakeLima`](qiskit.providers.fake_provider.FakeLima "qiskit.providers.fake_provider.FakeLima")() | A fake 5 qubit backend. | +| [`FakeLondon`](qiskit.providers.fake_provider.FakeLondon "qiskit.providers.fake_provider.FakeLondon")() | A fake 5 qubit backend. | +| [`FakeManhattan`](qiskit.providers.fake_provider.FakeManhattan "qiskit.providers.fake_provider.FakeManhattan")() | A fake Manhattan backend. | +| [`FakeManila`](qiskit.providers.fake_provider.FakeManila "qiskit.providers.fake_provider.FakeManila")() | A fake 5 qubit backend. | +| [`FakeMelbourne`](qiskit.providers.fake_provider.FakeMelbourne "qiskit.providers.fake_provider.FakeMelbourne")() | A fake 14 qubit backend. | +| [`FakeMontreal`](qiskit.providers.fake_provider.FakeMontreal "qiskit.providers.fake_provider.FakeMontreal")() | A fake 27 qubit backend. | +| [`FakeMumbai`](qiskit.providers.fake_provider.FakeMumbai "qiskit.providers.fake_provider.FakeMumbai")() | A fake 27 qubit backend. | +| [`FakeNairobi`](qiskit.providers.fake_provider.FakeNairobi "qiskit.providers.fake_provider.FakeNairobi")() | A fake 7 qubit backend. | +| [`FakeOurense`](qiskit.providers.fake_provider.FakeOurense "qiskit.providers.fake_provider.FakeOurense")() | A fake 5 qubit backend. | +| [`FakeParis`](qiskit.providers.fake_provider.FakeParis "qiskit.providers.fake_provider.FakeParis")() | A fake Paris backend. | +| [`FakePoughkeepsie`](qiskit.providers.fake_provider.FakePoughkeepsie "qiskit.providers.fake_provider.FakePoughkeepsie")() | A fake Poughkeepsie backend. | +| [`FakeQuito`](qiskit.providers.fake_provider.FakeQuito "qiskit.providers.fake_provider.FakeQuito")() | A fake 5 qubit backend. | +| [`FakeRochester`](qiskit.providers.fake_provider.FakeRochester "qiskit.providers.fake_provider.FakeRochester")() | A fake Rochester backend. | +| [`FakeRome`](qiskit.providers.fake_provider.FakeRome "qiskit.providers.fake_provider.FakeRome")() | A fake 5 qubit backend. | +| [`FakeRueschlikon`](qiskit.providers.fake_provider.FakeRueschlikon "qiskit.providers.fake_provider.FakeRueschlikon")() | A fake 16 qubit backend. | +| [`FakeSantiago`](qiskit.providers.fake_provider.FakeSantiago "qiskit.providers.fake_provider.FakeSantiago")() | A fake Santiago backend. | +| [`FakeSingapore`](qiskit.providers.fake_provider.FakeSingapore "qiskit.providers.fake_provider.FakeSingapore")() | A fake Singapore backend. | +| [`FakeSydney`](qiskit.providers.fake_provider.FakeSydney "qiskit.providers.fake_provider.FakeSydney")() | A fake 27 qubit backend. | +| [`FakeTenerife`](qiskit.providers.fake_provider.FakeTenerife "qiskit.providers.fake_provider.FakeTenerife")() | A fake 5 qubit backend. | +| [`FakeTokyo`](qiskit.providers.fake_provider.FakeTokyo "qiskit.providers.fake_provider.FakeTokyo")() | A fake 20 qubit backend. | +| [`FakeToronto`](qiskit.providers.fake_provider.FakeToronto "qiskit.providers.fake_provider.FakeToronto")() | A fake 27 qubit backend. | +| [`FakeValencia`](qiskit.providers.fake_provider.FakeValencia "qiskit.providers.fake_provider.FakeValencia")() | A fake 5 qubit backend. | +| [`FakeVigo`](qiskit.providers.fake_provider.FakeVigo "qiskit.providers.fake_provider.FakeVigo")() | A fake 5 qubit backend. | +| [`FakeWashington`](qiskit.providers.fake_provider.FakeWashington "qiskit.providers.fake_provider.FakeWashington")() | A fake 127 qubit backend. | +| [`FakeYorktown`](qiskit.providers.fake_provider.FakeYorktown "qiskit.providers.fake_provider.FakeYorktown")() | A fake 5 qubit backend. | + +## Special Fake Backends + +Special fake backends are fake backends that were created for special testing purposes. + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------ | +| [`FakeQasmSimulator`](qiskit.providers.fake_provider.FakeQasmSimulator "qiskit.providers.fake_provider.FakeQasmSimulator")() | A fake simulator backend. | +| [`FakeOpenPulse2Q`](qiskit.providers.fake_provider.FakeOpenPulse2Q "qiskit.providers.fake_provider.FakeOpenPulse2Q")() | A fake 2 qubit backend for pulse test. | +| [`FakeOpenPulse3Q`](qiskit.providers.fake_provider.FakeOpenPulse3Q "qiskit.providers.fake_provider.FakeOpenPulse3Q")() | Trivial extension of the FakeOpenPulse2Q. | +| [`Fake1Q`](qiskit.providers.fake_provider.Fake1Q "qiskit.providers.fake_provider.Fake1Q")() | A fake 1Q backend. | +| [`FakeBackendV2`](qiskit.providers.fake_provider.FakeBackendV2 "qiskit.providers.fake_provider.FakeBackendV2")() | A mock backend that doesn't implement run() to test compatibility with Terra internals. | +| [`FakeBackend5QV2`](qiskit.providers.fake_provider.FakeBackend5QV2 "qiskit.providers.fake_provider.FakeBackend5QV2")(\[bidirectional]) | A mock backend that doesn't implement run() to test compatibility with Terra internals. | +| [`FakeMumbaiFractionalCX`](qiskit.providers.fake_provider.FakeMumbaiFractionalCX "qiskit.providers.fake_provider.FakeMumbaiFractionalCX")() | A fake mumbai backend. | +| [`ConfigurableFakeBackend`](qiskit.providers.fake_provider.ConfigurableFakeBackend "qiskit.providers.fake_provider.ConfigurableFakeBackend")(name, n\_qubits\[, ...]) | Configurable backend. | +| [`GenericBackendV2`](qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2")(num\_qubits\[, basis\_gates, ...]) | Generic [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") implementation with a configurable constructor. | + +## Fake Backend Base Classes + +The fake backends based on IBM hardware are based on a set of base classes: + + + +`qiskit.providers.fake_provider.fake_backend.FakeBackendV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_backend.py "view source code") + +A fake backend class for testing and noisy simulation using real backend snapshots. + +The class inherits [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") class. This version differs from earlier [`FakeBackend`](#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.FakeBackend") (V1) class in a few aspects. Firstly, configuration attribute no longer exists. Instead, attributes exposing equivalent required immutable properties of the backend device are added. For example `fake_backend.configuration().n_qubits` is accessible from `fake_backend.num_qubits` now. Secondly, this version removes extra abstractions [`FakeQasmBackend`](#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.FakeQasmBackend") and [`FakePulseBackend`](#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.FakePulseBackend") that were present in V1. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + + + +`qiskit.providers.fake_provider.FakeBackend(configuration, time_alive=10)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_backend.py "view source code") + +This is a dummy backend just for testing purposes. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + + + +`qiskit.providers.fake_provider.FakeQasmBackend`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_qasm_backend.py "view source code") + +A fake OpenQASM backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + + + +`qiskit.providers.fake_provider.FakePulseBackend`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_pulse_backend.py "view source code") + +A fake pulse backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + diff --git a/docs/api/qiskit/0.46/providers_models.md b/docs/api/qiskit/0.46/providers_models.md new file mode 100644 index 00000000000..0816d353708 --- /dev/null +++ b/docs/api/qiskit/0.46/providers_models.md @@ -0,0 +1,39 @@ +--- +title: models +description: API reference for qiskit.providers.models +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.providers.models +--- + + + + + + + +# Backend Objects + + + +`qiskit.providers.models` + +Qiskit schema-conformant objects used by the backends and providers. + +## Backend Objects + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------- | +| [`BackendConfiguration`](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")(backend\_name, ...\[, ...]) | Backwards compat shim representing an abstract backend configuration. | +| [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")(backend\_name, ...) | Class representing backend properties | +| [`BackendStatus`](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus")(backend\_name, backend\_version, ...) | Class representing Backend Status. | +| [`QasmBackendConfiguration`](qiskit.providers.models.QasmBackendConfiguration "qiskit.providers.models.QasmBackendConfiguration")(backend\_name, ...) | Class representing an OpenQASM 2.0 Backend Configuration. | +| [`PulseBackendConfiguration`](qiskit.providers.models.PulseBackendConfiguration "qiskit.providers.models.PulseBackendConfiguration")(backend\_name, ...) | Static configuration state for an OpenPulse enabled backend. | +| [`UchannelLO`](qiskit.providers.models.UchannelLO "qiskit.providers.models.UchannelLO")(q, scale) | Class representing a U Channel LO | +| [`GateConfig`](qiskit.providers.models.GateConfig "qiskit.providers.models.GateConfig")(name, parameters, qasm\_def\[, ...]) | Class representing a Gate Configuration | +| [`PulseDefaults`](qiskit.providers.models.PulseDefaults "qiskit.providers.models.PulseDefaults")(qubit\_freq\_est, meas\_freq\_est, ...) | Description of default settings for Pulse systems. | +| [`Command`](qiskit.providers.models.Command "qiskit.providers.models.Command")(name\[, qubits, sequence]) | Class representing a Command. | +| [`JobStatus`](qiskit.providers.models.JobStatus "qiskit.providers.models.JobStatus")(job\_id, status, status\_msg, \*\*kwargs) | Model for JobStatus. | +| [`GateProperties`](qiskit.providers.models.GateProperties "qiskit.providers.models.GateProperties")(qubits, gate, parameters, ...) | Class representing a gate's properties | +| [`Nduv`](qiskit.providers.models.Nduv "qiskit.providers.models.Nduv")(date, name, unit, value) | Class representing name-date-unit-value | + diff --git a/docs/api/qiskit/0.46/pulse.md b/docs/api/qiskit/0.46/pulse.md new file mode 100644 index 00000000000..5ffda402d4f --- /dev/null +++ b/docs/api/qiskit/0.46/pulse.md @@ -0,0 +1,2798 @@ +--- +title: pulse +description: API reference for qiskit.pulse +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.pulse +--- + + + + + + + +# Pulse + + + +`qiskit.pulse` + +Qiskit-Pulse is a pulse-level quantum programming kit. This lower level of programming offers the user more control than programming with [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")s. + +Extracting the greatest performance from quantum hardware requires real-time pulse-level instructions. Pulse answers that need: it enables the quantum physicist *user* to specify the exact time dynamics of an experiment. It is especially powerful for error mitigation techniques. + +The input is given as arbitrary, time-ordered signals (see: [Instructions](#pulse-insts)) scheduled in parallel over multiple virtual hardware or simulator resources (see: [Channels](#pulse-channels)). The system also allows the user to recover the time dynamics of the measured output. + +This is sufficient to allow the quantum physicist to explore and correct for noise in a quantum system. + + + + + + + +## Instructions + + + +`qiskit.pulse.instructions` + +The `instructions` module holds the various [`Instruction`](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.Instruction")s which are supported by Qiskit Pulse. Instructions have operands, which typically include at least one [`Channel`](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") specifying where the instruction will be applied. + +Every instruction has a duration, whether explicitly included as an operand or implicitly defined. For instance, a [`ShiftPhase`](qiskit.pulse.instructions.ShiftPhase "qiskit.pulse.instructions.ShiftPhase") instruction can be instantiated with operands *phase* and *channel*, for some float `phase` and a [`Channel`](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") `channel`: + +```python +ShiftPhase(phase, channel) +``` + +The duration of this instruction is implicitly zero. On the other hand, the [`Delay`](qiskit.pulse.instructions.Delay "qiskit.pulse.instructions.Delay") instruction takes an explicit duration: + +```python +Delay(duration, channel) +``` + +An instruction can be added to a [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"), which is a sequence of scheduled Pulse `Instruction` s over many channels. `Instruction` s and `Schedule` s implement the same interface. + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------ | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`Acquire`](qiskit.pulse.instructions.Acquire "qiskit.pulse.instructions.Acquire")(duration, channel\[, mem\_slot, ...]) | The Acquire instruction is used to trigger the ADC associated with a particular qubit; e.g. | +| [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call")(subroutine\[, value\_dict, name]) | Pulse `Call` instruction. | +| [`Reference`](qiskit.pulse.instructions.Reference "qiskit.pulse.instructions.Reference")(name, \*extra\_keys) | Pulse compiler directive that refers to a subroutine. | +| [`Delay`](qiskit.pulse.instructions.Delay "qiskit.pulse.instructions.Delay")(duration, channel\[, name]) | A blocking instruction with no other effect. | +| [`Play`](qiskit.pulse.instructions.Play "qiskit.pulse.instructions.Play")(pulse, channel\[, name]) | This instruction is responsible for applying a pulse on a channel. | +| [`RelativeBarrier`](qiskit.pulse.instructions.RelativeBarrier "qiskit.pulse.instructions.RelativeBarrier")(\*channels\[, name]) | Pulse `RelativeBarrier` directive. | +| [`SetFrequency`](qiskit.pulse.instructions.SetFrequency "qiskit.pulse.instructions.SetFrequency")(frequency, channel\[, name]) | Set the channel frequency. | +| [`ShiftFrequency`](qiskit.pulse.instructions.ShiftFrequency "qiskit.pulse.instructions.ShiftFrequency")(frequency, channel\[, name]) | Shift the channel frequency away from the current frequency. | +| [`SetPhase`](qiskit.pulse.instructions.SetPhase "qiskit.pulse.instructions.SetPhase")(phase, channel\[, name]) | The set phase instruction sets the phase of the proceeding pulses on that channel to `phase` radians. | +| [`ShiftPhase`](qiskit.pulse.instructions.ShiftPhase "qiskit.pulse.instructions.ShiftPhase")(phase, channel\[, name]) | The shift phase instruction updates the modulation phase of proceeding pulses played on the same [`Channel`](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel"). | +| [`Snapshot`](qiskit.pulse.instructions.Snapshot "qiskit.pulse.instructions.Snapshot")(label\[, snapshot\_type, name]) | An instruction targeted for simulators, to capture a moment in the simulation. | +| [`TimeBlockade`](qiskit.pulse.instructions.TimeBlockade "qiskit.pulse.instructions.TimeBlockade")(duration, channel\[, name]) | Pulse `TimeBlockade` directive. | + +These are all instances of the same base class: + + + +`qiskit.pulse.instructions.Instruction(operands, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/instruction.py "view source code") + +The smallest schedulable unit: a single instruction. It has a fixed duration and specified channels. + +Instruction initializer. + +**Parameters** + +* **operands** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")) – The argument list. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Optional display name for this instruction. + + + + + +## Pulse Library + + + +`qiskit.pulse.library` + +This library provides Pulse users with convenient methods to build Pulse waveforms. + +A pulse programmer can choose from one of several [Pulse Models](#pulse-models) such as [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform") and [`SymbolicPulse`](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") to create a pulse program. The [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform") model directly stores the waveform data points in each class instance. This model provides the most flexibility to express arbitrary waveforms and allows a rapid prototyping of new control techniques. However, this model is typically memory inefficient and might be hard to scale to large-size quantum processors. Several waveform subclasses are defined by [Waveform Pulse Representation](#waveforms), but a user can also directly instantiate the [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform") class with `samples` argument which is usually a complex numpy array or any kind of array-like data. + +In contrast, the [`SymbolicPulse`](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") model only stores the function and its parameters that generate the waveform in a class instance. It thus provides greater memory efficiency at the price of less flexibility in the waveform. This model also defines a small set of pulse subclasses in [Parametric Pulse Representation](#symbolic-pulses) which are commonly used in superconducting quantum processors. An instance of these subclasses can be serialized in the [QPY Format](qpy#qpy-format) while keeping the memory-efficient parametric representation of waveforms. Note that [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform") object can be generated from an instance of a [`SymbolicPulse`](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") which will set values for the parameters and sample the parametric expression to create the [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + + + +### Pulse Models + +| | | +| ------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------- | +| [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform")(samples\[, name, epsilon, ...]) | A pulse specified completely by complex-valued samples; each sample is played for the duration of the backend cycle-time, dt. | +| [`SymbolicPulse`](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse")(pulse\_type, duration\[, ...]) | The pulse representation model with parameters and symbolic expressions. | +| [`ParametricPulse`](qiskit.pulse.library.ParametricPulse "qiskit.pulse.library.ParametricPulse")(duration\[, name, ...]) | The abstract superclass for parametric pulses. | + + + +### Waveform Pulse Representation + +### constant + + + +`qiskit.pulse.library.constant(duration, amp, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates constant-sampled [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp`, samples from the function: + +$$ +f(x) = A +$$ + + + The function `qiskit.pulse.library.discrete.constant()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including constant() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Constant(…).get\_waveform(). Note that complex value support for the amp parameter is deprecated in the SymbolicPulse library. Use two float values for (amp, angle) instead of complex amp + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Complex pulse amplitude. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### zero + + + +`qiskit.pulse.library.zero(duration, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates zero-sampled [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +Samples from the function: + +$$ +f(x) = 0 +$$ + + + The function `qiskit.pulse.library.discrete.zero()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including zero() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Constant(amp=0,…).get\_waveform(). + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### square + + + +`qiskit.pulse.library.square(duration, amp, freq=None, phase=0, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates square wave [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp`, $T=$ `period`, and $\phi=$ `phase`, applies the midpoint sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = A \text{sign}\left[ \sin\left(\frac{2 \pi x}{T} + 2\phi\right) \right] +$$ + +with the convention $\text{sign}(0) = 1$. + + + The function `qiskit.pulse.library.discrete.square()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including square() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Square(…).get\_waveform(). Note that pulse.Square() does not support complex values for amp, and that the phase is defined differently. See documentation. + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude. Wave range is $[-$ `amp` $,$ `amp` $]$. +* **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse frequency, units of 1./dt. If `None` defaults to 1./duration. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse phase. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### sawtooth + + + +`qiskit.pulse.library.sawtooth(duration, amp, freq=None, phase=0, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates sawtooth wave [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp`, $T=$ `period`, and $\phi=$ `phase`, applies the midpoint sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = 2 A \left( g(x) - \left\lfloor \frac{1}{2} + g(x) \right\rfloor\right) +$$ + +where $g(x) = x/T + \phi/\pi$. + + + The function `qiskit.pulse.library.discrete.sawtooth()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including sawtooth() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Sawtooth(…).get\_waveform(). Note that pulse.Sawtooth() does not support complex values for amp. Instead, use two float values for (amp, angle). Also note that the phase is defined differently, such that 2\*pi phase shifts by a full cycle. + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude. Wave range is $[-$ `amp` $,$ `amp` $]$. +* **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse frequency, units of 1./dt. If `None` defaults to 1./duration. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse phase. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +**Example** + +```python +import matplotlib.pyplot as plt +from qiskit.pulse.library import sawtooth +import numpy as np + +duration = 100 +amp = 1 +freq = 1 / duration +sawtooth_wave = np.real(sawtooth(duration, amp, freq).samples) +plt.plot(range(duration), sawtooth_wave) +plt.show() +``` + +![../\_images/pulse-1.png](/images/api/qiskit/0.46/pulse-1.png) + +### triangle + + + +`qiskit.pulse.library.triangle(duration, amp, freq=None, phase=0, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates triangle wave [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp`, $T=$ `period`, and $\phi=$ `phase`, applies the midpoint sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = A \left(-2\left|\text{sawtooth}(x, A, T, \phi)\right| + 1\right) +$$ + +This a non-sinusoidal wave with linear ramping. + + + The function `qiskit.pulse.library.discrete.triangle()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including triangle() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Triangle(…).get\_waveform(). Note that pulse.Triangle() does not support complex values for amp. Instead, use two float values for (amp, angle). + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude. Wave range is $[-$ `amp` $,$ `amp` $]$. +* **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse frequency, units of 1./dt. If `None` defaults to 1./duration. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse phase. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +**Example** + +```python +import matplotlib.pyplot as plt +from qiskit.pulse.library import triangle +import numpy as np + +duration = 100 +amp = 1 +freq = 1 / duration +triangle_wave = np.real(triangle(duration, amp, freq).samples) +plt.plot(range(duration), triangle_wave) +plt.show() +``` + +![../\_images/pulse-2.png](/images/api/qiskit/0.46/pulse-2.png) + +### cos + + + +`qiskit.pulse.library.cos(duration, amp, freq=None, phase=0, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates cosine wave [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp`, $\omega=$ `freq`, and $\phi=$ `phase`, applies the midpoint sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = A \cos(2 \pi \omega x + \phi) +$$ + + + The function `qiskit.pulse.library.discrete.cos()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including cos() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Cos(…).get\_waveform(). Note that pulse.Cos() does not support complex values for amp. Instead, use two float values for (amp, angle). + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude. +* **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse frequency, units of 1/dt. If `None` defaults to single cycle. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse phase. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### sin + + + +`qiskit.pulse.library.sin(duration, amp, freq=None, phase=0, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates sine wave [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp`, $\omega=$ `freq`, and $\phi=$ `phase`, applies the midpoint sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = A \sin(2 \pi \omega x + \phi) +$$ + + + The function `qiskit.pulse.library.discrete.sin()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including sin() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Sin(…).get\_waveform(). Note that pulse.Sin() does not support complex values for amp. Instead, use two float values for (amp, angle). + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude. +* **freq** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse frequency, units of 1/dt. If `None` defaults to single cycle. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse phase. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### gaussian + + + +`qiskit.pulse.library.gaussian(duration, amp, sigma, name=None, zero_ends=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates unnormalized gaussian [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp` and $\sigma=$ `sigma`, applies the `midpoint` sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = A\exp\left(\left(\frac{x - \mu}{2\sigma}\right)^2 \right), +$$ + +with the center $\mu=$ `duration/2`. + +If `zero_ends==True`, each output sample $y$ is modified according to: + +$$ +y \mapsto A\frac{y-y^*}{A-y^*}, +$$ + +where $y^*$ is the value of the endpoint samples. This sets the endpoints to $0$ while preserving the amplitude at the center. If $A=y^*$, $y$ is set to $1$. By default, the endpoints are at `x = -1, x = duration + 1`. + +Integrated area under the full curve is `amp * np.sqrt(2*np.pi*sigma**2)` + + + The function `qiskit.pulse.library.discrete.gaussian()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including gaussian() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Gaussian(…).get\_waveform(). Note that complex value support for the amp parameter is deprecated in the SymbolicPulse library. It is therefore recommended to use two float values for (amp, angle) instead of complex amp + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude at `duration/2`. +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width (standard deviation) of pulse. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. +* **zero\_ends** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, zero ends at `x = -1, x = duration + 1`, but rescale to preserve amp. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### gaussian\_deriv + + + +`qiskit.pulse.library.gaussian_deriv(duration, amp, sigma, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates unnormalized gaussian derivative [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp` and $\sigma=$ `sigma` applies the midpoint sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = -A\frac{(x - \mu)}{\sigma^2}\exp + \left(-\frac{1}{2}\left(\frac{x - \mu}{\sigma}\right)^2 \right) +$$ + +i.e. the derivative of the Gaussian function, with center $\mu=$ `duration/2`. + + + The function `qiskit.pulse.library.discrete.gaussian_deriv()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including gaussian\_deriv() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.GaussianDeriv(…).get\_waveform(). Note that pulse.GaussianDeriv() does not support complex values for amp. Instead, use two float values for (amp, angle). + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude of corresponding Gaussian at the pulse center (`duration/2`). +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width (standard deviation) of pulse. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### sech + + + +`qiskit.pulse.library.sech(duration, amp, sigma, name=None, zero_ends=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates unnormalized sech [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp` and $\sigma=$ `sigma`, applies the `midpoint` sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = A\text{sech}\left(\frac{x-\mu}{\sigma} \right) +$$ + +with the center $\mu=$ `duration/2`. + +If `zero_ends==True`, each output sample $y$ is modified according to: + +$$ +y \mapsto A\frac{y-y^*}{A-y^*}, +$$ + +where $y^*$ is the value of the endpoint samples. This sets the endpoints to $0$ while preserving the amplitude at the center. If $A=y^*$, $y$ is set to $1$. By default, the endpoints are at `x = -1, x = duration + 1`. + + + The function `qiskit.pulse.library.discrete.sech()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including sech() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Sech(…).get\_waveform(). Note that pulse.Sech() does not support complex values for amp. Instead, use two float values for (amp, angle). + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude at duration/2. +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width (standard deviation) of pulse. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of pulse. +* **zero\_ends** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, zero ends at `x = -1, x = duration + 1`, but rescale to preserve amp. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### sech\_deriv + + + +`qiskit.pulse.library.sech_deriv(duration, amp, sigma, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates unnormalized sech derivative [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $A=$ `amp`, $\sigma=$ `sigma`, and center $\mu=$ `duration/2`, applies the midpoint sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = \frac{d}{dx}\left[A\text{sech}\left(\frac{x-\mu}{\sigma} \right)\right], + + +$$ + +i.e. the derivative of $\text{sech}$. + + + The function `qiskit.pulse.library.discrete.sech_deriv()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including sech\_deriv() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.SechDeriv(…).get\_waveform(). Note that pulse.SechDeriv() does not support complex values for amp. Instead, use two float values for (amp, angle). + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude at center. +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width (standard deviation) of pulse. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of pulse. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### gaussian\_square + + + +`qiskit.pulse.library.gaussian_square(duration, amp, sigma, risefall=None, width=None, name=None, zero_ends=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates gaussian square [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). + +For $d=$ `duration`, $A=$ `amp`, $\sigma=$ `sigma`, and $r=$ `risefall`, applies the `midpoint` sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = \begin{cases} + g(x - r) ) & x\leq r \\ + A & r\leq x\leq d-r \\ + g(x - (d - r)) & d-r\leq x + \end{cases} +$$ + +where $g(x)$ is the Gaussian function sampled from in [`gaussian()`](#qiskit.pulse.library.gaussian "qiskit.pulse.library.gaussian") with $A=$ `amp`, $\mu=1$, and $\sigma=$ `sigma`. I.e. $f(x)$ represents a square pulse with smooth Gaussian edges. + +If `zero_ends == True`, the samples for the Gaussian ramps are remapped as in [`gaussian()`](#qiskit.pulse.library.gaussian "qiskit.pulse.library.gaussian"). + + + The function `qiskit.pulse.library.discrete.gaussian_square()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including gaussian\_square() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.GaussianSquare(…).get\_waveform(). Note that complex value support for the amp parameter is deprecated in the SymbolicPulse library. It is therefore recommended to use two float values for (amp, angle) instead of complex amp + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude. +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width (standard deviation) of Gaussian rise/fall portion of the pulse. +* **risefall** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Number of samples over which pulse rise and fall happen. Width of square portion of pulse will be `duration-2*risefall`. +* **width** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The duration of the embedded square pulse. Only one of `width` or `risefall` should be specified as the functional form requires `width = duration - 2 * risefall`. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. +* **zero\_ends** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, zero ends at `x = -1, x = duration + 1`, but rescale to preserve amp. + +**Raises** + +[**PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If `risefall` and `width` arguments are inconsistent or not enough info. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### drag + + + +`qiskit.pulse.library.drag(duration, amp, sigma, beta, name=None, zero_ends=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/discrete.py "view source code") + +Generates Y-only correction DRAG [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform") for standard nonlinear oscillator (SNO) \[1]. + +For $A=$ `amp`, $\sigma=$ `sigma`, and $\beta=$ `beta`, applies the `midpoint` sampling strategy to generate a discrete pulse sampled from the continuous function: + +$$ +f(x) = g(x) + i \beta h(x), +$$ + +where $g(x)$ is the function sampled in [`gaussian()`](#qiskit.pulse.library.gaussian "qiskit.pulse.library.gaussian"), and $h(x)$ is the function sampled in [`gaussian_deriv()`](#qiskit.pulse.library.gaussian_deriv "qiskit.pulse.library.gaussian_deriv"). + +If `zero_ends == True`, the samples from $g(x)$ are remapped as in [`gaussian()`](#qiskit.pulse.library.gaussian "qiskit.pulse.library.gaussian"). + + + The function `qiskit.pulse.library.discrete.drag()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. The discrete pulses library, including drag() is deprecated. Instead, use the SymbolicPulse library to create the waveform with pulse.Drag(…).get\_waveform(). Note that complex value support for the amp parameter is deprecated in the SymbolicPulse library. It is therefore recommended to use two float values for (amp, angle) instead of complex amp + + +**References** + +1. [*Gambetta, J. M., Motzoi, F., Merkel, S. T. & Wilhelm, F. K. “Analytic control methods for high-fidelity unitary operations in a weakly nonlinear oscillator.” Phys. Rev. A 83, 012308 (2011).*](http://dx.doi.org/10.1103/PhysRevA.83.012308) + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. Must be greater than zero. +* **amp** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Pulse amplitude at center `duration/2`. +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width (standard deviation) of pulse. +* **beta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Y correction amplitude. For the SNO this is $\beta=-\frac{\lambda_1^2}{4\Delta_2}$. Where $\lambda_1$ is the relative coupling strength between the first excited and second excited states and $\Delta_2$ is the detuning between the respective excited states. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse. +* **zero\_ends** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, zero ends at `x = -1, x = duration + 1`, but rescale to preserve amp. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + + + +### Parametric Pulse Representation + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`Constant`](qiskit.pulse.library.Constant_class.rst#qiskit.pulse.library.Constant "qiskit.pulse.library.Constant")(duration, amp\[, angle, name, ...]) | A simple constant pulse, with an amplitude value and a duration: | +| [`Drag`](qiskit.pulse.library.Drag_class.rst#qiskit.pulse.library.Drag "qiskit.pulse.library.Drag")(duration, amp, sigma, beta\[, angle, ...]) | The Derivative Removal by Adiabatic Gate (DRAG) pulse is a standard Gaussian pulse with an additional Gaussian derivative component and lifting applied. | +| [`Gaussian`](qiskit.pulse.library.Gaussian_class.rst#qiskit.pulse.library.Gaussian "qiskit.pulse.library.Gaussian")(duration, amp, sigma\[, angle, ...]) | A lifted and truncated pulse envelope shaped according to the Gaussian function whose mean is centered at the center of the pulse (duration / 2): | +| [`GaussianSquare`](qiskit.pulse.library.GaussianSquare "qiskit.pulse.library.GaussianSquare")(duration, amp, sigma\[, ...]) | A square pulse with a Gaussian shaped risefall on both sides lifted such that its first sample is zero. | +| [`GaussianSquareDrag`](qiskit.pulse.library.GaussianSquareDrag "qiskit.pulse.library.GaussianSquareDrag")(duration, amp, sigma, beta) | A square pulse with a Drag shaped rise and fall | +| [`gaussian_square_echo`](qiskit.pulse.library.gaussian_square_echo "qiskit.pulse.library.gaussian_square_echo")(duration, amp, sigma\[, ...]) | An echoed Gaussian square pulse with an active tone overlaid on it. | +| [`GaussianDeriv`](qiskit.pulse.library.GaussianDeriv "qiskit.pulse.library.GaussianDeriv")(duration, amp, sigma\[, angle, ...]) | An unnormalized Gaussian derivative pulse. | +| [`Sin`](qiskit.pulse.library.Sin_class.rst#qiskit.pulse.library.Sin "qiskit.pulse.library.Sin")(duration, amp, phase\[, freq, angle, ...]) | A sinusoidal pulse. | +| [`Cos`](qiskit.pulse.library.Cos_class.rst#qiskit.pulse.library.Cos "qiskit.pulse.library.Cos")(duration, amp, phase\[, freq, angle, ...]) | A cosine pulse. | +| [`Sawtooth`](qiskit.pulse.library.Sawtooth_class.rst#qiskit.pulse.library.Sawtooth "qiskit.pulse.library.Sawtooth")(duration, amp, phase\[, freq, ...]) | A sawtooth pulse. | +| [`Triangle`](qiskit.pulse.library.Triangle_class.rst#qiskit.pulse.library.Triangle "qiskit.pulse.library.Triangle")(duration, amp, phase\[, freq, ...]) | A triangle wave pulse. | +| [`Square`](qiskit.pulse.library.Square_fun.rst#qiskit.pulse.library.Square "qiskit.pulse.library.Square")(duration, amp, phase\[, freq, angle, ...]) | A square wave pulse. | +| [`Sech`](qiskit.pulse.library.Sech_fun.rst#qiskit.pulse.library.Sech "qiskit.pulse.library.Sech")(duration, amp, sigma\[, angle, name, ...]) | An unnormalized sech pulse. | +| [`SechDeriv`](qiskit.pulse.library.SechDeriv "qiskit.pulse.library.SechDeriv")(duration, amp, sigma\[, angle, ...]) | An unnormalized sech derivative pulse. | + + + + + + + +## Channels + + + +`qiskit.pulse.channels` + +Pulse is meant to be agnostic to the underlying hardware implementation, while still allowing low-level control. Therefore, our signal channels are *virtual* hardware channels. The backend which executes our programs is responsible for mapping these virtual channels to the proper physical channel within the quantum control hardware. + +Channels are characterized by their type and their index. Channels include: + +* transmit channels, which should subclass `PulseChannel` +* receive channels, such as [`AcquireChannel`](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") +* non-signal “channels” such as [`SnapshotChannel`](qiskit.pulse.channels.SnapshotChannel "qiskit.pulse.channels.SnapshotChannel"), [`MemorySlot`](qiskit.pulse.channels.MemorySlot "qiskit.pulse.channels.MemorySlot") and `RegisterChannel`. + +Novel channel types can often utilize the [`ControlChannel`](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel"), but if this is not sufficient, new channel types can be created. Then, they must be supported in the PulseQobj schema and the assembler. Channels are characterized by their type and their index. See each channel type below to learn more. + +| | | +| ---------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------- | +| [`DriveChannel`](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel")(\*args, \*\*kwargs) | Drive channels transmit signals to qubits which enact gate operations. | +| [`MeasureChannel`](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel")(\*args, \*\*kwargs) | Measure channels transmit measurement stimulus pulses for readout. | +| [`AcquireChannel`](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel")(\*args, \*\*kwargs) | Acquire channels are used to collect data. | +| [`ControlChannel`](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")(\*args, \*\*kwargs) | Control channels provide supplementary control over the qubit to the drive channel. | +| [`RegisterSlot`](qiskit.pulse.channels.RegisterSlot "qiskit.pulse.channels.RegisterSlot")(\*args, \*\*kwargs) | Classical resister slot channels represent classical registers (low-latency classical memory). | +| [`MemorySlot`](qiskit.pulse.channels.MemorySlot "qiskit.pulse.channels.MemorySlot")(\*args, \*\*kwargs) | Memory slot channels represent classical memory storage. | +| [`SnapshotChannel`](qiskit.pulse.channels.SnapshotChannel "qiskit.pulse.channels.SnapshotChannel")(\*args, \*\*kwargs) | Snapshot channels are used to specify instructions for simulators. | + +All channels are children of the same abstract base class: + + + +`qiskit.pulse.channels.Channel(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Base class of channels. Channels provide a Qiskit-side label for typical quantum control hardware signal channels. The final label -> physical channel mapping is the responsibility of the hardware backend. For instance, `DriveChannel(0)` holds instructions which the backend should map to the signal line driving gate operations on the qubit labeled (indexed) 0. + +When serialized channels are identified by their serialized name ``. The type of the channel is interpreted from the prefix, and the index often (but not always) maps to the qubit index. All concrete channel classes must have a `prefix` class attribute (and instances of that class have an index attribute). Base classes which have `prefix` set to `None` are prevented from being instantiated. + +To implement a new channel inherit from [`Channel`](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") and provide a unique string identifier for the `prefix` class attribute. + +Channel class. + +**Parameters** + +**index** – Index of channel. + + + +## Schedules + +Schedules are Pulse programs. They describe instruction sequences for the control hardware. The Schedule is one of the most fundamental objects to this pulse-level programming module. A `Schedule` is a representation of a *program* in Pulse. Each schedule tracks the time of each instruction occuring in parallel over multiple signal *channels*. + +| | | +| -------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule")(\*schedules\[, name, metadata]) | A quantum program *schedule* with exact time constraints for its instructions, operating over all input signal *channels* and supporting special syntaxes for building. | +| [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")(\[name, metadata, ...]) | Time-ordered sequence of instructions with alignment context. | + + + + + +## Pulse Transforms + + + +`qiskit.pulse.transforms` + +The pulse transforms provide transformation routines to reallocate and optimize pulse programs for backends. + + + +### Alignments + +The alignment transforms define alignment policies of instructions in [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"). These transformations are called to create [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule")s from [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")s. + +| | | +| ---------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------ | +| [`AlignEquispaced`](qiskit.pulse.transforms.AlignEquispaced "qiskit.pulse.transforms.AlignEquispaced")(duration) | Align instructions with equispaced interval within a specified duration. | +| [`AlignFunc`](qiskit.pulse.transforms.AlignFunc "qiskit.pulse.transforms.AlignFunc")(duration, func) | Allocate instructions at position specified by callback function. | +| [`AlignLeft`](qiskit.pulse.transforms.AlignLeft "qiskit.pulse.transforms.AlignLeft")() | Align instructions in as-soon-as-possible manner. | +| [`AlignRight`](qiskit.pulse.transforms.AlignRight "qiskit.pulse.transforms.AlignRight")() | Align instructions in as-late-as-possible manner. | +| [`AlignSequential`](qiskit.pulse.transforms.AlignSequential "qiskit.pulse.transforms.AlignSequential")() | Align instructions sequentially. | + +These are all subtypes of the abstract base class [`AlignmentKind`](#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.AlignmentKind"). + + + +`qiskit.pulse.transforms.AlignmentKind(context_params)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/alignments.py "view source code") + +An abstract class for schedule alignment. + +Create new context. + + + +### Canonicalization + +The canonicalization transforms convert schedules to a form amenable for execution on OpenPulse backends. + +### add\_implicit\_acquires + + + +`qiskit.pulse.transforms.add_implicit_acquires(schedule, meas_map)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Return a new schedule with implicit acquires from the measurement mapping replaced by explicit ones. + + + Since new acquires are being added, Memory Slots will be set to match the qubit index. This may overwrite your specification. + + +**Parameters** + +* **schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – Schedule to be aligned. +* **meas\_map** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – List of lists of qubits that are measured together. + +**Returns** + +A `Schedule` with the additional acquisition instructions. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### align\_measures + + + +`qiskit.pulse.transforms.align_measures(schedules, inst_map=None, cal_gate='u3', max_calibration_duration=None, align_time=None, align_all=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Return new schedules where measurements occur at the same physical time. + +This transformation will align the first [`Acquire`](qiskit.pulse.instructions.Acquire "qiskit.pulse.instructions.Acquire") on every channel to occur at the same time. + +Minimum measurement wait time (to allow for calibration pulses) is enforced and may be set with `max_calibration_duration`. + +By default only instructions containing a [`AcquireChannel`](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") or [`MeasureChannel`](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") will be shifted. If you wish to keep the relative timing of all instructions in the schedule set `align_all=True`. + +This method assumes that `MeasureChannel(i)` and `AcquireChannel(i)` correspond to the same qubit and the acquire/play instructions should be shifted together on these channels. + +```python +from qiskit import pulse +from qiskit.pulse import transforms + +d0 = pulse.DriveChannel(0) +m0 = pulse.MeasureChannel(0) +a0 = pulse.AcquireChannel(0) +mem0 = pulse.MemorySlot(0) + +sched = pulse.Schedule() +sched.append(pulse.Play(pulse.Constant(10, 0.5), d0), inplace=True) +sched.append(pulse.Play(pulse.Constant(10, 1.), m0).shift(sched.duration), inplace=True) +sched.append(pulse.Acquire(20, a0, mem0).shift(sched.duration), inplace=True) + +sched_shifted = sched << 20 + +aligned_sched, aligned_sched_shifted = transforms.align_measures([sched, sched_shifted]) + +assert aligned_sched == aligned_sched_shifted +``` + +If it is desired to only shift acquisition and measurement stimulus instructions set the flag `align_all=False`: + +```python +aligned_sched, aligned_sched_shifted = transforms.align_measures( + [sched, sched_shifted], + align_all=False, +) + +assert aligned_sched != aligned_sched_shifted +``` + +**Parameters** + +* **schedules** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")*]*) – Collection of schedules to be aligned together +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.instruction_schedule_map.InstructionScheduleMap") *| None*) – Mapping of circuit operations to pulse schedules +* **cal\_gate** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the gate to inspect for the calibration time +* **max\_calibration\_duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – If provided, inst\_map and cal\_gate will be ignored +* **align\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – If provided, this will be used as final align time. +* **align\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Shift all instructions in the schedule such that they maintain their relative alignment with the shifted acquisition instruction. If `False` only the acquisition and measurement pulse instructions will be shifted. + +**Returns** + +The input list of schedules transformed to have their measurements aligned. + +**Raises** + +[**PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the provided alignment time is negative. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")] + +### block\_to\_schedule + + + +`qiskit.pulse.transforms.block_to_schedule(block)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Convert `ScheduleBlock` to `Schedule`. + +**Parameters** + +**block** ([*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")) – A `ScheduleBlock` to convert. + +**Returns** + +Scheduled pulse program. + +**Raises** + +* [**UnassignedDurationError**](#qiskit.pulse.UnassignedDurationError "qiskit.pulse.UnassignedDurationError") – When any instruction duration is not assigned. +* [**PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When the alignment context duration is shorter than the schedule duration. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + + + This transform may insert barriers in between contexts. + + +### compress\_pulses + + + +`qiskit.pulse.transforms.compress_pulses(schedules)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Optimization pass to replace identical pulses. + +**Parameters** + +**schedules** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")*]*) – Schedules to compress. + +**Returns** + +Compressed schedules. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")] + +### flatten + + + +`qiskit.pulse.transforms.flatten(program)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Flatten (inline) any called nodes into a Schedule tree with no nested children. + +**Parameters** + +**program** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – Pulse program to remove nested structure. + +**Returns** + +Flatten pulse program. + +**Raises** + +[**PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When invalid data format is given. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### inline\_subroutines + + + +`qiskit.pulse.transforms.inline_subroutines(program)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Recursively remove call instructions and inline the respective subroutine instructions. + +Assigned parameter values, which are stored in the parameter table, are also applied. The subroutine is copied before the parameter assignment to avoid mutation problem. + +**Parameters** + +**program** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")) – A program which may contain the subroutine, i.e. `Call` instruction. + +**Returns** + +A schedule without subroutine. + +**Raises** + +[**PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When input program is not valid data format. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") | [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### pad + + + +`qiskit.pulse.transforms.pad(schedule, channels=None, until=None, inplace=False, pad_with=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Pad the input Schedule with `Delay``s on all unoccupied timeslots until ``schedule.duration` or `until` if not `None`. + +**Parameters** + +* **schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – Schedule to pad. +* **channels** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Channel*](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – Channels to pad. Defaults to all channels in `schedule` if not provided. If the supplied channel is not a member of `schedule` it will be added. +* **until** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Time to pad until. Defaults to `schedule.duration` if not provided. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Pad this schedule by mutating rather than returning a new schedule. +* **pad\_with** ([*Type*](https://docs.python.org/3/library/typing.html#typing.Type "(in Python v3.12)")*\[*[*Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")*] | None*) – Pulse `Instruction` subclass to be used for padding. Default to [`Delay`](qiskit.pulse.instructions.Delay "qiskit.pulse.instructions.Delay") instruction. + +**Returns** + +The padded schedule. + +**Raises** + +[**PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When non pulse instruction is set to pad\_with. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### remove\_directives + + + +`qiskit.pulse.transforms.remove_directives(schedule)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Remove directives. + +**Parameters** + +**schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – A schedule to remove compiler directives. + +**Returns** + +A schedule without directives. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### remove\_trivial\_barriers + + + +`qiskit.pulse.transforms.remove_trivial_barriers(schedule)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/canonicalization.py "view source code") + +Remove trivial barriers with 0 or 1 channels. + +**Parameters** + +**schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – A schedule to remove trivial barriers. + +**Returns** + +A schedule without trivial barriers + +**Return type** + +schedule + + + +### DAG + +The DAG transforms create DAG representation of input program. This can be used for optimization of instructions and equality checks. + +### block\_to\_dag + + + +`qiskit.pulse.transforms.block_to_dag(block)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/dag.py "view source code") + +Convert schedule block instruction into DAG. + +`ScheduleBlock` can be represented as a DAG as needed. For example, equality of two programs are efficiently checked on DAG representation. + +```python +with pulse.build() as sched1: + with pulse.align_left(): + pulse.play(my_gaussian0, pulse.DriveChannel(0)) + pulse.shift_phase(1.57, pulse.DriveChannel(2)) + pulse.play(my_gaussian1, pulse.DriveChannel(1)) + +with pulse.build() as sched2: + with pulse.align_left(): + pulse.shift_phase(1.57, pulse.DriveChannel(2)) + pulse.play(my_gaussian1, pulse.DriveChannel(1)) + pulse.play(my_gaussian0, pulse.DriveChannel(0)) +``` + +Here the `sched1 `` and ``sched2` are different implementations of the same program, but it is difficult to confirm on the list representation. + +Another example is instruction optimization. + +```python +with pulse.build() as sched: + with pulse.align_left(): + pulse.shift_phase(1.57, pulse.DriveChannel(1)) + pulse.play(my_gaussian0, pulse.DriveChannel(0)) + pulse.shift_phase(-1.57, pulse.DriveChannel(1)) +``` + +In above program two `shift_phase` instructions can be cancelled out because they are consecutive on the same drive channel. This can be easily found on the DAG representation. + +**Parameters** + +**block** (*"ScheduleBlock"*) – A schedule block to be converted. + +**Returns** + +Instructions in DAG representation. + +**Raises** + +[**PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When the context is invalid subclass. + +**Return type** + +[*PyDAG*](https://www.rustworkx.org/apiref/rustworkx.PyDAG.html#rustworkx.PyDAG "(in rustworkx v0.14.0)") + + + +### Composite transform + +A sequence of transformations to generate a target code. + +### target\_qobj\_transform + + + +`qiskit.pulse.transforms.target_qobj_transform(sched, remove_directives=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/base_transforms.py "view source code") + +A basic pulse program transformation for OpenPulse API execution. + +**Parameters** + +* **sched** ([*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *|*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")*] |* [*Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")*] |* [*Instruction*](#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")*]*) – Input program to transform. +* **remove\_directives** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set True to remove compiler directives. + +**Returns** + +Transformed program for execution. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + + + + + +## Pulse Builder + +Use the pulse builder DSL to write pulse programs with an imperative syntax. + + + The pulse builder interface is still in active development. It may have breaking API changes without deprecation warnings in future releases until otherwise indicated. + + +The pulse builder provides an imperative API for writing pulse programs with less difficulty than the [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") API. It contextually constructs a pulse schedule and then emits the schedule for execution. For example, to play a series of pulses on channels is as simple as: + +```python +from qiskit import pulse + +dc = pulse.DriveChannel +d0, d1, d2, d3, d4 = dc(0), dc(1), dc(2), dc(3), dc(4) + +with pulse.build(name='pulse_programming_in') as pulse_prog: + pulse.play([1, 1, 1, 0, 0, 1, 1, 1, 0, 1, 1, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0, 1, 1, 1], d0) + pulse.play([1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0], d1) + pulse.play([1, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0], d2) + pulse.play([1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 1, 1, 0, 0, 0, 1, 0, 0, 0, 1, 0], d3) + pulse.play([1, 1, 1, 1, 0, 1, 1, 1, 0, 1, 1, 1, 0, 1, 0, 1, 0, 1, 1, 1, 0, 0, 1, 0], d4) + +pulse_prog.draw() +``` + +![../\_images/pulse-3.png](/images/api/qiskit/0.46/pulse-3.png) + +To begin pulse programming we must first initialize our program builder context with [`build()`](#qiskit.pulse.builder.build "qiskit.pulse.builder.build"), after which we can begin adding program statements. For example, below we write a simple program that [`play()`](#qiskit.pulse.builder.play "qiskit.pulse.builder.play")s a pulse: + +```python +from qiskit import execute, pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.play(pulse.Constant(100, 1.0), d0) + +pulse_prog.draw() +``` + +![../\_images/pulse-4.png](/images/api/qiskit/0.46/pulse-4.png) + +The builder initializes a [`pulse.Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"), `pulse_prog` and then begins to construct the program within the context. The output pulse schedule will survive after the context is exited and can be executed like a normal Qiskit schedule using `qiskit.execute(pulse_prog, backend)`. + +Pulse programming has a simple imperative style. This leaves the programmer to worry about the raw experimental physics of pulse programming and not constructing cumbersome data structures. + +We can optionally pass a [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") to [`build()`](#qiskit.pulse.builder.build "qiskit.pulse.builder.build") to enable enhanced functionality. Below, we prepare a Bell state by automatically compiling the required pulses from their gate-level representations, while simultaneously applying a long decoupling pulse to a neighboring qubit. We terminate the experiment with a measurement to observe the state we prepared. This program which mixes circuits and pulses will be automatically lowered to be run as a pulse program: + +```python +import math + +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse3Q + +# TODO: This example should use a real mock backend. +backend = FakeOpenPulse3Q() + +d2 = pulse.DriveChannel(2) + +with pulse.build(backend) as bell_prep: + pulse.u2(0, math.pi, 0) + pulse.cx(0, 1) + +with pulse.build(backend) as decoupled_bell_prep_and_measure: + # We call our bell state preparation schedule constructed above. + with pulse.align_right(): + pulse.call(bell_prep) + pulse.play(pulse.Constant(bell_prep.duration, 0.02), d2) + pulse.barrier(0, 1, 2) + registers = pulse.measure_all() + +decoupled_bell_prep_and_measure.draw() +``` + +![../\_images/pulse-5.png](/images/api/qiskit/0.46/pulse-5.png) + + + Calling gates directly within the pulse builder namespace is deprecated as of qiskit 0.46.0. + + +With the pulse builder we are able to blend programming on qubits and channels. While the pulse schedule is based on instructions that operate on channels, the pulse builder automatically handles the mapping from qubits to channels for you. + +In the example below we demonstrate some more features of the pulse builder: + +```python +import math + +from qiskit import pulse, QuantumCircuit +from qiskit.pulse import library +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend) as pulse_prog: + # Create a pulse. + gaussian_pulse = library.gaussian(10, 1.0, 2) + # Get the qubit's corresponding drive channel from the backend. + d0 = pulse.drive_channel(0) + d1 = pulse.drive_channel(1) + # Play a pulse at t=0. + pulse.play(gaussian_pulse, d0) + # Play another pulse directly after the previous pulse at t=10. + pulse.play(gaussian_pulse, d0) + # The default scheduling behavior is to schedule pulses in parallel + # across channels. For example, the statement below + # plays the same pulse on a different channel at t=0. + pulse.play(gaussian_pulse, d1) + + # We also provide pulse scheduling alignment contexts. + # The default alignment context is align_left. + + # The sequential context schedules pulse instructions sequentially in time. + # This context starts at t=10 due to earlier pulses above. + with pulse.align_sequential(): + pulse.play(gaussian_pulse, d0) + # Play another pulse after at t=20. + pulse.play(gaussian_pulse, d1) + + # We can also nest contexts as each instruction is + # contained in its local scheduling context. + # The output of a child context is a context-schedule + # with the internal instructions timing fixed relative to + # one another. This is schedule is then called in the parent context. + + # Context starts at t=30. + with pulse.align_left(): + # Start at t=30. + pulse.play(gaussian_pulse, d0) + # Start at t=30. + pulse.play(gaussian_pulse, d1) + # Context ends at t=40. + + # Alignment context where all pulse instructions are + # aligned to the right, ie., as late as possible. + with pulse.align_right(): + # Shift the phase of a pulse channel. + pulse.shift_phase(math.pi, d1) + # Starts at t=40. + pulse.delay(100, d0) + # Ends at t=140. + + # Starts at t=130. + pulse.play(gaussian_pulse, d1) + # Ends at t=140. + + # Acquire data for a qubit and store in a memory slot. + pulse.acquire(100, 0, pulse.MemorySlot(0)) + + # We also support a variety of macros for common operations. + + # Measure all qubits. + pulse.measure_all() + + # Delay on some qubits. + # This requires knowledge of which channels belong to which qubits. + # delay for 100 cycles on qubits 0 and 1. + pulse.delay_qubits(100, 0, 1) + + # Call a quantum circuit. The pulse builder lazily constructs a quantum + # circuit which is then transpiled and scheduled before inserting into + # a pulse schedule. + # NOTE: Quantum register indices correspond to physical qubit indices. + qc = QuantumCircuit(2, 2) + qc.cx(0, 1) + pulse.call(qc) + # Calling a small set of standard gates and decomposing to pulses is + # also supported with more natural syntax. + pulse.u3(0, math.pi, 0, 0) + pulse.cx(0, 1) + + + # It is also be possible to call a preexisting schedule + tmp_sched = pulse.Schedule() + tmp_sched += pulse.Play(gaussian_pulse, d0) + pulse.call(tmp_sched) + + # We also support: + + # frequency instructions + pulse.set_frequency(5.0e9, d0) + + # phase instructions + pulse.shift_phase(0.1, d0) + + # offset contexts + with pulse.phase_offset(math.pi, d0): + pulse.play(gaussian_pulse, d0) +``` + + + Calling gates directly within the pulse builder namespace is deprecated as of qiskit 0.46.0. + + +The above is just a small taste of what is possible with the builder. See the rest of the module documentation for more information on its capabilities. + +### build + + + +`qiskit.pulse.builder.build(backend=None, schedule=None, name=None, default_alignment='left', default_transpiler_settings=None, default_circuit_scheduler_settings=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Create a context manager for launching the imperative pulse builder DSL. + +To enter a building context and starting building a pulse program: + +```python +from qiskit import transpile, pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.play(pulse.Constant(100, 0.5), d0) +``` + +While the output program `pulse_prog` cannot be executed as we are using a mock backend. If a real backend is being used, executing the program is done with: + +```python +backend.run(transpile(pulse_prog, backend)) +``` + + + `qiskit.pulse.builder.build()`’s argument `default_circuit_scheduler_settings` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. setting parameter `default_circuit_scheduler_settings` in build() was used for gate operations, which are deprecated. pulse schedules should only be used for gate calibrations as part of a quantum circuit, and not vice versa + + + + `qiskit.pulse.builder.build()`’s argument `default_transpiler_settings` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. setting parameter `default_transpiler_settings` in build() was used for gate operations, which are deprecated. pulse schedules should only be used for gate calibrations as part of a quantum circuit, and not vice versa + + +**Parameters** + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – A Qiskit backend. If not supplied certain builder functionality will be unavailable. +* **schedule** ([*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *| None*) – A pulse `ScheduleBlock` in which your pulse program will be built. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of pulse program to be built. +* **default\_alignment** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*AlignmentKind*](#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") *| None*) – Default scheduling alignment for builder. One of `left`, `right`, `sequential` or an alignment context. +* **default\_transpiler\_settings** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Default settings for the transpiler. +* **default\_circuit\_scheduler\_settings** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Default settings for the circuit to pulse scheduler. + +**Returns** + +A new builder context which has the active builder initialized. + +**Return type** + +[*ContextManager*](https://docs.python.org/3/library/typing.html#typing.ContextManager "(in Python v3.12)")\[[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")] + +### Channels + +Methods to return the correct channels for the respective qubit indices. + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeArmonk + +backend = FakeArmonk() + +with pulse.build(backend) as drive_sched: + d0 = pulse.drive_channel(0) + print(d0) +``` + +```python +DriveChannel(0) +``` + +### acquire\_channel + + + +`qiskit.pulse.builder.acquire_channel(qubit)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Return `AcquireChannel` for `qubit` on the active builder backend. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend): + assert pulse.acquire_channel(0) == pulse.AcquireChannel(0) +``` + + + Requires the active builder context to have a backend set. + + +**Return type** + +[*AcquireChannel*](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channels + + + +`qiskit.pulse.builder.control_channels(*qubits)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Return `ControlChannel` for `qubit` on the active builder backend. + +Return the secondary drive channel for the given qubit – typically utilized for controlling multi-qubit interactions. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() +with pulse.build(backend): + assert pulse.control_channels(0, 1) == [pulse.ControlChannel(0)] +``` + + + Requires the active builder context to have a backend set. + + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of ordered qubits of the form (control\_qubit, target\_qubit). + +**Returns** + +List of control channels associated with the supplied ordered list of qubits. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*ControlChannel*](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`qiskit.pulse.builder.drive_channel(qubit)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Return `DriveChannel` for `qubit` on the active builder backend. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend): + assert pulse.drive_channel(0) == pulse.DriveChannel(0) +``` + + + Requires the active builder context to have a backend set. + + +**Return type** + +[*DriveChannel*](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`qiskit.pulse.builder.measure_channel(qubit)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Return `MeasureChannel` for `qubit` on the active builder backend. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend): + assert pulse.measure_channel(0) == pulse.MeasureChannel(0) +``` + + + Requires the active builder context to have a backend set. + + +**Return type** + +[*MeasureChannel*](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### Instructions + +Pulse instructions are available within the builder interface. Here’s an example: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeArmonk + +backend = FakeArmonk() + +with pulse.build(backend) as drive_sched: + d0 = pulse.drive_channel(0) + a0 = pulse.acquire_channel(0) + + pulse.play(pulse.library.Constant(10, 1.0), d0) + pulse.delay(20, d0) + pulse.shift_phase(3.14/2, d0) + pulse.set_phase(3.14, d0) + pulse.shift_frequency(1e7, d0) + pulse.set_frequency(5e9, d0) + + with pulse.build() as temp_sched: + pulse.play(pulse.library.Gaussian(20, 1.0, 3.0), d0) + pulse.play(pulse.library.Gaussian(20, -1.0, 3.0), d0) + + pulse.call(temp_sched) + pulse.acquire(30, a0, pulse.MemorySlot(0)) + +drive_sched.draw() +``` + +![../\_images/pulse-6.png](/images/api/qiskit/0.46/pulse-6.png) + +### acquire + + + +`qiskit.pulse.builder.acquire(duration, qubit_or_channel, register, **metadata)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Acquire for a `duration` on a `channel` and store the result in a `register`. + +Examples: + +```python +from qiskit import pulse + +acq0 = pulse.AcquireChannel(0) +mem0 = pulse.MemorySlot(0) + +with pulse.build() as pulse_prog: + pulse.acquire(100, acq0, mem0) + + # measurement metadata + kernel = pulse.configuration.Kernel('linear_discriminator') + pulse.acquire(100, acq0, mem0, kernel=kernel) +``` + + + The type of data acquire will depend on the execution `meas_level`. + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration to acquire data for +* **qubit\_or\_channel** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*AcquireChannel*](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel")) – Either the qubit to acquire data for or the specific [`AcquireChannel`](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") to acquire on. +* **register** (*StorageLocation*) – Location to store measured result. +* **metadata** (*Kernel | Discriminator*) – Additional metadata for measurement. See [`Acquire`](qiskit.pulse.instructions.Acquire "qiskit.pulse.instructions.Acquire") for more information. + +**Raises** + +[**exceptions.PulseError**](#qiskit.pulse.PulseError "qiskit.pulse.exceptions.PulseError") – If the register type is not supported. + +### barrier + + + +`qiskit.pulse.builder.barrier(*channels_or_qubits, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Barrier directive for a set of channels and qubits. + +This directive prevents the compiler from moving instructions across the barrier. Consider the case where we want to enforce that one pulse happens after another on separate channels, this can be done with: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +d0 = pulse.DriveChannel(0) +d1 = pulse.DriveChannel(1) + +with pulse.build(backend) as barrier_pulse_prog: + pulse.play(pulse.Constant(10, 1.0), d0) + pulse.barrier(d0, d1) + pulse.play(pulse.Constant(10, 1.0), d1) +``` + +Of course this could have been accomplished with: + +```python +from qiskit.pulse import transforms + +with pulse.build(backend) as aligned_pulse_prog: + with pulse.align_sequential(): + pulse.play(pulse.Constant(10, 1.0), d0) + pulse.play(pulse.Constant(10, 1.0), d1) + +barrier_pulse_prog = transforms.target_qobj_transform(barrier_pulse_prog) +aligned_pulse_prog = transforms.target_qobj_transform(aligned_pulse_prog) + +assert barrier_pulse_prog == aligned_pulse_prog +``` + +The barrier allows the pulse compiler to take care of more advanced scheduling alignment operations across channels. For example in the case where we are calling an outside circuit or schedule and want to align a pulse at the end of one call: + +```python +import math + +d0 = pulse.DriveChannel(0) + +with pulse.build(backend) as pulse_prog: + with pulse.align_right(): + pulse.x(1) + # Barrier qubit 1 and d0. + pulse.barrier(1, d0) + # Due to barrier this will play before the gate on qubit 1. + pulse.play(pulse.Constant(10, 1.0), d0) + # This will end at the same time as the pulse above due to + # the barrier. + pulse.x(1) +``` + + + Requires the active builder context to have a backend set if qubits are barriered on. + + +**Parameters** + +* **channels\_or\_qubits** ([*Channel*](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Channels or qubits to barrier. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name for the barrier + +### call + + + +`qiskit.pulse.builder.call(target, name=None, value_dict=None, **kw_params)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Call the subroutine within the currently active builder context with arbitrary parameters which will be assigned to the target program. + + + If the `target` program is a [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), then a [`Reference`](qiskit.pulse.instructions.Reference "qiskit.pulse.instructions.Reference") instruction will be created and appended to the current context. The `target` program will be immediately assigned to the current scope as a subroutine. If the `target` program is [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"), it will be wrapped by the [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call") instruction and appended to the current context to avoid a mixed representation of [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") and [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"). If the `target` program is a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") it will be scheduled and the new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") will be added as a [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call") instruction. + + + + QuantumCircuit type for the argument target is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. ScheduleBlock should only be used for gate calibrations in a quantum circuit. Thus, the called quantum circuit should be added to the main circuit instead of to the ScheduleBlock. + + +**Examples** + +1. Calling a schedule block (recommended) + +```python +from qiskit import circuit, pulse +from qiskit.providers.fake_provider import FakeBogotaV2 + +backend = FakeBogotaV2() + +with pulse.build() as x_sched: + pulse.play(pulse.Gaussian(160, 0.1, 40), pulse.DriveChannel(0)) + +with pulse.build() as pulse_prog: + pulse.call(x_sched) + +print(pulse_prog) +``` + +```python +ScheduleBlock( + ScheduleBlock( + Play( + Gaussian(duration=160, amp=(0.1+0j), sigma=40), + DriveChannel(0) + ), + name="block0", + transform=AlignLeft() + ), + name="block1", + transform=AlignLeft() +) +``` + +The actual program is stored in the reference table attached to the schedule. + +```python +print(pulse_prog.references) +``` + +```python +ReferenceManager: + - ('block0', '634b3b50bd684e26a673af1fbd2d6c81'): ScheduleBlock(Play(Gaussian(... +``` + +In addition, you can call a parameterized target program with parameter assignment. + +```python +amp = circuit.Parameter("amp") + +with pulse.build() as subroutine: + pulse.play(pulse.Gaussian(160, amp, 40), pulse.DriveChannel(0)) + +with pulse.build() as pulse_prog: + pulse.call(subroutine, amp=0.1) + pulse.call(subroutine, amp=0.3) + +print(pulse_prog) +``` + +```python +ScheduleBlock( + ScheduleBlock( + Play( + Gaussian(duration=160, amp=(0.1+0j), sigma=40), + DriveChannel(0) + ), + name="block2", + transform=AlignLeft() + ), + ScheduleBlock( + Play( + Gaussian(duration=160, amp=(0.3+0j), sigma=40), + DriveChannel(0) + ), + name="block2", + transform=AlignLeft() + ), + name="block3", + transform=AlignLeft() +) +``` + +If there is a name collision between parameters, you can distinguish them by specifying each parameter object in a python dictionary. For example, + +```python +amp1 = circuit.Parameter('amp') +amp2 = circuit.Parameter('amp') + +with pulse.build() as subroutine: + pulse.play(pulse.Gaussian(160, amp1, 40), pulse.DriveChannel(0)) + pulse.play(pulse.Gaussian(160, amp2, 40), pulse.DriveChannel(1)) + +with pulse.build() as pulse_prog: + pulse.call(subroutine, value_dict={amp1: 0.1, amp2: 0.3}) + +print(pulse_prog) +``` + +```python +ScheduleBlock( + ScheduleBlock( + Play(Gaussian(duration=160, amp=(0.1+0j), sigma=40), DriveChannel(0)), + Play(Gaussian(duration=160, amp=(0.3+0j), sigma=40), DriveChannel(1)), + name="block4", + transform=AlignLeft() + ), + name="block5", + transform=AlignLeft() +) +``` + +2. Calling a schedule + +```python +x_sched = backend.instruction_schedule_map.get("x", (0,)) + +with pulse.build(backend) as pulse_prog: + pulse.call(x_sched) + +print(pulse_prog) +``` + +```python +ScheduleBlock( + Call( + Schedule( + ( + 0, + Play( + Drag( + duration=160, + amp=(0.18989731546729305+0j), + sigma=40, + beta=-1.201258305015517, + name='drag_86a8' + ), + DriveChannel(0), + name='drag_86a8' + ) + ), + name="x" + ), + name='x' + ), + name="block6", + transform=AlignLeft() +) +``` + +Currently, the backend calibrated gates are provided in the form of [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"). The parameter assignment mechanism is available also for schedules. However, the called schedule is not treated as a reference. + + + Calling a circuit from a schedule is deprecated as of qiskit 0.46.0. The Qiskit execution model has migrating toward the pulse gate model, where schedules are attached to circuits through the [`QuantumCircuit.add_calibration()`](qiskit.circuit.QuantumCircuit#add_calibration "qiskit.circuit.QuantumCircuit.add_calibration") method. Thus, instead of calling a circuit into the schedule, it should instead be added to the main circuit. + + +**Parameters** + +* **target** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *| None*) – Target circuit or pulse schedule to call. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Optional. A unique name of subroutine if defined. When the name is explicitly provided, one cannot call different schedule blocks with the same name. +* **value\_dict** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Optional. Parameters assigned to the `target` program. If this dictionary is provided, the `target` program is copied and then stored in the main built schedule and its parameters are assigned to the given values. This dictionary is keyed on [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects, allowing parameter name collision to be avoided. +* **kw\_params** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Alternative way to provide parameters. Since this is keyed on the string parameter name, the parameters having the same name are all updated together. If you want to avoid name collision, use `value_dict` with [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects instead. + +### delay + + + +`qiskit.pulse.builder.delay(duration, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Delay on a `channel` for a `duration`. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.delay(10, d0) +``` + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of cycles to delay for on `channel`. +* **channel** ([*Channel*](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – Channel to delay on. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the instruction. + +### play + + + +`qiskit.pulse.builder.play(pulse, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Play a `pulse` on a `channel`. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.play(pulse.Constant(10, 1.0), d0) +``` + +**Parameters** + +* **pulse** (*Pulse |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Pulse to play. +* **channel** (*PulseChannel*) – Channel to play pulse on. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the pulse. + +### reference + + + +`qiskit.pulse.builder.reference(name, *extra_keys)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Refer to undefined subroutine by string keys. + +A [`Reference`](qiskit.pulse.instructions.Reference "qiskit.pulse.instructions.Reference") instruction is implicitly created and a schedule can be separately registered to the reference at a later stage. + +```python +from qiskit import pulse + +with pulse.build() as main_prog: + pulse.reference("x_gate", "q0") + +with pulse.build() as subroutine: + pulse.play(pulse.Gaussian(160, 0.1, 40), pulse.DriveChannel(0)) + +main_prog.assign_references(subroutine_dict={("x_gate", "q0"): subroutine}) +``` + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of subroutine. +* **extra\_keys** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Helper keys to uniquely specify the subroutine. + +### set\_frequency + + + +`qiskit.pulse.builder.set_frequency(frequency, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Set the `frequency` of a pulse `channel`. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.set_frequency(1e9, d0) +``` + +**Parameters** + +* **frequency** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Frequency in Hz to set channel to. +* **channel** (*PulseChannel*) – Channel to set frequency of. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the instruction. + +### set\_phase + + + +`qiskit.pulse.builder.set_phase(phase, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Set the `phase` of a pulse `channel`. + +Examples: + +```python +import math + +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.set_phase(math.pi, d0) +``` + +**Parameters** + +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Phase in radians to set channel carrier signal to. +* **channel** (*PulseChannel*) – Channel to set phase of. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the instruction. + +### shift\_frequency + + + +`qiskit.pulse.builder.shift_frequency(frequency, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Shift the `frequency` of a pulse `channel`. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.shift_frequency(1e9, d0) +``` + +**Parameters** + +* **frequency** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Frequency in Hz to shift channel frequency by. +* **channel** (*PulseChannel*) – Channel to shift frequency of. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the instruction. + +### shift\_phase + + + +`qiskit.pulse.builder.shift_phase(phase, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Shift the `phase` of a pulse `channel`. + +Examples: + +```python +import math + +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + pulse.shift_phase(math.pi, d0) +``` + +**Parameters** + +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Phase in radians to shift channel carrier signal by. +* **channel** (*PulseChannel*) – Channel to shift phase of. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the instruction. + +### snapshot + + + +`qiskit.pulse.builder.snapshot(label, snapshot_type='statevector')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Simulator snapshot. + +Examples: + +```python +from qiskit import pulse + +with pulse.build() as pulse_prog: + pulse.snapshot('first', 'statevector') +``` + +**Parameters** + +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Label for snapshot. +* **snapshot\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Type of snapshot. + +### Contexts + +Builder aware contexts that modify the construction of a pulse program. For example an alignment context like [`align_right()`](#qiskit.pulse.builder.align_right "qiskit.pulse.builder.align_right") may be used to align all pulses as late as possible in a pulse program. + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) +d1 = pulse.DriveChannel(1) + +with pulse.build() as pulse_prog: + with pulse.align_right(): + # this pulse will start at t=0 + pulse.play(pulse.Constant(100, 1.0), d0) + # this pulse will start at t=80 + pulse.play(pulse.Constant(20, 1.0), d1) + +pulse_prog.draw() +``` + +![../\_images/pulse-7.png](/images/api/qiskit/0.46/pulse-7.png) + +### align\_equispaced + + + +`qiskit.pulse.builder.align_equispaced(duration)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Equispaced alignment pulse scheduling context. + +Pulse instructions within this context are scheduled with the same interval spacing such that the total length of the context block is `duration`. If the total free `duration` cannot be evenly divided by the number of instructions within the context, the modulo is split and then prepended and appended to the returned schedule. Delay instructions are automatically inserted in between pulses. + +This context is convenient to write a schedule for periodical dynamic decoupling or the Hahn echo sequence. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) +x90 = pulse.Gaussian(10, 0.1, 3) +x180 = pulse.Gaussian(10, 0.2, 3) + +with pulse.build() as hahn_echo: + with pulse.align_equispaced(duration=100): + pulse.play(x90, d0) + pulse.play(x180, d0) + pulse.play(x90, d0) + +hahn_echo.draw() +``` + +![../\_images/pulse-8.png](/images/api/qiskit/0.46/pulse-8.png) + +**Parameters** + +**duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Duration of this context. This should be larger than the schedule duration. + +**Yields** + +None + +**Return type** + +[*AlignmentKind*](#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +**Notes** + +The scheduling is performed for sub-schedules within the context rather than channel-wise. If you want to apply the equispaced context for each channel, you should use the context independently for channels. + +### align\_func + + + +`qiskit.pulse.builder.align_func(duration, func)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Callback defined alignment pulse scheduling context. + +Pulse instructions within this context are scheduled at the location specified by arbitrary callback function position that takes integer index and returns the associated fractional location within \[0, 1]. Delay instruction is automatically inserted in between pulses. + +This context may be convenient to write a schedule of arbitrary dynamical decoupling sequences such as Uhrig dynamical decoupling. + +Examples: + +```python +import numpy as np +from qiskit import pulse + +d0 = pulse.DriveChannel(0) +x90 = pulse.Gaussian(10, 0.1, 3) +x180 = pulse.Gaussian(10, 0.2, 3) + +def udd10_pos(j): + return np.sin(np.pi*j/(2*10 + 2))**2 + +with pulse.build() as udd_sched: + pulse.play(x90, d0) + with pulse.align_func(duration=300, func=udd10_pos): + for _ in range(10): + pulse.play(x180, d0) + pulse.play(x90, d0) + +udd_sched.draw() +``` + +![../\_images/pulse-9.png](/images/api/qiskit/0.46/pulse-9.png) + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Duration of context. This should be larger than the schedule duration. +* **func** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – A function that takes an index of sub-schedule and returns the fractional coordinate of of that sub-schedule. The returned value should be defined within \[0, 1]. The pulse index starts from 1. + +**Yields** + +None + +**Return type** + +[*AlignmentKind*](#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +**Notes** + +The scheduling is performed for sub-schedules within the context rather than channel-wise. If you want to apply the numerical context for each channel, you need to apply the context independently to channels. + +### align\_left + + + +`qiskit.pulse.builder.align_left()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Left alignment pulse scheduling context. + +Pulse instructions within this context are scheduled as early as possible by shifting them left to the earliest available time. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) +d1 = pulse.DriveChannel(1) + +with pulse.build() as pulse_prog: + with pulse.align_left(): + # this pulse will start at t=0 + pulse.play(pulse.Constant(100, 1.0), d0) + # this pulse will start at t=0 + pulse.play(pulse.Constant(20, 1.0), d1) +pulse_prog = pulse.transforms.block_to_schedule(pulse_prog) + +assert pulse_prog.ch_start_time(d0) == pulse_prog.ch_start_time(d1) +``` + +**Yields** + +None + +**Return type** + +[*ContextManager*](https://docs.python.org/3/library/typing.html#typing.ContextManager "(in Python v3.12)")\[None] + +### align\_right + + + +`qiskit.pulse.builder.align_right()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Right alignment pulse scheduling context. + +Pulse instructions within this context are scheduled as late as possible by shifting them right to the latest available time. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) +d1 = pulse.DriveChannel(1) + +with pulse.build() as pulse_prog: + with pulse.align_right(): + # this pulse will start at t=0 + pulse.play(pulse.Constant(100, 1.0), d0) + # this pulse will start at t=80 + pulse.play(pulse.Constant(20, 1.0), d1) +pulse_prog = pulse.transforms.block_to_schedule(pulse_prog) + +assert pulse_prog.ch_stop_time(d0) == pulse_prog.ch_stop_time(d1) +``` + +**Yields** + +None + +**Return type** + +[*AlignmentKind*](#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +### align\_sequential + + + +`qiskit.pulse.builder.align_sequential()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Sequential alignment pulse scheduling context. + +Pulse instructions within this context are scheduled sequentially in time such that no two instructions will be played at the same time. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) +d1 = pulse.DriveChannel(1) + +with pulse.build() as pulse_prog: + with pulse.align_sequential(): + # this pulse will start at t=0 + pulse.play(pulse.Constant(100, 1.0), d0) + # this pulse will also start at t=100 + pulse.play(pulse.Constant(20, 1.0), d1) +pulse_prog = pulse.transforms.block_to_schedule(pulse_prog) + +assert pulse_prog.ch_stop_time(d0) == pulse_prog.ch_start_time(d1) +``` + +**Yields** + +None + +**Return type** + +[*AlignmentKind*](#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +### circuit\_scheduler\_settings + + + +`qiskit.pulse.builder.circuit_scheduler_settings(**settings)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Set the currently active circuit scheduler settings for this context. + + + The function `qiskit.pulse.builder.circuit_scheduler_settings()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was used for gate operations, which are deprecated. pulse schedules should only be used for gate calibrations as part of a quantum circuit, and not vice versa + + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend): + print(pulse.active_circuit_scheduler_settings()) + with pulse.circuit_scheduler_settings(method='alap'): + print(pulse.active_circuit_scheduler_settings()) +``` + +```python +{} +{'method': 'alap'} +``` + +**Return type** + +[*ContextManager*](https://docs.python.org/3/library/typing.html#typing.ContextManager "(in Python v3.12)")\[None] + +### frequency\_offset + + + +`qiskit.pulse.builder.frequency_offset(frequency, *channels, compensate_phase=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Shift the frequency of inputs channels on entry into context and undo on exit. + +Examples: + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build(backend) as pulse_prog: + # shift frequency by 1GHz + with pulse.frequency_offset(1e9, d0): + pulse.play(pulse.Constant(10, 1.0), d0) + +assert len(pulse_prog.instructions) == 3 + +with pulse.build(backend) as pulse_prog: + # Shift frequency by 1GHz. + # Undo accumulated phase in the shifted frequency frame + # when exiting the context. + with pulse.frequency_offset(1e9, d0, compensate_phase=True): + pulse.play(pulse.Constant(10, 1.0), d0) + +assert len(pulse_prog.instructions) == 4 +``` + +**Parameters** + +* **frequency** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Amount of frequency offset in Hz. +* **channels** (*PulseChannel*) – Channels to offset frequency of. +* **compensate\_phase** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Compensate for accumulated phase accumulated with respect to the channels’ frame at its initial frequency. + +**Yields** + +None + +**Return type** + +[*ContextManager*](https://docs.python.org/3/library/typing.html#typing.ContextManager "(in Python v3.12)")\[None] + +### phase\_offset + + + +`qiskit.pulse.builder.phase_offset(phase, *channels)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Shift the phase of input channels on entry into context and undo on exit. + +Examples: + +```python +import math + +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +with pulse.build() as pulse_prog: + with pulse.phase_offset(math.pi, d0): + pulse.play(pulse.Constant(10, 1.0), d0) + +assert len(pulse_prog.instructions) == 3 +``` + +**Parameters** + +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Amount of phase offset in radians. +* **channels** (*PulseChannel*) – Channels to offset phase of. + +**Yields** + +None + +**Return type** + +[*ContextManager*](https://docs.python.org/3/library/typing.html#typing.ContextManager "(in Python v3.12)")\[None] + +### transpiler\_settings + + + +`qiskit.pulse.builder.transpiler_settings(**settings)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Set the currently active transpiler settings for this context. + + + The function `qiskit.pulse.builder.transpiler_settings()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was used for gate operations, which are deprecated. pulse schedules should only be used for gate calibrations as part of a quantum circuit, and not vice versa + + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend): + print(pulse.active_transpiler_settings()) + with pulse.transpiler_settings(optimization_level=3): + print(pulse.active_transpiler_settings()) +``` + +```python +{} +{'optimization_level': 3} +``` + +**Return type** + +[*ContextManager*](https://docs.python.org/3/library/typing.html#typing.ContextManager "(in Python v3.12)")\[None] + +### Macros + +Macros help you add more complex functionality to your pulse program. + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeArmonk + +backend = FakeArmonk() + +with pulse.build(backend) as measure_sched: + mem_slot = pulse.measure(0) + print(mem_slot) +``` + +```python +MemorySlot(0) +``` + +### measure + + + +`qiskit.pulse.builder.measure(qubits, registers=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Measure a qubit within the currently active builder context. + +At the pulse level a measurement is composed of both a stimulus pulse and an acquisition instruction which tells the systems measurement unit to acquire data and process it. We provide this measurement macro to automate the process for you, but if desired full control is still available with [`acquire()`](#qiskit.pulse.builder.acquire "qiskit.pulse.builder.acquire") and [`play()`](#qiskit.pulse.builder.play "qiskit.pulse.builder.play"). + +To use the measurement it is as simple as specifying the qubit you wish to measure: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +qubit = 0 + +with pulse.build(backend) as pulse_prog: + # Do something to the qubit. + qubit_drive_chan = pulse.drive_channel(0) + pulse.play(pulse.Constant(100, 1.0), qubit_drive_chan) + # Measure the qubit. + reg = pulse.measure(qubit) +``` + +For now it is not possible to do much with the handle to `reg` but in the future we will support using this handle to a result register to build up ones program. It is also possible to supply this register: + +```python +with pulse.build(backend) as pulse_prog: + pulse.play(pulse.Constant(100, 1.0), qubit_drive_chan) + # Measure the qubit. + mem0 = pulse.MemorySlot(0) + reg = pulse.measure(qubit, mem0) + +assert reg == mem0 +``` + + + Requires the active builder context to have a backend set. + + +**Parameters** + +* **qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Physical qubit to measure. +* **registers** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[StorageLocation] | StorageLocation | None*) – Register to store result in. If not selected the current behavior is to return the `MemorySlot` with the same index as `qubit`. This register will be returned. + +**Returns** + +The `register` the qubit measurement result will be stored in. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[StorageLocation] | StorageLocation + +### measure\_all + + + +`qiskit.pulse.builder.measure_all()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Measure all qubits within the currently active builder context. + +A simple macro function to measure all of the qubits in the device at the same time. This is useful for handling device `meas_map` and single measurement constraints. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend) as pulse_prog: + # Measure all qubits and return associated registers. + regs = pulse.measure_all() +``` + + + Requires the active builder context to have a backend set. + + +**Returns** + +The `register`s the qubit measurement results will be stored in. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*MemorySlot*](qiskit.pulse.channels.MemorySlot "qiskit.pulse.channels.MemorySlot")] + +### delay\_qubits + + + +`qiskit.pulse.builder.delay_qubits(duration, *qubits)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Insert delays on all of the `channels.Channel`s that correspond to the input `qubits` at the same time. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse3Q + +backend = FakeOpenPulse3Q() + +with pulse.build(backend) as pulse_prog: + # Delay for 100 cycles on qubits 0, 1 and 2. + regs = pulse.delay_qubits(100, 0, 1, 2) +``` + + + Requires the active builder context to have a backend set. + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration to delay for. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Physical qubits to delay on. Delays will be inserted based on the channels returned by `pulse.qubit_channels()`. + +### Utilities + +The utility functions can be used to gather attributes about the backend and modify how the program is built. + +```python +from qiskit import pulse + +from qiskit.providers.fake_provider import FakeArmonk + +backend = FakeArmonk() + +with pulse.build(backend) as u3_sched: + print('Number of qubits in backend: {}'.format(pulse.num_qubits())) + + samples = 160 + print('There are {} samples in {} seconds'.format( + samples, pulse.samples_to_seconds(160))) + + seconds = 1e-6 + print('There are {} seconds in {} samples.'.format( + seconds, pulse.seconds_to_samples(1e-6))) +``` + +```python +Number of qubits in backend: 1 +There are 160 samples in 3.5555555555555554e-08 seconds +There are 1e-06 seconds in 4500 samples. +``` + +### active\_backend + + + +`qiskit.pulse.builder.active_backend()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Get the backend of the currently active builder context. + +**Returns** + +**The active backend in the currently active** + +builder context. + +**Return type** + +[Backend](qiskit.providers.Backend "qiskit.providers.Backend") + +**Raises** + +[**exceptions.BackendNotSet**](#qiskit.pulse.BackendNotSet "qiskit.pulse.exceptions.BackendNotSet") – If the builder does not have a backend set. + +### active\_transpiler\_settings + + + +`qiskit.pulse.builder.active_transpiler_settings()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Return the current active builder context’s transpiler settings. + + + The function `qiskit.pulse.builder.active_transpiler_settings()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was used for gate operations, which are deprecated. pulse schedules should only be used for gate calibrations as part of a quantum circuit, and not vice versa + + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +transpiler_settings = {'optimization_level': 3} + +with pulse.build(backend, + default_transpiler_settings=transpiler_settings): + print(pulse.active_transpiler_settings()) +``` + +```python +{'optimization_level': 3} +``` + +**Return type** + +[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")] + +### active\_circuit\_scheduler\_settings + + + +`qiskit.pulse.builder.active_circuit_scheduler_settings()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Return the current active builder context’s circuit scheduler settings. + + + The function `qiskit.pulse.builder.active_circuit_scheduler_settings()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was used for gate operations, which are deprecated. pulse schedules should only be used for gate calibrations as part of a quantum circuit, and not vice versa + + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +circuit_scheduler_settings = {'method': 'alap'} + +with pulse.build( + backend, + default_circuit_scheduler_settings=circuit_scheduler_settings): + print(pulse.active_circuit_scheduler_settings()) +``` + +```python +{'method': 'alap'} +``` + +**Return type** + +[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")] + +### num\_qubits + + + +`qiskit.pulse.builder.num_qubits()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Return number of qubits in the currently active backend. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend): + print(pulse.num_qubits()) +``` + +```python +2 +``` + + + Requires the active builder context to have a backend set. + + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### qubit\_channels + + + +`qiskit.pulse.builder.qubit_channels(qubit)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Returns the set of channels associated with a qubit. + +Examples: + +```python +from qiskit import pulse +from qiskit.providers.fake_provider import FakeOpenPulse2Q + +backend = FakeOpenPulse2Q() + +with pulse.build(backend): + print(pulse.qubit_channels(0)) +``` + +```python +{MeasureChannel(0), ControlChannel(0), DriveChannel(0), AcquireChannel(0), ControlChannel(1)} +``` + + + Requires the active builder context to have a backend set. + + + + A channel may still be associated with another qubit in this list such as in the case where significant crosstalk exists. + + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[*Channel*](#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")] + +### samples\_to\_seconds + + + +`qiskit.pulse.builder.samples_to_seconds(samples)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Obtain the time in seconds that will elapse for the input number of samples on the active backend. + +**Parameters** + +**samples** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Number of samples to convert to time in seconds. + +**Returns** + +The time that elapses in `samples`. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### seconds\_to\_samples + + + +`qiskit.pulse.builder.seconds_to_samples(seconds)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/builder.py "view source code") + +Obtain the number of samples that will elapse in `seconds` on the active backend. + +Rounds down. + +**Parameters** + +**seconds** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Time in seconds to convert to samples. + +**Returns** + +The number of samples for the time to elapse + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") | [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +## Configuration + +| | | +| ------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap")() | Mapping from [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") [`qiskit.circuit.Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") names and qubits to [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") s. In particular, the mapping is formatted as type::. | + +## Exceptions + +### PulseError + + + +`qiskit.pulse.PulseError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/exceptions.py "view source code") + +Errors raised by the pulse module. + +Set the error message. + +### BackendNotSet + + + +`qiskit.pulse.BackendNotSet(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/exceptions.py "view source code") + +Raised if the builder context does not have a backend. + +Set the error message. + +### NoActiveBuilder + + + +`qiskit.pulse.NoActiveBuilder(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/exceptions.py "view source code") + +Raised if no builder context is active. + +Set the error message. + +### UnassignedDurationError + + + +`qiskit.pulse.UnassignedDurationError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/exceptions.py "view source code") + +Raised if instruction duration is unassigned. + +Set the error message. + +### UnassignedReferenceError + + + +`qiskit.pulse.UnassignedReferenceError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/exceptions.py "view source code") + +Raised if subroutine is unassigned. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/qasm.md b/docs/api/qiskit/0.46/qasm.md new file mode 100644 index 00000000000..43b68c777d1 --- /dev/null +++ b/docs/api/qiskit/0.46/qasm.md @@ -0,0 +1,54 @@ +--- +title: qasm +description: API reference for qiskit.qasm +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.qasm +--- + + + + + + + +# Qasm + + + +`qiskit.qasm` + + + The [`qiskit.qasm`](#module-qiskit.qasm "qiskit.qasm") module has been deprecated and superseded by the [`qiskit.qasm2`](qasm2#module-qiskit.qasm2 "qiskit.qasm2") module which provides a faster more correct parser. + + +## QASM Routines + + + +`qiskit.qasm.Qasm(filename=None, data=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm/qasm.py "view source code") + +OPENQASM circuit object. + +Create an OPENQASM circuit object. + +## Pygments + + + +`qiskit.qasm.OpenQASMLexer(*args, **kwds)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm/pygments/lexer.py "view source code") + +A pygments lexer for OpenQasm. + + + +`qiskit.qasm.QasmHTMLStyle`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm/pygments/lexer.py "view source code") + +A style for OpenQasm in a HTML env (e.g. Jupyter widget). + + + +`qiskit.qasm.QasmTerminalStyle`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm/pygments/lexer.py "view source code") + +A style for OpenQasm in a Terminal env (e.g. Jupyter print). + diff --git a/docs/api/qiskit/0.46/qasm2.md b/docs/api/qiskit/0.46/qasm2.md new file mode 100644 index 00000000000..cb5c866feab --- /dev/null +++ b/docs/api/qiskit/0.46/qasm2.md @@ -0,0 +1,539 @@ +--- +title: qasm2 +description: API reference for qiskit.qasm2 +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.qasm2 +--- + + + + + + + +# OpenQASM 2 + + + +`qiskit.qasm2` + +Qiskit has support for interoperation with OpenQASM 2.0 programs, both [parsing into Qiskit formats](#qasm2-parse) and [exporting back to OpenQASM 2](#qasm2-export). + + + OpenQASM 2 is a simple language, and not suitable for general serialisation of Qiskit objects. See [some discussion of alternatives below](#qasm2-alternatives), if that is what you are looking for. + + + + +## Parsing API + +This module contains two public functions, both of which create a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") from an OpenQASM 2 program. [`load()`](#qiskit.qasm2.load "qiskit.qasm2.load") takes a filename, while [`loads()`](#qiskit.qasm2.loads "qiskit.qasm2.loads") takes the program itself as a string. Their internals are very similar, so both offer almost the same API. + +### load + + + +`qiskit.qasm2.load(filename, *, include_path=('.',), include_input_directory='append', custom_instructions=(), custom_classical=(), strict=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/__init__.py "view source code") + +Parse an OpenQASM 2 program from a file into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). The given path should be ASCII or UTF-8 encoded, and contain the OpenQASM 2 program. + +**Parameters** + +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*PathLike*](https://docs.python.org/3/library/os.html#os.PathLike "(in Python v3.12)")) – The OpenQASM 2 program in a string. +* **include\_path** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*PathLike*](https://docs.python.org/3/library/os.html#os.PathLike "(in Python v3.12)")*]*) – order of directories to search when evaluating `include` statements. +* **include\_input\_directory** ([*Literal*](https://docs.python.org/3/library/typing.html#typing.Literal "(in Python v3.12)")*\['append', 'prepend'] | None*) – Whether to add the directory of the input file to the `include_path`, and if so, whether to *append* it to search last, or *prepend* it to search first. Pass `None` to suppress adding this directory entirely. +* **custom\_instructions** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*CustomInstruction*](#qiskit.qasm2.CustomInstruction "qiskit.qasm2.parse.CustomInstruction")*]*) – any custom constructors that should be used for specific gates or opaque instructions during circuit construction. See [Specifying custom instructions](#qasm2-custom-instructions) for more. +* **custom\_classical** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*CustomClassical*](#qiskit.qasm2.CustomClassical "qiskit.qasm2.CustomClassical")*]*) – any custom classical functions that should be used during the parsing of classical expressions. See [Specifying custom classical functions](#qasm2-custom-classical) for more. +* **strict** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to run in [strict mode](#qasm2-strict-mode). + +**Returns** + +A circuit object representing the same OpenQASM 2 program. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### loads + + + +`qiskit.qasm2.loads(string, *, include_path=('.',), custom_instructions=(), custom_classical=(), strict=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/__init__.py "view source code") + +Parse an OpenQASM 2 program from a string into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Parameters** + +* **string** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The OpenQASM 2 program in a string. +* **include\_path** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*PathLike*](https://docs.python.org/3/library/os.html#os.PathLike "(in Python v3.12)")*]*) – order of directories to search when evaluating `include` statements. +* **custom\_instructions** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*CustomInstruction*](#qiskit.qasm2.CustomInstruction "qiskit.qasm2.parse.CustomInstruction")*]*) – any custom constructors that should be used for specific gates or opaque instructions during circuit construction. See [Specifying custom instructions](#qasm2-custom-instructions) for more. +* **custom\_classical** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*CustomClassical*](#qiskit.qasm2.CustomClassical "qiskit.qasm2.CustomClassical")*]*) – any custom classical functions that should be used during the parsing of classical expressions. See [Specifying custom classical functions](#qasm2-custom-classical) for more. +* **strict** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to run in [strict mode](#qasm2-strict-mode). + +**Returns** + +A circuit object representing the same OpenQASM 2 program. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Both of these loading functions also take an argument `include_path`, which is an iterable of directory names to use when searching for files in `include` statements. The directories are tried from index 0 onwards, and the first match is used. The import `qelib1.inc` is treated specially; it is always found before looking in the include path, and contains exactly the content of the [paper describing the OpenQASM 2 language](https://arxiv.org/abs/1707.03429). The gates in this include file are mapped to circuit-library gate objects defined by Qiskit. + + + +### Specifying custom instructions + +You can extend the quantum components of the OpenQASM 2 language by passing an iterable of information on custom instructions as the argument `custom_instructions`. In files that have compatible definitions for these instructions, the given `constructor` will be used in place of whatever other handling [`qiskit.qasm2`](#module-qiskit.qasm2 "qiskit.qasm2") would have done. These instructions may optionally be marked as `builtin`, which causes them to not require an `opaque` or `gate` declaration, but they will silently ignore a compatible declaration. Either way, it is an error to provide a custom instruction that has a different number of parameters or qubits as a defined instruction in a parsed program. Each element of the argument iterable should be a particular data class: + + + +`qiskit.qasm2.CustomInstruction(name, num_params, num_qubits, constructor, builtin=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/parse.py "view source code") + +Information about a custom instruction that should be defined during the parse. + +The `name`, `num_params` and `num_qubits` fields are self-explanatory. The `constructor` field should be a callable object with signature `*args -> Instruction`, where each of the `num_params` `args` is a floating-point value. Most of the built-in Qiskit gate classes have this form. + +There is a final `builtin` field. This is optional, and if set true will cause the instruction to be defined and available within the parsing, even if there is no definition in any included OpenQASM 2 file. + +This can be particularly useful when trying to resolve ambiguities in the global-phase conventions of an OpenQASM 2 program. See [OpenQASM 2 Phase Conventions](#qasm2-phase-conventions) for more details. + + + +### Specifying custom classical functions + +Similar to the quantum extensions above, you can also extend the processing done to classical expressions (arguments to gates) by passing an iterable to the argument `custom_classical` to either loader. This needs the `name` (a valid OpenQASM 2 identifier), the number `num_params` of parameters it takes, and a Python callable that implements the function. The Python callable must be able to accept `num_params` positional floating-point arguments, and must return a float or integer (which will be converted to a float). Builtin functions cannot be overridden. + + + +`qiskit.qasm2.CustomClassical` + +Information about a custom classical function that should be defined in mathematical expressions. + +The given callable must be a Python function that takes num\_params floats, and returns a float. The name is the identifier that refers to it in the OpenQASM 2 program. This cannot clash with any defined gates. + + + +### Strict mode + +Both of the loader functions have an optional “strict” mode. By default, this parser is a little bit more relaxed than the official specification: it allows trailing commas in parameter lists; unnecessary (empty-statement) semicolons; the `OPENQASM 2.0;` version statement to be omitted; and a couple of other quality-of-life improvements without emitting any errors. You can use the letter-of-the-spec mode with `strict=True`. + + + +## Exporting API + +Similar to other serialisation modules in Python, this module offers two public functions: [`dump()`](#qiskit.qasm2.dump "qiskit.qasm2.dump") and [`dumps()`](#qiskit.qasm2.dumps "qiskit.qasm2.dumps"), which take a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and write out a representative OpenQASM 2 program to a file-like object or return a string, respectively. + +### dump + + + +`qiskit.qasm2.dump(circuit, filename_or_stream, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/export.py "view source code") + +Dump a circuit as an OpenQASM 2 program to a file or stream. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") to be exported. +* **filename\_or\_stream** ([*os.PathLike*](https://docs.python.org/3/library/os.html#os.PathLike "(in Python v3.12)") *|*[*io.TextIOBase*](https://docs.python.org/3/library/io.html#io.TextIOBase "(in Python v3.12)")) – either a path-like object (likely a [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") or [`pathlib.Path`](https://docs.python.org/3/library/pathlib.html#pathlib.Path "(in Python v3.12)")), or an already opened text-mode stream. + +**Raises** + +[**QASM2ExportError**](#qiskit.qasm2.QASM2ExportError "qiskit.qasm2.QASM2ExportError") – if the circuit cannot be represented by OpenQASM 2. + +### dumps + + + +`qiskit.qasm2.dumps(circuit, /)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/export.py "view source code") + +Export a circuit to an OpenQASM 2 program in a string. + +**Parameters** + +**circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") to be exported. + +**Returns** + +An OpenQASM 2 string representing the circuit. + +**Raises** + +[**QASM2ExportError**](#qiskit.qasm2.QASM2ExportError "qiskit.qasm2.QASM2ExportError") – if the circuit cannot be represented by OpenQASM 2. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +## Errors + +This module defines a generic error type that derives from [`QiskitError`](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") that can be used as a catch when you care about failures emitted by the interoperation layer specifically. + +### QASM2Error + + + +`qiskit.qasm2.QASM2Error(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/exceptions.py "view source code") + +A general error raised by the OpenQASM 2 interoperation layer. + +Set the error message. + +In cases where the lexer or parser fails due to an invalid OpenQASM 2 file, the conversion functions will raise a more specific error with a message explaining what the failure is, and where in the file it occurred. + +### QASM2ParseError + + + +`qiskit.qasm2.QASM2ParseError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/exceptions.py "view source code") + +An error raised because of a failure to parse an OpenQASM 2 file. + +Set the error message. + +When the exporters fail to export a circuit, likely because it has structure that cannot be represented by OpenQASM 2.0, they will also emit a custom error. + +### QASM2ExportError + + + +`qiskit.qasm2.QASM2ExportError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm2/exceptions.py "view source code") + +An error raised because of a failure to convert a Qiskit object to an OpenQASM 2 form. + +Set the error message. + + + +## Examples + +### Exporting examples + +Export a simple [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") to an OpenQASM 2 string: + +```python +import qiskit.qasm2 +from qiskit.circuit import QuantumCircuit + +qc = QuantumCircuit(2, 2) +qc.h(0) +qc.cx(0, 1) +qc.measure([0, 1], [0, 1]) +print(qiskit.qasm2.dumps(qc)) +``` + +```python +OPENQASM 2.0; +include "qelib1.inc"; +qreg q[2]; +creg c[2]; +h q[0]; +cx q[0],q[1]; +measure q[0] -> c[0]; +measure q[1] -> c[1]; +``` + +Write out the same [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") to a given filename: + +```python +qiskit.qasm2.dump(qc, "myfile.qasm") +``` + +Similarly, one can use general [`os.PathLike`](https://docs.python.org/3/library/os.html#os.PathLike "(in Python v3.12)") instances as the filename: + +```python +import pathlib + +qiskit.qasm2.dump(qc, pathlib.Path.home() / "myfile.qasm") +``` + +One can also dump the text to an already-open stream: + +```python +import io + +with io.StringIO() as stream: + qiskit.qasm2.dump(qc, stream) +``` + +### Parsing examples + +Use [`loads()`](#qiskit.qasm2.loads "qiskit.qasm2.loads") to import an OpenQASM 2 program in a string into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"): + +```python +import qiskit.qasm2 +program = """ + OPENQASM 2.0; + include "qelib1.inc"; + qreg q[2]; + creg c[2]; + + h q[0]; + cx q[0], q[1]; + + measure q -> c; +""" +circuit = qiskit.qasm2.loads(program) +circuit.draw() +``` + +```python + ┌───┐ ┌─┐ +q_0: ┤ H ├──■──┤M├─── + └───┘┌─┴─┐└╥┘┌─┐ +q_1: ─────┤ X ├─╫─┤M├ + └───┘ ║ └╥┘ +c: 2/═══════════╩══╩═ + 0 1 +``` + +You can achieve the same thing if the program is stored in a file by using [`load()`](#qiskit.qasm2.load "qiskit.qasm2.load") instead, passing the filename as an argument: + +```python +import qiskit.qasm2 +circuit = qiskit.qasm2.load("myfile.qasm") +``` + +OpenQASM 2 files can include other OpenQASM 2 files via the `include` statement. You can influence the search path used for finding these files with the `include_path` argument to both [`load()`](#qiskit.qasm2.load "qiskit.qasm2.load") and [`loads()`](#qiskit.qasm2.loads "qiskit.qasm2.loads"). By default, only the current working directory is searched. + +```python +import qiskit.qasm2 +program = """ + include "other.qasm"; + // ... and so on +""" +circuit = qiskit.qasm2.loads(program, include_path=("/path/to/a", "/path/to/b", ".")) +``` + +For [`load()`](#qiskit.qasm2.load "qiskit.qasm2.load") only, there is an extra argument `include_input_directory`, which can be used to either `'append'`, `'prepend'` or ignore (`None`) the directory of the loaded file in the include path. By default, this directory is appended to the search path, so it is tried last, but you can change this. + +```python +import qiskit.qasm2 +filenames = ["./subdirectory/a.qasm", "/path/to/b.qasm", "~/my.qasm"] +# Search the directory of each file before other parts of the include path. +circuits = [ + qiskit.qasm2.load(filename, include_input_directory="prepend") for filename in filenames +] +# Override the include path, and don't search the directory of each file unless it's in the +# absolute path list. +circuits = [ + qiskit.qasm2.load( + filename, + include_path=("/usr/include/qasm", "~/qasm/include"), + include_input_directory=None, + ) + for filename in filenames +] +``` + +Sometimes you may want to influence the [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") objects that the importer emits for given named instructions. Gates that are defined by the statement `include "qelib1.inc";` will automatically be associated with a suitable Qiskit circuit-library gate, but you can extend this: + +```python +from qiskit.circuit import Gate +from qiskit.qasm2 import loads, CustomInstruction + +class MyGate(Gate): + def __init__(self, theta): + super().__init__("my", 2, [theta]) + +class Builtin(Gate): + def __init__(self): + super().__init__("builtin", 1, []) + +program = """ + opaque my(theta) q1, q2; + qreg q[2]; + my(0.5) q[0], q[1]; + builtin q[0]; +""" +customs = [ + CustomInstruction(name="my", num_params=1, num_qubits=2, constructor=MyGate), + # Setting 'builtin=True' means the instruction doesn't require a declaration to be usable. + CustomInstruction("builtin", 0, 1, Builtin, builtin=True), +] +circuit = loads(program, custom_instructions=customs) +``` + +Similarly, you can add new classical functions used during the description of arguments to gates, both in the main body of the program (which come out constant-folded) and within the bodies of defined gates (which are computed on demand). Here we provide a Python version of `atan2(y, x)`, which mathematically is $\arctan(y/x)$ but correctly handling angle quadrants and infinities, and a custom `add_one` function: + +```python +import math +from qiskit.qasm2 import loads, CustomClassical + +program = """ + include "qelib1.inc"; + qreg q[2]; + rx(atan2(pi, 3 + add_one(0.2))) q[0]; + cx q[0], q[1]; +""" + +def add_one(x): + return x + 1 + +customs = [ + # `atan2` takes two parameters, and `math.atan2` implements it. + CustomClassical("atan2", 2, math.atan2), + # Our `add_one` takes only one parameter. + CustomClassical("add_one", 1, add_one), +] +circuit = loads(program, custom_classical=customs) +``` + + + +## OpenQASM 2 Phase Conventions + +As a language, OpenQASM 2 does not have a way to specify the global phase of a complete program, nor of particular gate definitions. This means that parsers of the language may interpret particular gates with a different global phase than what you might expect. For example, the *de facto* standard library of OpenQASM 2 `qelib1.inc` contains definitions of `u1` and `rz` as follows: + +```python +gate u1(lambda) q { + U(0, 0, lambda) q; +} + +gate rz(phi) a { + u1(phi) a; +} +``` + +In other words, `rz` appears to be a direct alias for `u1`. However, the interpretation of `u1` is specified in [equation (3) of the paper describing the language](https://arxiv.org/abs/1707.03429) as + +$$ +u_1(\lambda) = \operatorname{diag}\bigl(1, e^{i\lambda}\bigr) \sim R_z(\lambda) +$$ + +where the $\sim$ symbol denotes equivalence only up to a global phase. When parsing OpenQASM 2, we need to choose how to handle a distinction between such gates; `u1` is defined in the prose to be different by a phase to `rz`, but the language is not designed to represent this. + +Qiskit’s default position is to interpret a usage of the standard-library `rz` using [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate"), and a usage of `u1` as using the phase-distinct [`U1Gate`](qiskit.circuit.library.U1Gate "qiskit.circuit.library.U1Gate"). If you wish to use the phase conventions more implied by a direct interpretation of the `gate` statements in the header file, you can use [`CustomInstruction`](#qiskit.qasm2.CustomInstruction "qiskit.qasm2.CustomInstruction") to override how Qiskit builds the circuit. + +For the standard `qelib1.inc` include there is only one point of difference, and so the override needed to switch its phase convention is: + +```python +from qiskit import qasm2 +from qiskit.circuit.library import PhaseGate +from qiskit.quantum_info import Operator + +program = """ + OPENQASM 2.0; + include "qelib1.inc"; + qreg q[1]; + rz(pi / 2) q[0]; +""" + +custom = [ + qasm2.CustomInstruction("rz", 1, 1, PhaseGate), +] +``` + +This will use Qiskit’s [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate") class to represent the `rz` instruction, which is equal (including the phase) to [`U1Gate`](qiskit.circuit.library.U1Gate "qiskit.circuit.library.U1Gate"): + +```python +Operator(qasm2.loads(program, custom_instructions=custom)) +``` + +```python +Operator([[1.000000e+00+0.j, 0.000000e+00+0.j], + [0.000000e+00+0.j, 6.123234e-17+1.j]], + input_dims=(2,), output_dims=(2,)) +``` + + + +## Legacy Compatibility + +[`QuantumCircuit.from_qasm_str()`](qiskit.circuit.QuantumCircuit#from_qasm_str "qiskit.circuit.QuantumCircuit.from_qasm_str") and [`from_qasm_file()`](qiskit.circuit.QuantumCircuit#from_qasm_file "qiskit.circuit.QuantumCircuit.from_qasm_file") used to make a few additions on top of the raw specification. Qiskit originally tried to use OpenQASM 2 as a sort of serialisation format, and expanded its behaviour as Qiskit expanded. The new parser under all its defaults implements the specification more strictly. + +The complete legacy code-paths are + +```python +from qiskit.converters import ast_to_dag, dag_to_circuit +from qiskit.qasm import Qasm + +def from_qasm_file(path: str): + dag_to_circuit(ast_to_dag(Qasm(filename=path).parse())) + +def from_qasm_str(qasm_str: str): + dag_to_circuit(ast_to_dag(Qasm(data=qasm_str).parse())) +``` + +In particular, in the legacy importers: + +* **the include\_path is effectively:** + + 1. `/qasm/libs`, where `` is the root of the installed `qiskit` package; + 2. the current working directory. + +* **there are additional instructions defined in `qelib1.inc`:** + + **`csx a, b`** + + Controlled $\sqrt X$ gate, corresponding to [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate"). + + **`cu(theta, phi, lambda, gamma) c, t`** + + The four-parameter version of a controlled-$U$, corresponding to [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate"). + + **`rxx(theta) a, b`** + + Two-qubit rotation around the $XX$ axis, corresponding to [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate"). + + **`rzz(theta) a, b`** + + Two-qubit rotation around the $ZZ$ axis, corresponding to [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate"). + + **`rccx a, b, c`** + + The double-controlled $X$ gate, but with relative phase differences over the standard Toffoli gate. This *should* correspond to the Qiskit gate [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate"), but the legacy converter wouldn’t actually output this type. + + **`rc3x a, b, c, d`** + + The triple-controlled $X$ gate, but with relative phase differences over the standard definition. Corresponds to [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate"). + + **`c3x a, b, c, d`** + + The triple-controlled $X$ gate, corresponding to [`C3XGate`](qiskit.circuit.library.C3XGate "qiskit.circuit.library.C3XGate"). + + **`c3sqrtx a, b, c, d`** + + The triple-controlled $\sqrt X$ gate, corresponding to [`C3SXGate`](qiskit.circuit.library.C3SXGate "qiskit.circuit.library.C3SXGate"). + + **`c4x a, b, c, d, e`** + + The quadruple-controlled $X$ gate., corresponding to [`C4XGate`](qiskit.circuit.library.C4XGate "qiskit.circuit.library.C4XGate"). + +* if *any* `opaque` or `gate` definition was given for the name `delay`, they attempt to output a [`Delay`](qiskit.circuit.Delay "qiskit.circuit.Delay") instruction at each call. To function, this expects a definition compatible with `opaque delay(t) q;`, where the time `t` is given in units of `dt`. The importer will raise errors on construction if there was not exactly one parameter and one qubit, or if the parameter is not integer-valued. + +* the additional scientific-calculator functions `asin`, `acos` and `atan` are available. + +* the parsed grammar is effectively the same as [the strict mode of the new importers](#qasm2-strict-mode). + +You can emulate this behaviour in [`load()`](#qiskit.qasm2.load "qiskit.qasm2.load") and [`loads()`](#qiskit.qasm2.loads "qiskit.qasm2.loads") by setting include\_path appropriately (try inspecting the variable `qiskit.__file__` to find the installed location), and by passing a list of [`CustomInstruction`](#qiskit.qasm2.CustomInstruction "qiskit.qasm2.CustomInstruction") instances for each of the custom gates you care about. To make things easier we make three tuples available, which each contain one component of a configuration that is equivalent to Qiskit’s legacy converter behaviour. + +**qiskit.qasm2.LEGACY\_CUSTOM\_INSTRUCTIONS** + +A tuple containing the extra custom\_instructions that Qiskit’s legacy built-in converters used if `qelib1.inc` is included, and there is any definition of a `delay` instruction. The gates in the paper version of `qelib1.inc` and `delay` all require a compatible declaration statement to be present within the OpenQASM 2 program, but Qiskit’s legacy additions are all marked as builtins since they are not actually present in any include file this parser sees. + +**qiskit.qasm2.LEGACY\_CUSTOM\_CLASSICAL** + +A tuple containing the extra custom\_classical functions that Qiskit’s legacy built-in converters use beyond those specified by the paper. This is the three basic inverse trigonometric functions: $\asin$, $\acos$ and $\atan$. + +**qiskit.qasm2.LEGACY\_INCLUDE\_PATH** + +A tuple containing the exact include\_path used by the legacy Qiskit converter. + +On *all* the gates defined in Qiskit’s legacy version of `qelib1.inc` and the `delay` instruction, it does not matter how the gates are actually defined and used, the legacy importer will always attempt to output its custom objects for them. This can result in errors during the circuit construction, even after a successful parse. There is no way to emulate this buggy behaviour with [`qiskit.qasm2`](#module-qiskit.qasm2 "qiskit.qasm2"); only an `include "qelib1.inc";` statement or the custom\_instructions argument can cause built-in Qiskit instructions to be used, and the signatures of these match each other. + + + Circuits imported with [`load()`](#qiskit.qasm2.load "qiskit.qasm2.load") and [`loads()`](#qiskit.qasm2.loads "qiskit.qasm2.loads") with the above legacy-compatibility settings should compare equal to those created by Qiskit’s legacy importer, provided no non-`qelib1.inc` user gates are defined. User-defined gates are handled slightly differently in the new importer, and while they should have equivalent [`definition`](qiskit.circuit.Instruction#definition "qiskit.circuit.Instruction.definition") fields on inspection, this module uses a custom class to lazily load the definition when it is requested (like most Qiskit objects), rather than eagerly creating it during the parse. Qiskit’s comparison rules for gates will see these two objects as unequal, although any pass through [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") for a particular backend should produce the same output circuits. + + + + +## Alternatives + +The parser components of this module started off as a separate PyPI package: [qiskit-qasm2](https://pypi.org/project/qiskit-qasm2/). This package at version 0.5.3 was vendored into Qiskit Terra 0.24. Any subsequent changes between the two packages may not necessarily be kept in sync. + +There is a newer version of the OpenQASM specification, version 3.0, which is described at [https://openqasm.com](https://openqasm.com). This includes far more facilities for high-level classical programming. Qiskit has some rudimentary support for OpenQASM 3 already; see [`qiskit.qasm3`](qasm3#module-qiskit.qasm3 "qiskit.qasm3") for that. + +OpenQASM 2 is not a suitable serialization language for Qiskit’s [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). This module is provided for interoperability purposes, not as a general serialization format. If that is what you need, consider using [`qiskit.qpy`](qpy#module-qiskit.qpy "qiskit.qpy") instead. + diff --git a/docs/api/qiskit/0.46/qasm3.md b/docs/api/qiskit/0.46/qasm3.md new file mode 100644 index 00000000000..dfedb2c5339 --- /dev/null +++ b/docs/api/qiskit/0.46/qasm3.md @@ -0,0 +1,299 @@ +--- +title: qasm3 +description: API reference for qiskit.qasm3 +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.qasm3 +--- + + + + + + + +# OpenQASM 3 + + + +`qiskit.qasm3` + +Qiskit provides some tools for converting between [OpenQASM 3](https://openqasm.com) representations of quantum programs, and the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") class. These will continue to evolve as Qiskit’s support for the dynamic-circuit capabilities expressed by OpenQASM 3 increases. + +## Exporting to OpenQASM 3 + +The high-level functions are simply [`dump()`](#qiskit.qasm3.dump "qiskit.qasm3.dump") and [`dumps()`](#qiskit.qasm3.dumps "qiskit.qasm3.dumps"), which respectively export to a file (given as a filename) and to a Python string. + +### dump + + + +`qiskit.qasm3.dump(circuit, stream, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/__init__.py "view source code") + +Serialize a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object as an OpenQASM 3 stream to file-like object. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Circuit to serialize. +* **stream** (*TextIOBase*) – stream-like object to dump the OpenQASM 3 serialization +* **\*\*kwargs** – Arguments for the [`Exporter`](#qiskit.qasm3.Exporter "qiskit.qasm3.Exporter") constructor. + +### dumps + + + +`qiskit.qasm3.dumps(circuit, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/__init__.py "view source code") + +Serialize a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object in an OpenQASM 3 string. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Circuit to serialize. +* **\*\*kwargs** – Arguments for the [`Exporter`](#qiskit.qasm3.Exporter "qiskit.qasm3.Exporter") constructor. + +**Returns** + +The OpenQASM 3 serialization + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +Both of these exporter functions are single-use wrappers around the main [`Exporter`](#qiskit.qasm3.Exporter "qiskit.qasm3.Exporter") class. For more complex exporting needs, including dumping multiple circuits in a single session, it may be more convenient or faster to use the complete interface. + + + +`qiskit.qasm3.Exporter(includes=('stdgates.inc', ), basis_gates=('U', ), disable_constants=False, alias_classical_registers=None, allow_aliasing=None, indent='  ', experimental=ExperimentalFeatures.None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/exporter.py "view source code") + +QASM3 exporter main class. + +**Parameters** + +* **includes** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – the filenames that should be emitted as includes. These files will be parsed for gates, and any objects dumped from this exporter will use those definitions where possible. + +* **basis\_gates** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – the basic defined gate set of the backend. + +* **disable\_constants** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True`, always emit floating-point constants for numeric parameter values. If `False` (the default), then values close to multiples of OpenQASM 3 constants (`pi`, `euler`, and `tau`) will be emitted in terms of those constants instead, potentially improving accuracy in the output. + +* **alias\_classical\_registers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – + + If `True`, then bits may be contained in more than one register. If so, the registers will be emitted using “alias” definitions, which might not be well supported by consumers of OpenQASM 3. + + + **Parameter `allow_aliasing`** + + A value for `allow_aliasing` overrides any value given here, and supersedes this parameter. + + +* **allow\_aliasing** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – + + If `True`, then bits may be contained in more than one register. If so, the registers will be emitted using “alias” definitions, which might not be well supported by consumers of OpenQASM 3. Defaults to `False` or the value of `alias_classical_registers`. + + New in version 0.25.0. + +* **indent** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the indentation string to use for each level within an indented block. Can be set to the empty string to disable indentation. + +* **experimental** ([*ExperimentalFeatures*](#qiskit.qasm3.ExperimentalFeatures "qiskit.qasm3.experimental.ExperimentalFeatures")) – any experimental features to enable during the export. See [`ExperimentalFeatures`](#qiskit.qasm3.ExperimentalFeatures "qiskit.qasm3.ExperimentalFeatures") for more details. + +### dump + + + +`dump(circuit, stream)` + +Convert the circuit to OpenQASM 3, dumping the result to a file or text stream. + +### dumps + + + +`dumps(circuit)` + +Convert the circuit to OpenQASM 3, returning the result as a string. + +All of these interfaces will raise [`QASM3ExporterError`](#qiskit.qasm3.QASM3ExporterError "qiskit.qasm3.QASM3ExporterError") on failure. + +### QASM3ExporterError + + + +`qiskit.qasm3.QASM3ExporterError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/exceptions.py "view source code") + +An error raised during running the OpenQASM 3 exporter. + +Set the error message. + +### Experimental features + +The OpenQASM 3 language is still evolving as hardware capabilities improve, so there is no final syntax that Qiskit can reliably target. In order to represent the evolving language, we will sometimes release features before formal standardization, which may need to change as the review process in the OpenQASM 3 design committees progresses. By default, the exporters will only support standardised features of the language. To enable these early-release features, use the `experimental` keyword argument of [`dump()`](#qiskit.qasm3.dump "qiskit.qasm3.dump") and [`dumps()`](#qiskit.qasm3.dumps "qiskit.qasm3.dumps"). The available feature flags are: + + + +`qiskit.qasm3.ExperimentalFeatures(value)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/experimental.py "view source code") + +Flags for experimental features that the OpenQASM 3 exporter supports. + +These are experimental and are more liable to change, because the OpenQASM 3 specification has not formally accepted them yet, so the syntax may not be finalized. + + + +### SWITCH\_CASE\_V1 + +`= 1` + +Support exporting switch-case statements as proposed by [https://github.com/openqasm/openqasm/pull/463](https://github.com/openqasm/openqasm/pull/463) at [commit bfa787aa3078](https://github.com/openqasm/openqasm/pull/463/commits/bfa787aa3078). + +If you want to enable multiple experimental features, you should combine the flags using the `|` operator, such as `flag1 | flag2`. + +For example, to perform an export using the early semantics of `switch` support: + +```python +from qiskit import qasm3, QuantumCircuit, QuantumRegister, ClassicalRegister + +# Build the circuit +qreg = QuantumRegister(3) +creg = ClassicalRegister(3) +qc = QuantumCircuit(qreg, creg) +with qc.switch(creg) as case: + with case(0): + qc.x(0) + with case(1, 2): + qc.x(1) + with case(case.DEFAULT): + qc.x(2) + +# Export to an OpenQASM 3 string. +qasm_string = qasm3.dumps(qc, experimental=qasm3.ExperimentalFeatures.SWITCH_CASE_V1) +``` + + + All features enabled by the experimental flags are naturally transient. If it becomes necessary to remove flags, they will be subject to [the standard Qiskit deprecation policy](https://github.com/Qiskit/qiskit/blob/main/DEPRECATION.md). We will leave these experimental flags in place for as long as is reasonable. + + However, we cannot guarantee any support windows for *consumers* of OpenQASM 3 code generated using these experimental flags, if the OpenQASM 3 language specification changes the proposal that the flag is based on. It is possible that any tool you are using to consume OpenQASM 3 code created using these flags may update or remove their support while Qiskit continues to offer the flag. You should not rely on the resultant experimental OpenQASM 3 code for long-term storage of programs. + + +## Importing from OpenQASM 3 + +Currently only two high-level functions are offered, as Qiskit support for importing from OpenQASM 3 is in its infancy, and the implementation is expected to change significantly. The two functions are [`load()`](#qiskit.qasm3.load "qiskit.qasm3.load") and [`loads()`](#qiskit.qasm3.loads "qiskit.qasm3.loads"), which are direct counterparts of [`dump()`](#qiskit.qasm3.dump "qiskit.qasm3.dump") and [`dumps()`](#qiskit.qasm3.dumps "qiskit.qasm3.dumps"), respectively loading a program indirectly from a named file and directly from a given string. + + + While we are still in the exploratory release period, to use either function, the package `qiskit_qasm3_import` must be installed. This can be done by installing Qiskit Terra with the `qasm3-import` extra, such as by: + + ```python + pip install qiskit-terra[qasm3-import] + ``` + + We expect that this functionality will eventually be merged into core Terra, and no longer require an optional import, but we do not yet have a timeline for this. + + +### load + + + +`qiskit.qasm3.load(filename)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/__init__.py "view source code") + +Load an OpenQASM 3 program from the file `filename`. + +**Parameters** + +**filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the filename to load the program from. + +**Returns** + +a circuit representation of the OpenQASM 3 program. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QASM3ImporterError**](#qiskit.qasm3.QASM3ImporterError "qiskit.qasm3.QASM3ImporterError") – if the OpenQASM 3 file is invalid, or cannot be represented by a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +### loads + + + +`qiskit.qasm3.loads(program)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/__init__.py "view source code") + +Load an OpenQASM 3 program from the given string. + +**Parameters** + +**program** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the OpenQASM 3 program. + +**Returns** + +a circuit representation of the OpenQASM 3 program. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QASM3ImporterError**](#qiskit.qasm3.QASM3ImporterError "qiskit.qasm3.QASM3ImporterError") – if the OpenQASM 3 file is invalid, or cannot be represented by a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +Both of these two functions raise [`QASM3ImporterError`](#qiskit.qasm3.QASM3ImporterError "qiskit.qasm3.QASM3ImporterError") on failure. + +### QASM3ImporterError + + + +`qiskit.qasm3.QASM3ImporterError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qasm3/exceptions.py "view source code") + +An error raised during the OpenQASM 3 importer. + +Set the error message. + +For example, we can define a quantum program using OpenQASM 3, and use [`loads()`](#qiskit.qasm3.loads "qiskit.qasm3.loads") to directly convert it into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"): + +```python +import qiskit.qasm3 + +program = """ + OPENQASM 3.0; + include "stdgates.inc"; + + input float[64] a; + qubit[3] q; + bit[2] mid; + bit[3] out; + + let aliased = q[0:1]; + + gate my_gate(a) c, t { + gphase(a / 2); + ry(a) c; + cx c, t; + } + gate my_phase(a) c { + ctrl @ inv @ gphase(a) c; + } + + my_gate(a * 2) aliased[0], q[{1, 2}][0]; + measure q[0] -> mid[0]; + measure q[1] -> mid[1]; + + while (mid == "00") { + reset q[0]; + reset q[1]; + my_gate(a) q[0], q[1]; + my_phase(a - pi/2) q[1]; + mid[0] = measure q[0]; + mid[1] = measure q[1]; + } + + if (mid[0]) { + let inner_alias = q[{0, 1}]; + reset inner_alias; + } + + out = measure q; +""" +circuit = qiskit.qasm3.loads(program) +circuit.draw("mpl") +``` + +![../\_images/qasm3-1.png](/images/api/qiskit/0.46/qasm3-1.png) + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.AlgorithmJob.md b/docs/api/qiskit/0.46/qiskit.algorithms.AlgorithmJob.md new file mode 100644 index 00000000000..1c28c725869 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.AlgorithmJob.md @@ -0,0 +1,168 @@ +--- +title: AlgorithmJob +description: API reference for qiskit.algorithms.AlgorithmJob +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.AlgorithmJob +--- + +# AlgorithmJob + + + +`qiskit.algorithms.AlgorithmJob(function, *args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/algorithm_job.py "view source code") + +Bases: `PrimitiveJob` + +This empty class is introduced for typing purposes. + +**Parameters** + +**function** – a callable function to execute the job. + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backend + + + +`backend()` + +Return the backend where this job was executed. + +**Return type** + +[*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") + +### cancel + + + +`cancel()` + +Attempt to cancel the job. + +### cancelled + + + +`cancelled()` + +Return whether the job has been cancelled. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### done + + + +`done()` + +Return whether the job has successfully run. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### in\_final\_state + + + +`in_final_state()` + +Return whether the job is in a final job state such as `DONE` or `ERROR`. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### job\_id + + + +`job_id()` + +Return a unique id identifying the job. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### result + + + +`result()` + +Return the results of the job. + +**Return type** + +*T* + +### running + + + +`running()` + +Return whether the job is actively running. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### status + + + +`status()` + +Return the status of the job, among the values of `JobStatus`. + +### submit + + + +`submit()` + +Submit the job to the backend for execution. + +### wait\_for\_final\_state + + + +`wait_for_final_state(timeout=None, wait=5, callback=None)` + +Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. + +**Parameters** + +* **timeout** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Seconds to wait for the job. If `None`, wait indefinitely. + +* **wait** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Seconds between queries. + +* **callback** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – + + Callback function invoked after each query. The following positional arguments are provided to the callback function: + + * job\_id: Job ID + * job\_status: Status of the job from the last query + * job: This BaseJob instance + + Note: different subclass might provide different arguments to the callback function. + +**Raises** + +[**JobTimeoutError**](providers#qiskit.providers.JobTimeoutError "qiskit.providers.JobTimeoutError") – If the job does not reach a final state before the specified timeout. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.AmplificationProblem.md b/docs/api/qiskit/0.46/qiskit.algorithms.AmplificationProblem.md new file mode 100644 index 00000000000..426a92036ac --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.AmplificationProblem.md @@ -0,0 +1,93 @@ +--- +title: AmplificationProblem +description: API reference for qiskit.algorithms.AmplificationProblem +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.AmplificationProblem +--- + +# AmplificationProblem + + + +`qiskit.algorithms.AmplificationProblem(oracle, state_preparation=None, grover_operator=None, post_processing=None, objective_qubits=None, is_good_state=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_amplifiers/amplification_problem.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +The amplification problem is the input to amplitude amplification algorithms, like Grover. + +This class contains all problem-specific information required to run an amplitude amplification algorithm. It minimally contains the Grover operator. It can further hold some post processing on the optimal bitstring. + +**Parameters** + +* **oracle** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")) – The oracle reflecting about the bad states. +* **state\_preparation** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A circuit preparing the input state, referred to as $\mathcal{A}$. If None, a layer of Hadamard gates is used. +* **grover\_operator** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – The Grover operator $\mathcal{Q}$ used as unitary in the phase estimation circuit. If None, this operator is constructed from the `oracle` and `state_preparation`. +* **post\_processing** (*Callable\[\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*], Any] | None*) – A mapping applied to the most likely bitstring. +* **objective\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – If set, specifies the indices of the qubits that should be measured. If None, all qubits will be measured. The `is_good_state` function will be applied on the measurement outcome of these qubits. +* **is\_good\_state** (*Callable\[\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*],* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] |* [*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *| None*) – A function to check whether a string represents a good state. By default if the `oracle` argument has an `evaluate_bitstring` method (currently only provided by the [`PhaseOracle`](qiskit.circuit.library.PhaseOracle "qiskit.circuit.library.PhaseOracle") class) this will be used, otherwise this kwarg is required and **must** be specified. + +## Attributes + + + +### grover\_operator + +Get the $\mathcal{Q}$ operator, or Grover operator. + +If the Grover operator is not set, we try to build it from the $\mathcal{A}$ operator and objective\_qubits. This only works if objective\_qubits is a list of integers. + +**Returns** + +The Grover operator, or None if neither the Grover operator nor the $\mathcal{A}$ operator is set. + + + +### is\_good\_state + +Check whether a provided bitstring is a good state or not. + +**Returns** + +A callable that takes in a bitstring and returns True if the measurement is a good state, False otherwise. + + + +### objective\_qubits + +The indices of the objective qubits. + +**Returns** + +The indices of the objective qubits as list of integers. + + + +### oracle + +Return the oracle. + +**Returns** + +The oracle. + + + +### post\_processing + +Apply post processing to the input value. + +**Returns** + +A handle to the post processing function. Acts as identity by default. + + + +### state\_preparation + +Get the state preparation operator $\mathcal{A}$. + +**Returns** + +The $\mathcal{A}$ operator as QuantumCircuit. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeAmplifier.md b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeAmplifier.md new file mode 100644 index 00000000000..4b14d938e73 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeAmplifier.md @@ -0,0 +1,40 @@ +--- +title: AmplitudeAmplifier +description: API reference for qiskit.algorithms.AmplitudeAmplifier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.AmplitudeAmplifier +--- + +# AmplitudeAmplifier + + + +`qiskit.algorithms.AmplitudeAmplifier`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_amplifiers/amplitude_amplifier.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +The interface for amplification algorithms. + +## Methods + +### amplify + + + +`abstract amplify(amplification_problem)` + +Run the amplification algorithm. + +**Parameters** + +**amplification\_problem** ([*AmplificationProblem*](qiskit.algorithms.AmplificationProblem "qiskit.algorithms.amplitude_amplifiers.amplification_problem.AmplificationProblem")) – The amplification problem. + +**Returns** + +The result as a `AmplificationResult`, where e.g. the most likely state can be queried as `result.top_measurement`. + +**Return type** + +*AmplitudeAmplifierResult* + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimation.md b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimation.md new file mode 100644 index 00000000000..c844fb460d4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimation.md @@ -0,0 +1,209 @@ +--- +title: AmplitudeEstimation +description: API reference for qiskit.algorithms.AmplitudeEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.AmplitudeEstimation +--- + +# AmplitudeEstimation + + + +`qiskit.algorithms.AmplitudeEstimation(num_eval_qubits, phase_estimation_circuit=None, iqft=None, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/ae.py "view source code") + +Bases: [`AmplitudeEstimator`](qiskit.algorithms.AmplitudeEstimator "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimator") + +The Quantum Phase Estimation-based Amplitude Estimation algorithm. + +This class implements the original Quantum Amplitude Estimation (QAE) algorithm, introduced by \[1]. This canonical version uses quantum phase estimation along with a set of $m$ additional evaluation qubits to find an estimate $\tilde{a}$, that is restricted to the grid + +$$ +\tilde{a} \in \{\sin^2(\pi y / 2^m) : y = 0, ..., 2^{m-1}\} +$$ + +More evaluation qubits produce a finer sampling grid, therefore the accuracy of the algorithm increases with $m$. + +Using a maximum likelihood post processing, this grid constraint can be circumvented. This improved estimator is implemented as well, see \[2] Appendix A for more detail. + + + This class does not support the [`EstimationProblem.is_good_state`](qiskit.algorithms.EstimationProblem#is_good_state "qiskit.algorithms.EstimationProblem.is_good_state") property, as for phase estimation-based QAE, the oracle that identifes the good states must be encoded in the Grover operator. To set custom oracles, the [`EstimationProblem.grover_operator`](qiskit.algorithms.EstimationProblem#grover_operator "qiskit.algorithms.EstimationProblem.grover_operator") attribute can be set directly. + + +**References** + +**\[1]: Brassard, G., Hoyer, P., Mosca, M., & Tapp, A. (2000).** + +Quantum Amplitude Amplification and Estimation. [arXiv:quant-ph/0005055](http://arxiv.org/abs/quant-ph/0005055). + +**\[2]: Grinko, D., Gacon, J., Zoufal, C., & Woerner, S. (2019).** + +Iterative Quantum Amplitude Estimation. [arXiv:1912.05559](https://arxiv.org/abs/1912.05559). + + + `qiskit.algorithms.amplitude_estimators.ae.AmplitudeEstimation.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **num\_eval\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of evaluation qubits. +* **phase\_estimation\_circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – The phase estimation circuit used to run the algorithm. Defaults to the standard phase estimation circuit from the circuit library, qiskit.circuit.library.PhaseEstimation when None. +* **iqft** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – The inverse quantum Fourier transform component, defaults to using a standard implementation from qiskit.circuit.library.QFT when None. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: The backend (or QuantumInstance) to execute the circuits on. +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – A sampler primitive to evaluate the circuits. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the number of evaluation qubits is smaller than 1. + +## Attributes + + + +### quantum\_instance + +Get the quantum instance. + + + The property `qiskit.algorithms.amplitude_estimators.ae.AmplitudeEstimation.quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Returns** + +The quantum instance used to run this algorithm. + +**Type** + +Deprecated + + + +### sampler + +Get the sampler primitive. + +**Returns** + +The sampler primitive to evaluate the circuits. + +## Methods + +### compute\_confidence\_interval + + + +`static compute_confidence_interval(result, alpha=0.05, kind='likelihood_ratio')` + +Compute the (1 - alpha) confidence interval. + +**Parameters** + +* **result** ([*AmplitudeEstimationResult*](qiskit.algorithms.AmplitudeEstimationResult "qiskit.algorithms.amplitude_estimators.ae.AmplitudeEstimationResult")) – An amplitude estimation result for which to compute the confidence interval. +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Confidence level: compute the (1 - alpha) confidence interval. +* **kind** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The method to compute the confidence interval, can be ‘fisher’, ‘observed\_fisher’ or ‘likelihood\_ratio’ (default) + +**Returns** + +The (1 - alpha) confidence interval of the specified kind. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If the confidence interval method kind is not implemented. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### compute\_mle + + + +`static compute_mle(result, apply_post_processing=False)` + +Compute the Maximum Likelihood Estimator (MLE). + +**Parameters** + +* **result** ([*AmplitudeEstimationResult*](qiskit.algorithms.AmplitudeEstimationResult "qiskit.algorithms.amplitude_estimators.ae.AmplitudeEstimationResult")) – An amplitude estimation result object. +* **apply\_post\_processing** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, apply the post processing to the MLE before returning it. + +**Returns** + +The MLE for the provided result object. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### construct\_circuit + + + +`construct_circuit(estimation_problem, measurement=False)` + +Construct the Amplitude Estimation quantum circuit. + +**Parameters** + +* **estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – The estimation problem for which to construct the QAE circuit. +* **measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Boolean flag to indicate if measurements should be included in the circuit. + +**Returns** + +The QuantumCircuit object for the constructed circuit. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### estimate + + + +`estimate(estimation_problem)` + +Run the amplitude estimation algorithm on provided estimation problem. + +**Parameters** + +**estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – The estimation problem. + +**Returns** + +An amplitude estimation results object. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If state\_preparation or objective\_qubits are not set in the estimation\_problem. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – A quantum instance or sampler must be provided. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – Sampler job run error. + +**Return type** + +[*AmplitudeEstimationResult*](qiskit.algorithms.AmplitudeEstimationResult "qiskit.algorithms.amplitude_estimators.ae.AmplitudeEstimationResult") + +### evaluate\_measurements + + + +`evaluate_measurements(circuit_results, threshold=1e-06)` + +Evaluate the results from the circuit simulation. + +Given the probabilities from statevector simulation of the QAE circuit, compute the probabilities that the measurements y/gridpoints a are the best estimate. + +**Parameters** + +* **circuit\_results** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | np.ndarray*) – The circuit result from the QAE circuit. Can be either a counts dict or a statevector or a quasi-probabilities dict. +* **threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Measurements with probabilities below the threshold are discarded. + +**Returns** + +**Dictionaries containing the a gridpoints with respective probabilities and** + +y measurements with respective probabilities, in this order. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")], [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]] + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimationResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimationResult.md new file mode 100644 index 00000000000..80b08e2a4dd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimationResult.md @@ -0,0 +1,124 @@ +--- +title: AmplitudeEstimationResult +description: API reference for qiskit.algorithms.AmplitudeEstimationResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.AmplitudeEstimationResult +--- + +# AmplitudeEstimationResult + + + +`qiskit.algorithms.AmplitudeEstimationResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/ae.py "view source code") + +Bases: [`AmplitudeEstimatorResult`](qiskit.algorithms.AmplitudeEstimatorResult "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimatorResult") + +The `AmplitudeEstimation` result object. + +## Attributes + + + +### circuit\_results + +Return the circuit results. Can be a statevector or counts dictionary. + + + +### confidence\_interval + +Return the confidence interval for the amplitude (95% interval by default). + + + +### confidence\_interval\_processed + +Return the post-processed confidence interval (95% interval by default). + + + +### estimation + +Return the estimation for the amplitude in $[0, 1]$. + + + +### estimation\_processed + +Return the estimation for the amplitude after the post-processing has been applied. + + + +### max\_probability + +Return the maximum sampling probability. + + + +### measurements + +Return the measurements as integers with their measurement probability. + + + +### mle + +Return the MLE for the amplitude, in $\[0, 1]\$. + + + +### mle\_processed + +Return the post-processed MLE for the amplitude. + + + +### num\_evaluation\_qubits + +Returns the number of evaluation qubits. + + + +### num\_oracle\_queries + +Return the number of Grover oracle queries. + + + +### post\_processing + +Return a handle to the post processing function. + + + +### samples + +Return the measurement samples with their measurement probability. + + + +### samples\_processed + +Return the post-processed measurement samples with their measurement probability. + + + +### shots + +Return the number of shots used. Is 1 for statevector-based simulations. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimator.md b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimator.md new file mode 100644 index 00000000000..821c503ac49 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimator.md @@ -0,0 +1,36 @@ +--- +title: AmplitudeEstimator +description: API reference for qiskit.algorithms.AmplitudeEstimator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.AmplitudeEstimator +--- + +# AmplitudeEstimator + + + +`qiskit.algorithms.AmplitudeEstimator`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/amplitude_estimator.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +The Amplitude Estimation interface. + +## Methods + +### estimate + + + +`abstract estimate(estimation_problem)` + +Run the amplitude estimation algorithm. + +**Parameters** + +**estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – An `EstimationProblem` containing all problem-relevant information such as the state preparation and the objective qubits. + +**Return type** + +[*AmplitudeEstimatorResult*](qiskit.algorithms.AmplitudeEstimatorResult "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimatorResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimatorResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimatorResult.md new file mode 100644 index 00000000000..5a0c1c7ded8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.AmplitudeEstimatorResult.md @@ -0,0 +1,82 @@ +--- +title: AmplitudeEstimatorResult +description: API reference for qiskit.algorithms.AmplitudeEstimatorResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.AmplitudeEstimatorResult +--- + +# AmplitudeEstimatorResult + + + +`qiskit.algorithms.AmplitudeEstimatorResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/amplitude_estimator.py "view source code") + +Bases: `AlgorithmResult` + +The results object for amplitude estimation algorithms. + +## Attributes + + + +### circuit\_results + +Return the circuit results. Can be a statevector or counts dictionary. + + + +### confidence\_interval + +Return the confidence interval for the amplitude (95% interval by default). + + + +### confidence\_interval\_processed + +Return the post-processed confidence interval (95% interval by default). + + + +### estimation + +Return the estimation for the amplitude in $[0, 1]$. + + + +### estimation\_processed + +Return the estimation for the amplitude after the post-processing has been applied. + + + +### num\_oracle\_queries + +Return the number of Grover oracle queries. + + + +### post\_processing + +Return a handle to the post processing function. + + + +### shots + +Return the number of shots used. Is 1 for statevector-based simulations. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.Eigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.Eigensolver.md new file mode 100644 index 00000000000..ad57568cab0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.Eigensolver.md @@ -0,0 +1,65 @@ +--- +title: Eigensolver +description: API reference for qiskit.algorithms.Eigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.Eigensolver +--- + +# Eigensolver + + + +`qiskit.algorithms.Eigensolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigen_solvers/eigen_solver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Deprecated: Eigensolver Interface. + +The Eigensolver interface has been superseded by the [`qiskit.algorithms.eigensolvers.Eigensolver`](qiskit.algorithms.eigensolvers.Eigensolver "qiskit.algorithms.eigensolvers.Eigensolver") interface. This interface will be deprecated in a future release and subsequently removed after that. + +Algorithms that can compute eigenvalues for an operator may implement this interface to allow different algorithms to be used interchangeably. + + + The class `qiskit.algorithms.eigen_solvers.eigen_solver.Eigensolver` is deprecated as of qiskit 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the interface `qiskit.algorithms.eigensolvers.Eigensolver`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +## Methods + +### compute\_eigenvalues + + + +`abstract compute_eigenvalues(operator, aux_operators=None)` + +Computes eigenvalues. Operator and aux\_operators can be supplied here and if not None will override any already set into algorithm so it can be reused with different operators. While an operator is required by algorithms, aux\_operators are optional. To ‘remove’ a previous aux\_operators array use an empty list here. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators, total particle count operators so we can get values for these at the ground state. + +**Returns** + +EigensolverResult + +**Return type** + +[EigensolverResult](qiskit.algorithms.EigensolverResult "qiskit.algorithms.EigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.EigensolverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.EigensolverResult.md new file mode 100644 index 00000000000..03e7cb8b914 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.EigensolverResult.md @@ -0,0 +1,60 @@ +--- +title: EigensolverResult +description: API reference for qiskit.algorithms.EigensolverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.EigensolverResult +--- + +# EigensolverResult + + + +`qiskit.algorithms.EigensolverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigen_solvers/eigen_solver.py "view source code") + +Bases: `AlgorithmResult` + +Deprecated: Eigensolver Result. + +The EigensolverResult class has been superseded by the [`qiskit.algorithms.eigensolvers.EigensolverResult`](qiskit.algorithms.eigensolvers.EigensolverResult "qiskit.algorithms.eigensolvers.EigensolverResult") class. This class will be deprecated in a future release and subsequently removed after that. + + + The class `qiskit.algorithms.eigen_solvers.eigen_solver.EigensolverResult` is deprecated as of qiskit 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.eigensolvers.EigensolverResult`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +## Attributes + + + +### aux\_operator\_eigenvalues + +Return aux operator expectation values. + +These values are in fact tuples formatted as (mean, standard deviation). + + + +### eigenstates + +return eigen states + + + +### eigenvalues + +returns eigen values + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.EstimationProblem.md b/docs/api/qiskit/0.46/qiskit.algorithms.EstimationProblem.md new file mode 100644 index 00000000000..aeac7da70d1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.EstimationProblem.md @@ -0,0 +1,116 @@ +--- +title: EstimationProblem +description: API reference for qiskit.algorithms.EstimationProblem +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.EstimationProblem +--- + +# EstimationProblem + + + +`qiskit.algorithms.EstimationProblem(state_preparation, objective_qubits, grover_operator=None, post_processing=None, is_good_state=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/estimation_problem.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +The estimation problem is the input to amplitude estimation algorithm. + +This class contains all problem-specific information required to run an amplitude estimation algorithm. That means, it minimally contains the state preparation and the specification of the good state. It can further hold some post processing on the estimation of the amplitude or a custom Grover operator. + +**Parameters** + +* **state\_preparation** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A circuit preparing the input state, referred to as $\mathcal{A}$. +* **objective\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A single qubit index or a list of qubit indices to specify which qubits to measure. The `is_good_state` function is applied on the bitstring of these objective qubits. +* **grover\_operator** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – The Grover operator $\mathcal{Q}$ used as unitary in the phase estimation circuit. +* **post\_processing** (*Callable\[\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A mapping applied to the result of the algorithm $0 \leq a \leq 1$, usually used to map the estimate to a target interval. Defaults to the identity. +* **is\_good\_state** (*Callable\[\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*],* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*] | None*) – A function to check whether a string represents a good state. Defaults to all objective qubits being in state $|1\rangle$. + +## Attributes + + + +### grover\_operator + +Get the $\mathcal{Q}$ operator, or Grover operator. + +If the Grover operator is not set, we try to build it from the $\mathcal{A}$ operator and objective\_qubits. This only works if objective\_qubits is a list of integers. + +**Returns** + +The Grover operator, or None if neither the Grover operator nor the $\mathcal{A}$ operator is set. + + + +### has\_good\_state + +Check whether an [`is_good_state`](#qiskit.algorithms.EstimationProblem.is_good_state "qiskit.algorithms.EstimationProblem.is_good_state") function is set. + +Some amplitude estimators, such as [`AmplitudeEstimation`](qiskit.algorithms.AmplitudeEstimation "qiskit.algorithms.AmplitudeEstimation") do not support a custom implementation of the [`is_good_state`](#qiskit.algorithms.EstimationProblem.is_good_state "qiskit.algorithms.EstimationProblem.is_good_state") function, and can only handle the default. + +**Returns** + +`True`, if a custom [`is_good_state`](#qiskit.algorithms.EstimationProblem.is_good_state "qiskit.algorithms.EstimationProblem.is_good_state") is set, otherwise returns `False`. + + + +### is\_good\_state + +Checks whether a bitstring represents a good state. + +**Returns** + +Handle to the `is_good_state` callable. + + + +### objective\_qubits + +Get the criterion for a measurement outcome to be in a ‘good’ state. + +**Returns** + +The criterion as list of qubit indices. + + + +### post\_processing + +Apply post processing to the input value. + +**Returns** + +A handle to the post processing function. Acts as identity by default. + + + +### state\_preparation + +Get the $\mathcal{A}$ operator encoding the amplitude $a$. + +**Returns** + +The $\mathcal{A}$ operator as QuantumCircuit. + +## Methods + +### rescale + + + +`rescale(scaling_factor)` + +Rescale the good state amplitude in the estimation problem. + +**Parameters** + +**scaling\_factor** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The scaling factor in \[0, 1]. + +**Returns** + +A rescaled estimation problem. + +**Return type** + +[*EstimationProblem*](#qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.EvolutionProblem.md b/docs/api/qiskit/0.46/qiskit.algorithms.EvolutionProblem.md new file mode 100644 index 00000000000..64be4821117 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.EvolutionProblem.md @@ -0,0 +1,62 @@ +--- +title: EvolutionProblem +description: API reference for qiskit.algorithms.EvolutionProblem +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.EvolutionProblem +--- + +# EvolutionProblem + + + +`qiskit.algorithms.EvolutionProblem(hamiltonian, time, initial_state=None, aux_operators=None, truncation_threshold=1e-12, t_param=None, param_value_dict=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/evolvers/evolution_problem.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: Evolution problem class. + +The EvolutionProblem class has been superseded by the `qiskit.algorithms.time_evolvers.TimeEvolutionProblem` class. This class will be deprecated in a future release and subsequently removed after that. + +This class is the input to time evolution algorithms and must contain information on the total evolution time, a quantum state to be evolved and under which Hamiltonian the state is evolved. + + + The class `qiskit.algorithms.evolvers.evolution_problem.EvolutionProblem` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.time_evolvers.TimeEvolutionProblem`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **hamiltonian** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – The Hamiltonian under which to evolve the system. +* **time** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Total time of evolution. +* **initial\_state** ([*StateFn*](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.StateFn") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – The quantum state to be evolved for methods like Trotterization. For variational time evolutions, where the evolution happens in an ansatz, this argument is not required. +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the evolved `initial_state` and their expectation values returned. +* **truncation\_threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Defines a threshold under which values can be assumed to be 0. Used when `aux_operators` is provided. +* **t\_param** ([*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter") *| None*) – Time parameter in case of a time-dependent Hamiltonian. This free parameter must be within the `hamiltonian`. +* **param\_value\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] | None*) – Maps free parameters in the problem to values. Depending on the algorithm, it might refer to e.g. a Hamiltonian or an initial state. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If non-positive time of evolution is provided. + +## Attributes + + + +### time + +Returns time. + +## Methods + +### validate\_params + + + +`validate_params()` + +Checks if all parameters present in the Hamiltonian are also present in the dictionary that maps them to values. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If Hamiltonian parameters cannot be bound with data provided. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.EvolutionResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.EvolutionResult.md new file mode 100644 index 00000000000..09ed5d3cd01 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.EvolutionResult.md @@ -0,0 +1,43 @@ +--- +title: EvolutionResult +description: API reference for qiskit.algorithms.EvolutionResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.EvolutionResult +--- + +# EvolutionResult + + + +`qiskit.algorithms.EvolutionResult(evolved_state, aux_ops_evaluated=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/evolvers/evolution_result.py "view source code") + +Bases: `AlgorithmResult` + +Deprecated: Class for holding evolution result. + +The EvolutionResult class has been superseded by the `qiskit.algorithms.time_evolvers.TimeEvolutionResult` class. This class will be deprecated in a future release and subsequently removed after that. + + + The class `qiskit.algorithms.evolvers.evolution_result.EvolutionResult` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.time_evolvers.TimeEvolutionResult`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **evolved\_state** ([*StateFn*](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.StateFn") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – An evolved quantum state. +* **aux\_ops\_evaluated** (*ListOrDict\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]] | None*) – Optional list of observables for which expected values on an evolved state are calculated. These values are in fact tuples formatted as (mean, standard deviation). + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimation.md b/docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimation.md new file mode 100644 index 00000000000..f05209412d3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimation.md @@ -0,0 +1,129 @@ +--- +title: FasterAmplitudeEstimation +description: API reference for qiskit.algorithms.FasterAmplitudeEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.FasterAmplitudeEstimation +--- + +# FasterAmplitudeEstimation + + + +`qiskit.algorithms.FasterAmplitudeEstimation(delta, maxiter, rescale=True, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/fae.py "view source code") + +Bases: [`AmplitudeEstimator`](qiskit.algorithms.AmplitudeEstimator "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimator") + +The Faster Amplitude Estimation algorithm. + +The Faster Amplitude Estimation (FAE) \[1] algorithm is a variant of Quantum Amplitude Estimation (QAE), where the Quantum Phase Estimation (QPE) by an iterative Grover search, similar to \[2]. + +Due to the iterative version of the QPE, this algorithm does not require any additional qubits, as the originally proposed QAE \[3] and thus the resulting circuits are less complex. + +**References** + +**\[1]: K. Nakaji. Faster Amplitude Estimation, 2020;** + +[arXiv:2002.02417](https://arxiv.org/pdf/2003.02417.pdf) + +**\[2]: D. Grinko et al. Iterative Amplitude Estimation, 2019;** + +[arXiv:1912.05559](http://arxiv.org/abs/1912.05559) + +**\[3]: G. Brassard et al. Quantum Amplitude Amplification and Estimation, 2000;** + +[arXiv:quant-ph/0005055](http://arxiv.org/abs/quant-ph/0005055) + + + `qiskit.algorithms.amplitude_estimators.fae.FasterAmplitudeEstimation.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **delta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The probability that the true value is outside of the final confidence interval. +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of iterations, the maximal power of Q is 2 \*\* (maxiter - 1). +* **rescale** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to rescale the problem passed to estimate. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: The quantum instance or backend to run the circuits. +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – A sampler primitive to evaluate the circuits. + + + This algorithm overwrites the number of shots set in the `quantum_instance` argument, but will reset them to the initial number after running. + + +## Attributes + + + +### quantum\_instance + +Deprecated. Get the quantum instance. + + + The property `qiskit.algorithms.amplitude_estimators.fae.FasterAmplitudeEstimation.quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Returns** + +The quantum instance used to run this algorithm. + + + +### sampler + +Get the sampler primitive. + +**Returns** + +The sampler primitive to evaluate the circuits. + +## Methods + +### construct\_circuit + + + +`construct_circuit(estimation_problem, k, measurement=False)` + +Construct the circuit $Q^k X |0\rangle>$. + +The A operator is the unitary specifying the QAE problem and Q the associated Grover operator. + +**Parameters** + +* **estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.EstimationProblem")) – The estimation problem for which to construct the circuit. +* **k** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The power of the Q operator. +* **measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Boolean flag to indicate if measurements should be included in the circuits. + +**Returns** + +The circuit $Q^k X |0\rangle$. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")]] + +### estimate + + + +`estimate(estimation_problem)` + +Run the amplitude estimation algorithm on provided estimation problem. + +**Parameters** + +**estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – The estimation problem. + +**Returns** + +An amplitude estimation results object. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – A quantum instance or Sampler must be provided. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – Sampler run error. + +**Return type** + +[*FasterAmplitudeEstimationResult*](qiskit.algorithms.FasterAmplitudeEstimationResult "qiskit.algorithms.amplitude_estimators.fae.FasterAmplitudeEstimationResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimationResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimationResult.md new file mode 100644 index 00000000000..4dbb1d7c8d1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.FasterAmplitudeEstimationResult.md @@ -0,0 +1,106 @@ +--- +title: FasterAmplitudeEstimationResult +description: API reference for qiskit.algorithms.FasterAmplitudeEstimationResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.FasterAmplitudeEstimationResult +--- + +# FasterAmplitudeEstimationResult + + + +`qiskit.algorithms.FasterAmplitudeEstimationResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/fae.py "view source code") + +Bases: [`AmplitudeEstimatorResult`](qiskit.algorithms.AmplitudeEstimatorResult "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimatorResult") + +The result object for the Faster Amplitude Estimation algorithm. + +## Attributes + + + +### circuit\_results + +Return the circuit results. Can be a statevector or counts dictionary. + + + +### confidence\_interval + +Return the confidence interval for the amplitude (95% interval by default). + + + +### confidence\_interval\_processed + +Return the post-processed confidence interval (95% interval by default). + + + +### estimation + +Return the estimation for the amplitude in $[0, 1]$. + + + +### estimation\_processed + +Return the estimation for the amplitude after the post-processing has been applied. + + + +### num\_first\_state\_steps + +Return the number of steps taken in the first step of algorithm. + + + +### num\_oracle\_queries + +Return the number of Grover oracle queries. + + + +### num\_steps + +Return the total number of steps taken in the algorithm. + + + +### post\_processing + +Return a handle to the post processing function. + + + +### shots + +Return the number of shots used. Is 1 for statevector-based simulations. + + + +### success\_probability + +Return the success probability of the algorithm. + + + +### theta\_intervals + +Return the confidence intervals for the angles in each iteration. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.Grover.md b/docs/api/qiskit/0.46/qiskit.algorithms.Grover.md new file mode 100644 index 00000000000..b7db25ad874 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.Grover.md @@ -0,0 +1,196 @@ +--- +title: Grover +description: API reference for qiskit.algorithms.Grover +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.Grover +--- + +# Grover + + + +`qiskit.algorithms.Grover(iterations=None, growth_rate=None, sample_from_iterations=False, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_amplifiers/grover.py "view source code") + +Bases: [`AmplitudeAmplifier`](qiskit.algorithms.AmplitudeAmplifier "qiskit.algorithms.amplitude_amplifiers.amplitude_amplifier.AmplitudeAmplifier") + +Grover’s Search algorithm. + + + If you want to learn more about the theory behind Grover’s Search algorithm, check out the [Qiskit Textbook](https://qiskit.org/textbook/ch-algorithms/grover.html). or the [Qiskit Tutorials](https://qiskit.org/documentation/tutorials/algorithms/07_grover_examples.html) for more concrete how-to examples. + + +Grover’s Search \[1, 2] is a well known quantum algorithm that can be used for searching through unstructured collections of records for particular targets with quadratic speedup compared to classical algorithms. + +Given a set $X$ of $N$ elements $X=\{x_1,x_2,\ldots,x_N\}$ and a boolean function $f : X \rightarrow \{0,1\}$, the goal of an unstructured-search problem is to find an element $x^* \in X$ such that $f(x^*)=1$. + +The search is called *unstructured* because there are no guarantees as to how the database is ordered. On a sorted database, for instance, one could perform binary search to find an element in $\mathbb{O}(\log N)$ worst-case time. Instead, in an unstructured-search problem, there is no prior knowledge about the contents of the database. With classical circuits, there is no alternative but to perform a linear number of queries to find the target element. Conversely, Grover’s Search algorithm allows to solve the unstructured-search problem on a quantum computer in $\mathcal{O}(\sqrt{N})$ queries. + +To carry out this search a so-called oracle is required, that flags a good element/state. The action of the oracle $\mathcal{S}_f$ is + +$$ +\mathcal{S}_f |x\rangle = (-1)^{f(x)} |x\rangle, +$$ + +i.e. it flips the phase of the state $|x\rangle$ if $x$ is a hit. The details of how $S_f$ works are unimportant to the algorithm; Grover’s search algorithm treats the oracle as a black box. + +This class supports oracles in form of a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +With the given oracle, Grover’s Search constructs the Grover operator to amplify the amplitudes of the good states: + +$$ +\mathcal{Q} = H^{\otimes n} \mathcal{S}_0 H^{\otimes n} \mathcal{S}_f + = D \mathcal{S}_f, +$$ + +where $\mathcal{S}_0$ flips the phase of the all-zero state and acts as identity on all other states. Sometimes the first three operands are summarized as diffusion operator, which implements a reflection over the equal superposition state. + +If the number of solutions is known, we can calculate how often $\mathcal{Q}$ should be applied to find a solution with very high probability, see the method optimal\_num\_iterations. If the number of solutions is unknown, the algorithm tries different powers of Grover’s operator, see the iterations argument, and after each iteration checks if a good state has been measured using good\_state. + +The generalization of Grover’s Search, Quantum Amplitude Amplification \[3], uses a modified version of $\mathcal{Q}$ where the diffusion operator does not reflect about the equal superposition state, but another state specified via an operator $\mathcal{A}$: + +$$ +\mathcal{Q} = \mathcal{A} \mathcal{S}_0 \mathcal{A}^\dagger \mathcal{S}_f. +$$ + +For more information, see the [`GroverOperator`](qiskit.circuit.library.GroverOperator "qiskit.circuit.library.GroverOperator") in the circuit library. + +**References** + +**\[1]: L. K. Grover (1996), A fast quantum mechanical algorithm for database search,** + +[arXiv:quant-ph/9605043](https://arxiv.org/abs/quant-ph/9605043). + +**\[2]: I. Chuang & M. Nielsen, Quantum Computation and Quantum Information,** + +Cambridge: Cambridge University Press, 2000. Chapter 6.1.2. + +**\[3]: Brassard, G., Hoyer, P., Mosca, M., & Tapp, A. (2000).** + +Quantum Amplitude Amplification and Estimation. [arXiv:quant-ph/0005055](http://arxiv.org/abs/quant-ph/0005055). + + + `qiskit.algorithms.amplitude_amplifiers.grover.Grover.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **iterations** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | Iterator\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Specify the number of iterations/power of Grover’s operator to be checked. \* If an int, only one circuit is run with that power of the Grover operator. If the number of solutions is known, this option should be used with the optimal power. The optimal power can be computed with `Grover.optimal_num_iterations`. \* If a list, all the powers in the list are run in the specified order. \* If an iterator, the powers yielded by the iterator are checked, until a maximum number of iterations or maximum power is reached. \* If `None`, the [`AmplificationProblem`](qiskit.algorithms.AmplificationProblem "qiskit.algorithms.AmplificationProblem") provided must have an `is_good_state`, and circuits are run until that good state is reached. +* **growth\_rate** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – If specified, the iterator is set to increasing powers of `growth_rate`, i.e. to `int(growth_rate ** 1), int(growth_rate ** 2), ...` until a maximum number of iterations is reached. +* **sample\_from\_iterations** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, instead of taking the values in `iterations` as powers of the Grover operator, a random integer sample between 0 and smaller value than the iteration is used as a power, see \[1], Section 4. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: A Quantum Instance or Backend to run the circuits. +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – A Sampler to use for sampling the results of the circuits. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `growth_rate` is a float but not larger than 1. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If both `iterations` and `growth_rate` is set. + +**References** + +**\[1]: Boyer et al., Tight bounds on quantum searching** + +[https://arxiv.org/abs/quant-ph/9605034](https://arxiv.org/abs/quant-ph/9605034) + +## Attributes + + + +### quantum\_instance + +Deprecated. Get the quantum instance. + + + The property `qiskit.algorithms.amplitude_amplifiers.grover.Grover.quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Returns** + +The quantum instance used to run this algorithm. + + + +### sampler + +Get the sampler. + +**Returns** + +The sampler used to run this algorithm. + +## Methods + +### amplify + + + +`amplify(amplification_problem)` + +Run the Grover algorithm. + +**Parameters** + +**amplification\_problem** ([*AmplificationProblem*](qiskit.algorithms.AmplificationProblem "qiskit.algorithms.amplitude_amplifiers.amplification_problem.AmplificationProblem")) – The amplification problem. + +**Returns** + +The result as a `GroverResult`, where e.g. the most likely state can be queried as `result.top_measurement`. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If a quantum instance or sampler is not set. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If a sampler job fails. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `is_good_state` is not provided and is required (i.e. when iterations +* **is None**\*\* or ****a list****)\*\* – + +**Return type** + +[*GroverResult*](qiskit.algorithms.GroverResult "qiskit.algorithms.amplitude_amplifiers.grover.GroverResult") + +### construct\_circuit + + + +`construct_circuit(problem, power=None, measurement=False)` + +Construct the circuit for Grover’s algorithm with `power` Grover operators. + +**Parameters** + +* **problem** ([*AmplificationProblem*](qiskit.algorithms.AmplificationProblem "qiskit.algorithms.AmplificationProblem")) – The amplification problem for the algorithm. +* **power** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of times the Grover operator is repeated. If None, this argument is set to the first item in `iterations`. +* **measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Boolean flag to indicate if measurement should be included in the circuit. + +**Returns** + +the QuantumCircuit object for the constructed circuit + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If no power is passed and the iterations are not an integer. + +### optimal\_num\_iterations + + + +`static optimal_num_iterations(num_solutions, num_qubits)` + +Return the optimal number of iterations, if the number of solutions is known. + +**Parameters** + +* **num\_solutions** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of solutions. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits used to encode the states. + +**Returns** + +The optimal number of iterations for Grover’s algorithm to succeed. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.GroverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.GroverResult.md new file mode 100644 index 00000000000..2c282eeee73 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.GroverResult.md @@ -0,0 +1,86 @@ +--- +title: GroverResult +description: API reference for qiskit.algorithms.GroverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.GroverResult +--- + +# GroverResult + + + +`qiskit.algorithms.GroverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_amplifiers/grover.py "view source code") + +Bases: `AmplitudeAmplifierResult` + +Grover Result. + +## Attributes + + + +### assignment + +The post-processed value of the most likely bitstring. + +**Returns** + +The output of the `post_processing` function of the respective `AmplificationProblem`, where the input is the `top_measurement`. The type is the same as the return type of the post-processing function. + + + +### circuit\_results + +Return the circuit results. Can be a statevector or counts dictionary. + + + +### iterations + +All the powers of the Grover operator that have been tried. + +**Returns** + +The powers of the Grover operator tested. + + + +### max\_probability + +Return the maximum sampling probability. + + + +### oracle\_evaluation + +Whether the classical oracle evaluation of the top measurement was True or False. + +**Returns** + +The classical oracle evaluation of the top measurement. + + + +### top\_measurement + +The most frequently measured output as bitstring. + +**Returns** + +The most frequently measured output state. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimation.md b/docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimation.md new file mode 100644 index 00000000000..17276958a9c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimation.md @@ -0,0 +1,90 @@ +--- +title: HamiltonianPhaseEstimation +description: API reference for qiskit.algorithms.HamiltonianPhaseEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.HamiltonianPhaseEstimation +--- + +# HamiltonianPhaseEstimation + + + +`qiskit.algorithms.HamiltonianPhaseEstimation(num_evaluation_qubits, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/phase_estimators/hamiltonian_phase_estimation.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Run the Quantum Phase Estimation algorithm to find the eigenvalues of a Hermitian operator. + +This class is nearly the same as [`PhaseEstimation`](qiskit.algorithms.PhaseEstimation "qiskit.algorithms.PhaseEstimation"), differing only in that the input in that class is a unitary operator, whereas here the input is a Hermitian operator from which a unitary will be obtained by scaling and exponentiating. The scaling is performed in order to prevent the phases from wrapping around $2\pi$. The problem of estimating eigenvalues $\lambda_j$ of the Hermitian operator $H$ is solved by running a circuit representing + +$$ +\exp(i b H) |\psi\rangle = \sum_j \exp(i b \lambda_j) c_j |\lambda_j\rangle, +$$ + +where the input state is + +$$ +|\psi\rangle = \sum_j c_j |\lambda_j\rangle, +$$ + +and $\lambda_j$ are the eigenvalues of $H$. + +Here, $b$ is a scaling factor sufficiently large to map positive $\lambda$ to $[0,\pi)$ and negative $\lambda$ to $[\pi,2\pi)$. Each time the circuit is run, one measures a phase corresponding to $lambda_j$ with probability $|c_j|^2$. + +If $H$ is a Pauli sum, the bound $b$ is computed from the sum of the absolute values of the coefficients of the terms. There is no way to reliably recover eigenvalues from phases very near the endpoints of these intervals. Because of this you should be aware that for degenerate cases, such as $H=Z$, the eigenvalues $\pm 1$ will be mapped to the same phase, $\pi$, and so cannot be distinguished. In this case, you need to specify a larger bound as an argument to the method `estimate`. + +This class uses and works together with [`PhaseEstimationScale`](qiskit.algorithms.PhaseEstimationScale "qiskit.algorithms.PhaseEstimationScale") to manage scaling the Hamiltonian and the phases that are obtained by the QPE algorithm. This includes setting, or computing, a bound on the eigenvalues of the operator, using this bound to obtain a scale factor, scaling the operator, and shifting and scaling the measured phases to recover the eigenvalues. + +Note that, although we speak of “evolving” the state according the Hamiltonian, in the present algorithm, we are not actually considering time evolution. Rather, the role of time is played by the scaling factor, which is chosen to best extract the eigenvalues of the Hamiltonian. + +A few of the ideas in the algorithm may be found in Ref. \[1]. + +**Reference:** + +**\[1]: Quantum phase estimation of multiple eigenvalues for small-scale (noisy) experiments** + +T.E. O’Brien, B. Tarasinski, B.M. Terhal [arXiv:1809.09697](https://arxiv.org/abs/1809.09697) + + + `qiskit.algorithms.phase_estimators.hamiltonian_phase_estimation.HamiltonianPhaseEstimation.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **num\_evaluation\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits used in estimating the phase. The phase will be estimated as a binary string with this many bits. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: The quantum instance on which the circuit will be run. +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – The sampler primitive on which the circuit will be sampled. + +## Methods + +### estimate + + + +`estimate(hamiltonian, state_preparation=None, evolution=None, bound=None)` + +Run the Hamiltonian phase estimation algorithm. + +**Parameters** + +* **hamiltonian** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.PauliOp") *|*[*MatrixOp*](qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.MatrixOp") *|*[*SummedOp*](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp") *|*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") *|*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – A Hermitian operator. If the algorithm is used with a `Sampler` primitive, the allowed types are `Pauli`, `SparsePauliOp`, and `PauliSumOp`. If the algorithm is used with a `QuantumInstance`, `PauliOp, ``MatrixOp`, `PauliSumOp`, and `SummedOp` types are allowed. +* **state\_preparation** ([*StateFn*](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.StateFn") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *| None*) – The `StateFn` to be prepared, whose eigenphase will be measured. If this parameter is omitted, no preparation circuit will be run and input state will be the all-zero state in the computational basis. +* **evolution** ([*EvolutionSynthesis*](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") *|*[*EvolutionBase*](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.EvolutionBase") *| None*) – An evolution converter that generates a unitary from `hamiltonian`. If `None`, then the default `PauliTrotterEvolution` is used. +* **bound** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – An upper bound on the absolute value of the eigenvalues of `hamiltonian`. If omitted, then `hamiltonian` must be a Pauli sum, or a `PauliOp`, in which case a bound will be computed. If `hamiltonian` is a `MatrixOp`, then `bound` may not be `None`. The tighter the bound, the higher the resolution of computed phases. + +**Returns** + +`HamiltonianPhaseEstimationResult` instance containing the result of the estimation and diagnostic information. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `evolution` is not of type `EvolutionSynthesis` when a `Sampler` is provided. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `hamiltonian` type is not `Pauli` or `SparsePauliOp` or `PauliSumOp` when a `Sampler` is provided. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `bound` is `None` and `hamiltonian` is not a Pauli sum, i.e. a `PauliSumOp` or a `SummedOp` whose terms are of type `PauliOp`. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `evolution` is not of type `EvolutionBase` when no `Sampler` is provided. + +**Return type** + +[HamiltonianPhaseEstimationResult](qiskit.algorithms.HamiltonianPhaseEstimationResult "qiskit.algorithms.HamiltonianPhaseEstimationResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimationResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimationResult.md new file mode 100644 index 00000000000..5b81fe777f5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.HamiltonianPhaseEstimationResult.md @@ -0,0 +1,92 @@ +--- +title: HamiltonianPhaseEstimationResult +description: API reference for qiskit.algorithms.HamiltonianPhaseEstimationResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.HamiltonianPhaseEstimationResult +--- + +# HamiltonianPhaseEstimationResult + + + +`qiskit.algorithms.HamiltonianPhaseEstimationResult(phase_estimation_result, phase_estimation_scale, id_coefficient)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/phase_estimators/hamiltonian_phase_estimation_result.py "view source code") + +Bases: `AlgorithmResult` + +Store and manipulate results from running HamiltonianPhaseEstimation. + +This API of this class is nearly the same as PhaseEstimatorResult, differing only in the presence of an additional keyword argument in the methods. If scaled is False, then the phases are not translated and scaled to recover the eigenvalues of the Hamiltonian. Instead phi in $[0, 1)$ is returned, as is the case when then unitary is not derived from a Hamiltonian. + +This class is meant to be instantiated via HamiltonianPhaseEstimation.estimate. + +**Parameters** + +* **phase\_estimation\_result** ([*PhaseEstimationResult*](qiskit.algorithms.PhaseEstimationResult "qiskit.algorithms.PhaseEstimationResult")) – The result object returned by PhaseEstimation.estimate. +* **phase\_estimation\_scale** ([*PhaseEstimationScale*](qiskit.algorithms.PhaseEstimationScale "qiskit.algorithms.PhaseEstimationScale")) – object used to scale phases to obtain eigenvalues. +* **id\_coefficient** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The coefficient of the identity term in the Hamiltonian. Eigenvalues are computed without this term so that the coefficient must added to give correct eigenvalues. This is done automatically when retrieving eigenvalues. + +## Attributes + + + +### most\_likely\_eigenvalue + +The most likely eigenvalue of the Hamiltonian. + +This method calls most\_likely\_phase and scales the result to obtain an eigenvalue. + +**Returns** + +The most likely eigenvalue of the Hamiltonian. + + + +### phase + +The most likely phase of the unitary corresponding to the Hamiltonian. + +**Returns** + +The most likely phase. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + +### filter\_phases + + + +`filter_phases(cutoff=0.0, scaled=True, as_float=True)` + +Filter phases as does PhaseEstimatorResult.filter\_phases, with the addition that phi is shifted and translated to return eigenvalues of the Hamiltonian. + +**Parameters** + +* **cutoff** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Minimum weight of number of counts required to keep a bit string. The default value is 0.0. +* **scaled** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If False, return phi in $[0, 1)$ rather than the eigenvalues of the Hamiltonian. +* **as\_float** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, returned keys are floats in $[0.0, 1.0)$. If False returned keys are bit strings. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if as\_float is False and scaled is True. + +**Returns** + +A dict of filtered phases. + +**Return type** + +Mapping\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") | [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryEvolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryEvolver.md new file mode 100644 index 00000000000..27922a3abc0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryEvolver.md @@ -0,0 +1,48 @@ +--- +title: ImaginaryEvolver +description: API reference for qiskit.algorithms.ImaginaryEvolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.ImaginaryEvolver +--- + +# ImaginaryEvolver + + + +`qiskit.algorithms.ImaginaryEvolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/evolvers/imaginary_evolver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Deprecated: Interface for Quantum Imaginary Time Evolution. + +The ImaginaryEvolver interface has been superseded by the `qiskit.algorithms.time_evolvers.ImaginaryTimeEvolver` interface. This interface will be deprecated in a future release and subsequently removed after that. + + + The class `qiskit.algorithms.evolvers.imaginary_evolver.ImaginaryEvolver` is deprecated as of qiskit 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the interface `qiskit.algorithms.time_evolvers.ImaginaryTimeEvolver`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +## Methods + +### evolve + + + +`abstract evolve(evolution_problem)` + +Perform imaginary time evolution $\exp(-\tau H)|\Psi\rangle$. + +Evolves an initial state $|\Psi\rangle$ for an imaginary time $\tau$ under a Hamiltonian $H$, as provided in the `evolution_problem`. + +**Parameters** + +**evolution\_problem** ([*EvolutionProblem*](qiskit.algorithms.EvolutionProblem "qiskit.algorithms.evolvers.evolution_problem.EvolutionProblem")) – The definition of the evolution problem. + +**Returns** + +Evolution result which includes an evolved quantum state. + +**Return type** + +[*EvolutionResult*](qiskit.algorithms.EvolutionResult "qiskit.algorithms.evolvers.evolution_result.EvolutionResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryTimeEvolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryTimeEvolver.md new file mode 100644 index 00000000000..d69a3a74c68 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.ImaginaryTimeEvolver.md @@ -0,0 +1,42 @@ +--- +title: ImaginaryTimeEvolver +description: API reference for qiskit.algorithms.ImaginaryTimeEvolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.ImaginaryTimeEvolver +--- + +# ImaginaryTimeEvolver + + + +`qiskit.algorithms.ImaginaryTimeEvolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/imaginary_time_evolver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Interface for Quantum Imaginary Time Evolution. + +## Methods + +### evolve + + + +`abstract evolve(evolution_problem)` + +Perform imaginary time evolution $\exp(-\tau H)|\Psi\rangle$. + +Evolves an initial state $|\Psi\rangle$ for an imaginary time $\tau$ under a Hamiltonian $H$, as provided in the `evolution_problem`. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – The definition of the evolution problem. + +**Returns** + +Evolution result which includes an evolved quantum state. + +**Return type** + +[*TimeEvolutionResult*](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.time_evolvers.time_evolution_result.TimeEvolutionResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimation.md b/docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimation.md new file mode 100644 index 00000000000..6469f0cf473 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimation.md @@ -0,0 +1,141 @@ +--- +title: IterativeAmplitudeEstimation +description: API reference for qiskit.algorithms.IterativeAmplitudeEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.IterativeAmplitudeEstimation +--- + +# IterativeAmplitudeEstimation + + + +`qiskit.algorithms.IterativeAmplitudeEstimation(epsilon_target, alpha, confint_method='beta', min_ratio=2, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/iae.py "view source code") + +Bases: [`AmplitudeEstimator`](qiskit.algorithms.AmplitudeEstimator "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimator") + +The Iterative Amplitude Estimation algorithm. + +This class implements the Iterative Quantum Amplitude Estimation (IQAE) algorithm, proposed in \[1]. The output of the algorithm is an estimate that, with at least probability $1 - \alpha$, differs by epsilon to the target value, where both alpha and epsilon can be specified. + +It differs from the original QAE algorithm proposed by Brassard \[2] in that it does not rely on Quantum Phase Estimation, but is only based on Grover’s algorithm. IQAE iteratively applies carefully selected Grover iterations to find an estimate for the target amplitude. + +**References** + +**\[1]: Grinko, D., Gacon, J., Zoufal, C., & Woerner, S. (2019).** + +Iterative Quantum Amplitude Estimation. [arXiv:1912.05559](https://arxiv.org/abs/1912.05559). + +**\[2]: Brassard, G., Hoyer, P., Mosca, M., & Tapp, A. (2000).** + +Quantum Amplitude Amplification and Estimation. [arXiv:quant-ph/0005055](http://arxiv.org/abs/quant-ph/0005055). + +The output of the algorithm is an estimate for the amplitude a, that with at least probability 1 - alpha has an error of epsilon. The number of A operator calls scales linearly in 1/epsilon (up to a logarithmic factor). + + + `qiskit.algorithms.amplitude_estimators.iae.IterativeAmplitudeEstimation.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **epsilon\_target** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Target precision for estimation target a, has values between 0 and 0.5 +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Confidence level, the target probability is 1 - alpha, has values between 0 and 1 +* **confint\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Statistical method used to estimate the confidence intervals in each iteration, can be ‘chernoff’ for the Chernoff intervals or ‘beta’ for the Clopper-Pearson intervals (default) +* **min\_ratio** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Minimal q-ratio ($K_{i+1} / K_i$) for FindNextK +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: Quantum Instance or Backend +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – A sampler primitive to evaluate the circuits. + +**Raises** + +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – if the method to compute the confidence intervals is not supported +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the target epsilon is not in (0, 0.5] +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If alpha is not in (0, 1) +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If confint\_method is not supported + +## Attributes + + + +### epsilon\_target + +Returns the target precision `epsilon_target` of the algorithm. + +**Returns** + +The target precision (which is half the width of the confidence interval). + + + +### quantum\_instance + +Deprecated. Get the quantum instance. + + + The property `qiskit.algorithms.amplitude_estimators.iae.IterativeAmplitudeEstimation.quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Returns** + +The quantum instance used to run this algorithm. + + + +### sampler + +Get the sampler primitive. + +**Returns** + +The sampler primitive to evaluate the circuits. + +## Methods + +### construct\_circuit + + + +`construct_circuit(estimation_problem, k=0, measurement=False)` + +Construct the circuit $\mathcal{Q}^k \mathcal{A} |0\rangle$. + +The A operator is the unitary specifying the QAE problem and Q the associated Grover operator. + +**Parameters** + +* **estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – The estimation problem for which to construct the QAE circuit. +* **k** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The power of the Q operator. +* **measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Boolean flag to indicate if measurements should be included in the circuits. + +**Returns** + +The circuit implementing $\mathcal{Q}^k \mathcal{A} |0\rangle$. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### estimate + + + +`estimate(estimation_problem)` + +Run the amplitude estimation algorithm on provided estimation problem. + +**Parameters** + +**estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – The estimation problem. + +**Returns** + +An amplitude estimation results object. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – A quantum instance or Sampler must be provided. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – Sampler job run error. + +**Return type** + +[*IterativeAmplitudeEstimationResult*](qiskit.algorithms.IterativeAmplitudeEstimationResult "qiskit.algorithms.amplitude_estimators.iae.IterativeAmplitudeEstimationResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimationResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimationResult.md new file mode 100644 index 00000000000..a15dbdf6a71 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.IterativeAmplitudeEstimationResult.md @@ -0,0 +1,130 @@ +--- +title: IterativeAmplitudeEstimationResult +description: API reference for qiskit.algorithms.IterativeAmplitudeEstimationResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.IterativeAmplitudeEstimationResult +--- + +# IterativeAmplitudeEstimationResult + + + +`qiskit.algorithms.IterativeAmplitudeEstimationResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/iae.py "view source code") + +Bases: [`AmplitudeEstimatorResult`](qiskit.algorithms.AmplitudeEstimatorResult "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimatorResult") + +The `IterativeAmplitudeEstimation` result object. + +## Attributes + + + +### alpha + +Return the confidence level $\alpha$. + + + +### circuit\_results + +Return the circuit results. Can be a statevector or counts dictionary. + + + +### confidence\_interval + +Return the confidence interval for the amplitude (95% interval by default). + + + +### confidence\_interval\_processed + +Return the post-processed confidence interval. + + + +### epsilon\_estimated + +Return the estimated half-width of the confidence interval. + + + +### epsilon\_estimated\_processed + +Return the post-processed estimated half-width of the confidence interval. + + + +### epsilon\_target + +Return the target half-width of the confidence interval. + + + +### estimate\_intervals + +Return the confidence intervals for the estimate in each iteration. + + + +### estimation + +Return the estimation for the amplitude in $[0, 1]$. + + + +### estimation\_processed + +Return the estimation for the amplitude after the post-processing has been applied. + + + +### num\_oracle\_queries + +Return the number of Grover oracle queries. + + + +### post\_processing + +Return a handle to the post processing function. + + + +### powers + +Return the powers of the Grover operator in each iteration. + + + +### ratios + +Return the ratios $K_{i+1}/K_{i}$ for each iteration $i$. + + + +### shots + +Return the number of shots used. Is 1 for statevector-based simulations. + + + +### theta\_intervals + +Return the confidence intervals for the angles in each iteration. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.IterativePhaseEstimation.md b/docs/api/qiskit/0.46/qiskit.algorithms.IterativePhaseEstimation.md new file mode 100644 index 00000000000..3095e76d3f6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.IterativePhaseEstimation.md @@ -0,0 +1,92 @@ +--- +title: IterativePhaseEstimation +description: API reference for qiskit.algorithms.IterativePhaseEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.IterativePhaseEstimation +--- + +# IterativePhaseEstimation + + + +`qiskit.algorithms.IterativePhaseEstimation(num_iterations, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/phase_estimators/ipe.py "view source code") + +Bases: `PhaseEstimator` + +Run the Iterative quantum phase estimation (QPE) algorithm. + +Given a unitary circuit and a circuit preparing an eigenstate, return the phase of the eigenvalue as a number in $[0,1)$ using the iterative phase estimation algorithm. + +**\[1]: Dobsicek et al. (2006), Arbitrary accuracy iterative phase estimation algorithm as a two** + +qubit benchmark, [arxiv/quant-ph/0610214](https://arxiv.org/abs/quant-ph/0610214) + + + `qiskit.algorithms.phase_estimators.ipe.IterativePhaseEstimation.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **num\_iterations** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of iterations (rounds) of the phase estimation to run. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: The quantum instance on which the circuit will be run. +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – The sampler primitive on which the circuit will be sampled. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if num\_iterations is not greater than zero. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If neither sampler nor quantum instance is provided. + +## Methods + +### construct\_circuit + + + +`construct_circuit(unitary, state_preparation, k, omega=0.0, measurement=False)` + +Construct the kth iteration Quantum Phase Estimation circuit. + +For details of parameters, see Fig. 2 in [https://arxiv.org/pdf/quant-ph/0610214.pdf](https://arxiv.org/pdf/quant-ph/0610214.pdf). + +**Parameters** + +* **unitary** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The circuit representing the unitary operator whose eigenvalue (via phase) will be measured. +* **state\_preparation** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The circuit that prepares the state whose eigenphase will be measured. If this parameter is omitted, no preparation circuit will be run and input state will be the all-zero state in the computational basis. +* **k** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the iteration idx. +* **omega** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the feedback angle. +* **measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Boolean flag to indicate if measurement should be included in the circuit. + +**Returns** + +the quantum circuit per iteration + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### estimate + + + +`estimate(unitary, state_preparation)` + +Estimate the eigenphase of the input unitary and initial-state pair. + +**Parameters** + +* **unitary** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The circuit representing the unitary operator whose eigenvalue (via phase) will be measured. +* **state\_preparation** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The circuit that prepares the state whose eigenphase will be measured. If this parameter is omitted, no preparation circuit will be run and input state will be the all-zero state in the computational basis. + +**Returns** + +Estimated phase in an IterativePhaseEstimationResult object. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If neither sampler nor quantum instance is provided. + +**Return type** + +*IterativePhaseEstimationResult* + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation.md b/docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation.md new file mode 100644 index 00000000000..a3678f12946 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation.md @@ -0,0 +1,175 @@ +--- +title: MaximumLikelihoodAmplitudeEstimation +description: API reference for qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation +--- + +# MaximumLikelihoodAmplitudeEstimation + + + +`qiskit.algorithms.MaximumLikelihoodAmplitudeEstimation(evaluation_schedule, minimizer=None, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/mlae.py "view source code") + +Bases: [`AmplitudeEstimator`](qiskit.algorithms.AmplitudeEstimator "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimator") + +The Maximum Likelihood Amplitude Estimation algorithm. + +This class implements the quantum amplitude estimation (QAE) algorithm without phase estimation, as introduced in \[1]. In comparison to the original QAE algorithm \[2], this implementation relies solely on different powers of the Grover operator and does not require additional evaluation qubits. Finally, the estimate is determined via a maximum likelihood estimation, which is why this class in named `MaximumLikelihoodAmplitudeEstimation`. + +**References** + +**\[1]: Suzuki, Y., Uno, S., Raymond, R., Tanaka, T., Onodera, T., & Yamamoto, N. (2019).** + +Amplitude Estimation without Phase Estimation. [arXiv:1904.10246](https://arxiv.org/abs/1904.10246). + +**\[2]: Brassard, G., Hoyer, P., Mosca, M., & Tapp, A. (2000).** + +Quantum Amplitude Amplification and Estimation. [arXiv:quant-ph/0005055](http://arxiv.org/abs/quant-ph/0005055). + + + `qiskit.algorithms.amplitude_estimators.mlae.MaximumLikelihoodAmplitudeEstimation.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **evaluation\_schedule** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – If a list, the powers applied to the Grover operator. The list element must be non-negative. If a non-negative integer, an exponential schedule is used where the highest power is 2 to the integer minus 1: \[id, Q^2^0, …, Q^2^(evaluation\_schedule-1)]. +* **minimizer** (*MINIMIZER | None*) – A minimizer used to find the minimum of the likelihood function. Defaults to a brute search where the number of evaluation points is determined according to `evaluation_schedule`. The minimizer takes a function as first argument and a list of (float, float) tuples (as bounds) as second argument and returns a single float which is the found minimum. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: Quantum Instance or Backend +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – A sampler primitive to evaluate the circuits. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the number of oracle circuits is smaller than 1. + +## Attributes + + + +### quantum\_instance + +Deprecated. Get the quantum instance. + + + The property `qiskit.algorithms.amplitude_estimators.mlae.MaximumLikelihoodAmplitudeEstimation.quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Returns** + +The quantum instance used to run this algorithm. + + + +### sampler + +Get the sampler primitive. + +**Returns** + +The sampler primitive to evaluate the circuits. + +## Methods + +### compute\_confidence\_interval + + + +`static compute_confidence_interval(result, alpha, kind='fisher', apply_post_processing=False)` + +Compute the alpha confidence interval using the method kind. + +The confidence level is (1 - alpha) and supported kinds are ‘fisher’, ‘likelihood\_ratio’ and ‘observed\_fisher’ with shorthand notations ‘fi’, ‘lr’ and ‘oi’, respectively. + +**Parameters** + +* **result** ([*MaximumLikelihoodAmplitudeEstimationResult*](qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult "qiskit.algorithms.amplitude_estimators.mlae.MaximumLikelihoodAmplitudeEstimationResult")) – A maximum likelihood amplitude estimation result. +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The confidence level. +* **kind** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The method to compute the confidence interval. Defaults to ‘fisher’, which computes the theoretical Fisher information. +* **apply\_post\_processing** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, apply post-processing to the confidence interval. + +**Returns** + +The specified confidence interval. + +**Raises** + +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If run() hasn’t been called yet. +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If the method kind is not supported. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### compute\_mle + + + +`compute_mle(circuit_results, estimation_problem, num_state_qubits=None, return_counts=False)` + +Compute the MLE via a grid-search. + +This is a stable approach if sufficient gridpoints are used. + +**Parameters** + +* **circuit\_results** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | np.ndarray]*) – A list of circuit outcomes. Can be counts or statevectors. +* **estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.EstimationProblem")) – The estimation problem containing the evaluation schedule and the number of likelihood function evaluations used to find the minimum. +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of state qubits, required for statevector simulations. +* **return\_counts** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, returns the good counts. + +**Returns** + +The MLE for the provided result object. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]] + +### construct\_circuits + + + +`construct_circuits(estimation_problem, measurement=False)` + +Construct the Amplitude Estimation w/o QPE quantum circuits. + +**Parameters** + +* **estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – The estimation problem for which to construct the QAE circuit. +* **measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Boolean flag to indicate if measurement should be included in the circuits. + +**Returns** + +A list with the QuantumCircuit objects for the algorithm. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[qiskit.circuit.quantumcircuit.QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")] + +### estimate + + + +`estimate(estimation_problem)` + +Run the amplitude estimation algorithm on provided estimation problem. + +**Parameters** + +**estimation\_problem** ([*EstimationProblem*](qiskit.algorithms.EstimationProblem "qiskit.algorithms.amplitude_estimators.estimation_problem.EstimationProblem")) – The estimation problem. + +**Returns** + +An amplitude estimation results object. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – A quantum instance or Sampler must be provided. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If state\_preparation is not set in estimation\_problem. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – Sampler job run error + +**Return type** + +[*MaximumLikelihoodAmplitudeEstimationResult*](qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult "qiskit.algorithms.amplitude_estimators.mlae.MaximumLikelihoodAmplitudeEstimationResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult.md new file mode 100644 index 00000000000..88a16515f26 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult.md @@ -0,0 +1,112 @@ +--- +title: MaximumLikelihoodAmplitudeEstimationResult +description: API reference for qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult +--- + +# MaximumLikelihoodAmplitudeEstimationResult + + + +`qiskit.algorithms.MaximumLikelihoodAmplitudeEstimationResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/amplitude_estimators/mlae.py "view source code") + +Bases: [`AmplitudeEstimatorResult`](qiskit.algorithms.AmplitudeEstimatorResult "qiskit.algorithms.amplitude_estimators.amplitude_estimator.AmplitudeEstimatorResult") + +The `MaximumLikelihoodAmplitudeEstimation` result object. + +## Attributes + + + +### circuit\_results + +Return the circuit results. Can be a statevector or counts dictionary. + + + +### confidence\_interval + +Return the confidence interval for the amplitude (95% interval by default). + + + +### confidence\_interval\_processed + +Return the post-processed confidence interval (95% interval by default). + + + +### estimation + +Return the estimation for the amplitude in $[0, 1]$. + + + +### estimation\_processed + +Return the estimation for the amplitude after the post-processing has been applied. + + + +### evaluation\_schedule + +Return the evaluation schedule for the powers of the Grover operator. + + + +### fisher\_information + +Return the Fisher information for the estimated amplitude. + + + +### good\_counts + +Return the percentage of good counts per circuit power. + + + +### minimizer + +Return the minimizer used for the search of the likelihood function. + + + +### num\_oracle\_queries + +Return the number of Grover oracle queries. + + + +### post\_processing + +Return a handle to the post processing function. + + + +### shots + +Return the number of shots used. Is 1 for statevector-based simulations. + + + +### theta + +Return the estimate for the angle $\theta$. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolver.md new file mode 100644 index 00000000000..9dd4b03ecfd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolver.md @@ -0,0 +1,67 @@ +--- +title: MinimumEigensolver +description: API reference for qiskit.algorithms.MinimumEigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.MinimumEigensolver +--- + +# MinimumEigensolver + + + +`qiskit.algorithms.MinimumEigensolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigen_solvers/minimum_eigen_solver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Deprecated: Minimum Eigensolver Interface. + +The Minimum Eigensolver interface has been superseded by the [`qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver") interface. This interface will be deprecated in a future release and subsequently removed after that. + +Algorithms that can compute a minimum eigenvalue for an operator may implement this interface to allow different algorithms to be used interchangeably. + + + The class `qiskit.algorithms.minimum_eigen_solvers.minimum_eigen_solver.MinimumEigensolver` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the interface `qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +## Methods + +### compute\_minimum\_eigenvalue + + + +`abstract compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes minimum eigenvalue. Operator and aux\_operators can be supplied here and if not None will override any already set into algorithm so it can be reused with different operators. While an operator is required by algorithms, aux\_operators are optional. To ‘remove’ a previous aux\_operators array use an empty list here. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators, total particle count operators so we can get values for these at the ground state. + +**Returns** + +MinimumEigensolverResult + +**Return type** + +[MinimumEigensolverResult](qiskit.algorithms.MinimumEigensolverResult "qiskit.algorithms.MinimumEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenstate of the main operator then it can compute the expectation value of the aux\_operators for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolverResult.md new file mode 100644 index 00000000000..361249940ab --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.MinimumEigensolverResult.md @@ -0,0 +1,60 @@ +--- +title: MinimumEigensolverResult +description: API reference for qiskit.algorithms.MinimumEigensolverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.MinimumEigensolverResult +--- + +# MinimumEigensolverResult + + + +`qiskit.algorithms.MinimumEigensolverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigen_solvers/minimum_eigen_solver.py "view source code") + +Bases: `AlgorithmResult` + +Deprecated: Minimum Eigensolver Result. + +The MinimumEigensolverResult class has been superseded by the [`qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult") class. This class will be deprecated in a future release and subsequently removed after that. + + + The class `qiskit.algorithms.minimum_eigen_solvers.minimum_eigen_solver.MinimumEigensolverResult` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +## Attributes + + + +### aux\_operator\_eigenvalues + +Return aux operator expectation values. + +These values are in fact tuples formatted as (mean, standard deviation). + + + +### eigenstate + +return eigen state + + + +### eigenvalue + +returns eigen value + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.NumPyEigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.NumPyEigensolver.md new file mode 100644 index 00000000000..10eac4810ba --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.NumPyEigensolver.md @@ -0,0 +1,88 @@ +--- +title: NumPyEigensolver +description: API reference for qiskit.algorithms.NumPyEigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.NumPyEigensolver +--- + +# NumPyEigensolver + + + +`qiskit.algorithms.NumPyEigensolver(k=1, filter_criterion=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigen_solvers/numpy_eigen_solver.py "view source code") + +Bases: [`Eigensolver`](qiskit.algorithms.Eigensolver "qiskit.algorithms.eigen_solvers.eigen_solver.Eigensolver") + +Deprecated: NumPy Eigensolver algorithm. + +The NumPyEigensolver class has been superseded by the [`qiskit.algorithms.eigensolvers.NumPyEigensolver`](qiskit.algorithms.eigensolvers.NumPyEigensolver "qiskit.algorithms.eigensolvers.NumPyEigensolver") class. This class will be deprecated in a future release and subsequently removed after that. + +NumPy Eigensolver computes up to the first $k$ eigenvalues of a complex-valued square matrix of dimension $n \times n$, with $k \leq n$. + + + Operators are automatically converted to SciPy’s `spmatrix` as needed and this conversion can be costly in terms of memory and performance as the operator size, mostly in terms of number of qubits it represents, gets larger. + + + + The class `qiskit.algorithms.eigen_solvers.numpy_eigen_solver.NumPyEigensolver` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.eigensolvers.NumPyEigensolver`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **k** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – How many eigenvalues are to be computed, has a min. value of 1. +* **filter\_criterion** (*Callable\[\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *| np.ndarray,*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*, ListOrDict\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None],* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – callable that allows to filter eigenvalues/eigenstates, only feasible eigenstates are returned in the results. The callable has the signature filter(eigenstate, eigenvalue, aux\_values) and must return a boolean to indicate whether to keep this value in the final returned result or not. If the number of elements that satisfies the criterion is smaller than k then the returned list has fewer elements and can even be empty. + +## Attributes + + + +### filter\_criterion + +returns the filter criterion if set + + + +### k + +returns k (number of eigenvalues requested) + +## Methods + +### compute\_eigenvalues + + + +`compute_eigenvalues(operator, aux_operators=None)` + +Computes eigenvalues. Operator and aux\_operators can be supplied here and if not None will override any already set into algorithm so it can be reused with different operators. While an operator is required by algorithms, aux\_operators are optional. To ‘remove’ a previous aux\_operators array use an empty list here. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators, total particle count operators so we can get values for these at the ground state. + +**Returns** + +EigensolverResult + +**Return type** + +[EigensolverResult](qiskit.algorithms.EigensolverResult "qiskit.algorithms.EigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.NumPyMinimumEigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.NumPyMinimumEigensolver.md new file mode 100644 index 00000000000..8ebc24d2b58 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.NumPyMinimumEigensolver.md @@ -0,0 +1,77 @@ +--- +title: NumPyMinimumEigensolver +description: API reference for qiskit.algorithms.NumPyMinimumEigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.NumPyMinimumEigensolver +--- + +# NumPyMinimumEigensolver + + + +`qiskit.algorithms.NumPyMinimumEigensolver(filter_criterion=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigen_solvers/numpy_minimum_eigen_solver.py "view source code") + +Bases: [`MinimumEigensolver`](qiskit.algorithms.MinimumEigensolver "qiskit.algorithms.minimum_eigen_solvers.minimum_eigen_solver.MinimumEigensolver") + +Deprecated: Numpy Minimum Eigensolver algorithm. + +The NumPyMinimumEigensolver class has been superseded by the [`qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver") class. This class will be deprecated in a future release and subsequently removed after that. + + + The class `qiskit.algorithms.minimum_eigen_solvers.numpy_minimum_eigen_solver.NumPyMinimumEigensolver` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +**filter\_criterion** (*Callable\[\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *| np.ndarray,*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*, ListOrDict\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None],* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – callable that allows to filter eigenvalues/eigenstates. The minimum eigensolver is only searching over feasible states and returns an eigenstate that has the smallest eigenvalue among feasible states. The callable has the signature filter(eigenstate, eigenvalue, aux\_values) and must return a boolean to indicate whether to consider this value or not. If there is no feasible element, the result can even be empty. + +## Attributes + + + +### filter\_criterion + +returns the filter criterion if set + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes minimum eigenvalue. Operator and aux\_operators can be supplied here and if not None will override any already set into algorithm so it can be reused with different operators. While an operator is required by algorithms, aux\_operators are optional. To ‘remove’ a previous aux\_operators array use an empty list here. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators, total particle count operators so we can get values for these at the ground state. + +**Returns** + +MinimumEigensolverResult + +**Return type** + +[MinimumEigensolverResult](qiskit.algorithms.MinimumEigensolverResult "qiskit.algorithms.MinimumEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenstate of the main operator then it can compute the expectation value of the aux\_operators for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.PVQD.md b/docs/api/qiskit/0.46/qiskit.algorithms.PVQD.md new file mode 100644 index 00000000000..f6e2ec0719e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.PVQD.md @@ -0,0 +1,232 @@ +--- +title: PVQD +description: API reference for qiskit.algorithms.PVQD +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.PVQD +--- + +# PVQD + + + +`qiskit.algorithms.PVQD(fidelity, ansatz, initial_parameters, estimator=None, optimizer=None, num_timesteps=None, evolution=None, use_parameter_shift=True, initial_guess=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/pvqd/pvqd.py "view source code") + +Bases: [`RealTimeEvolver`](qiskit.algorithms.RealTimeEvolver "qiskit.algorithms.time_evolvers.real_time_evolver.RealTimeEvolver") + +The projected Variational Quantum Dynamics (p-VQD) Algorithm. + +In each timestep, this algorithm computes the next state with a Trotter formula (specified by the `evolution` argument) and projects the timestep onto a variational form (`ansatz`). The projection is determined by maximizing the fidelity of the Trotter-evolved state and the ansatz, using a classical optimization routine. See Ref. \[1] for details. + +The following attributes can be set via the initializer but can also be read and updated once the PVQD object has been constructed. + + + +### ansatz + +The parameterized circuit representing the time-evolved state. + +**Type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + +### initial\_parameters + +The parameters of the ansatz at time 0. + +**Type** + +np.ndarray + + + +### optimizer + +The classical optimization routine used to maximize the fidelity of the Trotter step and ansatz. + +**Type** + +Optional\[Union\[[Optimizer](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer"), [Minimizer](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer")]] + + + +### num\_timesteps + +The number of timesteps to take. If None, it is automatically selected to achieve a timestep of approximately 0.01. + +**Type** + +Optional\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + + + +### evolution + +The method to perform the Trotter step. Defaults to first-order Lie-Trotter evolution. + +**Type** + +Optional\[[EvolutionSynthesis](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis")] + + + +### use\_parameter\_shift + +If True, use the parameter shift rule for loss function gradients (if the ansatz supports). + +**Type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + +### initial\_guess + +The starting point for the first classical optimization run, at time 0. Defaults to random values in $[-0.01, 0.01]$. + +**Type** + +Optional\[np.ndarray] + +**Example** + +This snippet computes the real time evolution of a quantum Ising model on two neighboring sites and keeps track of the magnetization. + +```python +import numpy as np + +from qiskit.algorithms.state_fidelities import ComputeUncompute +from qiskit.algorithms.time_evolvers import TimeEvolutionProblem, PVQD +from qiskit.primitives import Estimator, Sampler +from qiskit.circuit.library import EfficientSU2 +from qiskit.quantum_info import SparsePauliOp, Pauli +from qiskit.algorithms.optimizers import L_BFGS_B + +sampler = Sampler() +fidelity = ComputeUncompute(sampler) +estimator = Estimator() +hamiltonian = 0.1 * SparsePauliOp(["ZZ", "IX", "XI"]) +observable = Pauli("ZZ") +ansatz = EfficientSU2(2, reps=1) +initial_parameters = np.zeros(ansatz.num_parameters) + +time = 1 +optimizer = L_BFGS_B() + +# setup the algorithm +pvqd = PVQD( + fidelity, + ansatz, + initial_parameters, + estimator, + num_timesteps=100, + optimizer=optimizer, +) + +# specify the evolution problem +problem = TimeEvolutionProblem( + hamiltonian, time, aux_operators=[hamiltonian, observable] +) + +# and evolve! +result = pvqd.evolve(problem) +``` + +**References** + +**\[1] Stefano Barison, Filippo Vicentini, and Giuseppe Carleo (2021), An efficient** + +quantum algorithm for the time evolution of parameterized circuits, [Quantum 5, 512](https://quantum-journal.org/papers/q-2021-07-28-512/). + +**Parameters** + +* **fidelity** ([*BaseStateFidelity*](qiskit.algorithms.state_fidelities.BaseStateFidelity "qiskit.algorithms.state_fidelities.BaseStateFidelity")) – A fidelity primitive used by the algorithm. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A parameterized circuit preparing the variational ansatz to model the time evolved quantum state. +* **initial\_parameters** (*np.ndarray*) – The initial parameters for the ansatz. Together with the ansatz, these define the initial state of the time evolution. +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") *| None*) – An estimator primitive used for calculating expected values of auxiliary operators (if provided via the problem). +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") *| None*) – The classical optimizers used to minimize the overlap between Trotterization and ansatz. Can be either a [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") or a callable using the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol. This argument is optional since it is not required for [`get_loss()`](#qiskit.algorithms.PVQD.get_loss "qiskit.algorithms.PVQD.get_loss"), but it has to be set before [`evolve()`](#qiskit.algorithms.PVQD.evolve "qiskit.algorithms.PVQD.evolve") is called. +* **num\_timesteps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of time steps. If `None` it will be set such that the timestep is close to 0.01. +* **evolution** ([*EvolutionSynthesis*](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") *| None*) – The evolution synthesis to use for the construction of the Trotter step. Defaults to first-order Lie-Trotter decomposition, see also `evolution` for different options. +* **use\_parameter\_shift** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, use the parameter shift rule to compute gradients. If False, the optimizer will not be passed a gradient callable. In that case, Qiskit optimizers will use a finite difference rule to approximate the gradients. +* **initial\_guess** (*np.ndarray | None*) – The initial guess for the first VQE optimization. Afterwards the previous iteration result is used as initial guess. If None, this is set to a random vector with elements in the interval $[-0.01, 0.01]$. + +## Methods + +### evolve + + + +`evolve(evolution_problem)` + +Perform real time evolution $\exp(-i t H)|\Psi\rangle$. + +Evolves an initial state $|\Psi\rangle$ for a time $t$ under a Hamiltonian $H$, as provided in the `evolution_problem`. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – The evolution problem containing the hamiltonian, total evolution time and observables to evaluate. + +**Returns** + +A result object containing the evolution information and evaluated observables. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `aux_operators` provided in the time evolution problem but no estimator provided to the algorithm. +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If the evolution problem contains an initial state. + +**Return type** + +[*TimeEvolutionResult*](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.time_evolvers.time_evolution_result.TimeEvolutionResult") + +### get\_loss + + + +`get_loss(hamiltonian, ansatz, dt, current_parameters)` + +Get a function to evaluate the infidelity between Trotter step and ansatz. + +**Parameters** + +* **hamiltonian** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – The Hamiltonian under which to evolve. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The parameterized quantum circuit which attempts to approximate the time-evolved state. +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The time step. +* **current\_parameters** (*np.ndarray*) – The current parameters. + +**Returns** + +**A callable to evaluate the infidelity and, if gradients are supported and required,** + +a second callable to evaluate the gradient of the infidelity. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[Callable\[\[np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")], Callable\[\[np.ndarray], np.ndarray]] | None + +### step + + + +`step(hamiltonian, ansatz, theta, dt, initial_guess)` + +Perform a single time step. + +**Parameters** + +* **hamiltonian** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – The Hamiltonian under which to evolve. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The parameterized quantum circuit which attempts to approximate the time-evolved state. +* **theta** (*np.ndarray*) – The current parameters. +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The time step. +* **initial\_guess** (*np.ndarray*) – The initial guess for the classical optimization of the fidelity between the next variational state and the Trotter-evolved last state. If None, this is set to a random vector with elements in the interval $[-0.01, 0.01]$. + +**Returns** + +A tuple consisting of the next parameters and the fidelity of the optimization. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[np.ndarray, [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.PVQDResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.PVQDResult.md new file mode 100644 index 00000000000..4bae482a186 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.PVQDResult.md @@ -0,0 +1,42 @@ +--- +title: PVQDResult +description: API reference for qiskit.algorithms.PVQDResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.PVQDResult +--- + +# PVQDResult + + + +`qiskit.algorithms.PVQDResult(evolved_state, aux_ops_evaluated=None, times=None, parameters=None, fidelities=None, estimated_error=None, observables=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/pvqd/pvqd_result.py "view source code") + +Bases: [`TimeEvolutionResult`](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.time_evolvers.time_evolution_result.TimeEvolutionResult") + +The result object for the p-VQD algorithm. + +**Parameters** + +* **evolved\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – An evolved quantum state. +* **aux\_ops\_evaluated** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]] | None*) – Optional list of observables for which expected values on an evolved state are calculated. These values are in fact tuples formatted as (mean, standard deviation). +* **times** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – The times evaluated during the time integration. +* **parameters** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[np.ndarray] | None*) – The parameter values at each evaluation time. +* **fidelities** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – The fidelity of the Trotter step and variational update at each iteration. +* **estimated\_error** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The overall estimated error evaluated as one minus the product of all fidelities. +* **observables** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – The value of the observables evaluated at each iteration. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimation.md b/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimation.md new file mode 100644 index 00000000000..e32c2a64cb6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimation.md @@ -0,0 +1,128 @@ +--- +title: PhaseEstimation +description: API reference for qiskit.algorithms.PhaseEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.PhaseEstimation +--- + +# PhaseEstimation + + + +`qiskit.algorithms.PhaseEstimation(num_evaluation_qubits, quantum_instance=None, sampler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/phase_estimators/phase_estimation.py "view source code") + +Bases: `PhaseEstimator` + +Run the Quantum Phase Estimation (QPE) algorithm. + +This runs QPE with a multi-qubit register for reading the phases \[1] of input states. + +The algorithm takes as input a unitary $U$ and a state $|\psi\rangle$, which may be written + +$$ +|\psi\rangle = \sum_j c_j |\phi_j\rangle, +$$ + +where $|\phi_j\rangle$ are eigenstates of $U$. We prepare the quantum register in the state $|\psi\rangle$ then apply $U$ leaving the register in the state + +$$ +U|\psi\rangle = \sum_j \exp(i \phi_j) c_j |\phi_j\rangle. +$$ + +In the ideal case, one then measures the phase $\phi_j$ with probability $|c_j|^2$. In practice, many (or all) of the bit strings may be measured due to noise and the possibility that $\phi_j$ may not be representable exactly by the output register. In the latter case the probability for each eigenphase will be spread across bitstrings, with amplitudes that decrease with distance from the bitstring most closely approximating the eigenphase. + +The main input to the constructor is the number of qubits in the phase-reading register. For phase estimation, there are two methods: + +**first. estimate, which takes a state preparation circuit to prepare an input state, and** + +a unitary that will act on the input state. In this case, an instance of `qiskit.circuit.PhaseEstimation`, a QPE circuit, containing the state preparation and input unitary will be constructed. + +**second. estimate\_from\_pe\_circuit, which takes a quantum-phase-estimation circuit in which** + +the unitary and state preparation are already embedded. + +In both estimation methods, the QPE circuit is run on a backend and the frequencies or counts of the phases represented by bitstrings are recorded. The results are returned as an instance of `PhaseEstimationResult`. + +**Reference:** + +**\[1]: Michael A. Nielsen and Isaac L. Chuang. 2011.** + +Quantum Computation and Quantum Information: 10th Anniversary Edition (10th ed.). Cambridge University Press, New York, NY, USA. + + + `qiskit.algorithms.phase_estimators.phase_estimation.PhaseEstimation.__init__()`’s argument `quantum_instance` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the `sampler` argument. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **num\_evaluation\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits used in estimating the phase. The phase will be estimated as a binary string with this many bits. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Deprecated: The quantum instance on which the circuit will be run. +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – The sampler primitive on which the circuit will be sampled. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If neither sampler nor quantum instance is provided. + +## Methods + +### construct\_circuit + + + +`construct_circuit(unitary, state_preparation=None)` + +Return the circuit to be executed to estimate phases. + +This circuit includes as sub-circuits the core phase estimation circuit, with the addition of the state-preparation circuit and possibly measurement instructions. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### estimate + + + +`estimate(unitary, state_preparation=None)` + +Build a phase estimation circuit and run the corresponding algorithm. + +**Parameters** + +* **unitary** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The circuit representing the unitary operator whose eigenvalues (via phase) will be measured. +* **state\_preparation** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – The circuit that prepares the state whose eigenphase will be measured. If this parameter is omitted, no preparation circuit will be run and input state will be the all-zero state in the computational basis. + +**Returns** + +An instance of qiskit.algorithms.phase\_estimator\_result.PhaseEstimationResult. + +**Return type** + +[PhaseEstimationResult](qiskit.algorithms.PhaseEstimationResult "qiskit.algorithms.PhaseEstimationResult") + +### estimate\_from\_pe\_circuit + + + +`estimate_from_pe_circuit(pe_circuit, num_unitary_qubits)` + +Run the phase estimation algorithm on a phase estimation circuit + +**Parameters** + +* **pe\_circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The phase estimation circuit. +* **num\_unitary\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Must agree with the number of qubits in the unitary in pe\_circuit. + +**Returns** + +An instance of qiskit.algorithms.phase\_estimator\_result.PhaseEstimationResult. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – Primitive job failed. + +**Return type** + +[*PhaseEstimationResult*](qiskit.algorithms.PhaseEstimationResult "qiskit.algorithms.phase_estimators.phase_estimation_result.PhaseEstimationResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationResult.md new file mode 100644 index 00000000000..d500ae05dd7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationResult.md @@ -0,0 +1,103 @@ +--- +title: PhaseEstimationResult +description: API reference for qiskit.algorithms.PhaseEstimationResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.PhaseEstimationResult +--- + +# PhaseEstimationResult + + + +`qiskit.algorithms.PhaseEstimationResult(num_evaluation_qubits, circuit_result, phases)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/phase_estimators/phase_estimation_result.py "view source code") + +Bases: `PhaseEstimatorResult` + +Store and manipulate results from running PhaseEstimation. + +This class is instantiated by the `PhaseEstimation` class, not via user code. The `PhaseEstimation` class generates a list of phases and corresponding weights. Upon completion it returns the results as an instance of this class. The main method for accessing the results is filter\_phases. + +The canonical phase satisfying the `PhaseEstimator` interface, returned by the attribute phase, is the most likely phase. + +**Parameters** + +* **num\_evaluation\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits in phase-readout register. +* **circuit\_result** ([*Result*](qiskit.result.Result "qiskit.result.Result")) – result object returned by method running circuit. +* **phases** ([*numpy.ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – ndarray or dict of phases and frequencies determined by QPE. + +## Attributes + + + +### circuit\_result + +Return the result object returned by running the QPE circuit (on hardware or simulator). + +This is useful for inspecting and troubleshooting the QPE algorithm. + + + +### most\_likely\_phase + +DEPRECATED - Return the most likely phase as a number in $[0.0, 1.0)$. + +1.0 corresponds to a phase of $2\pi$. This selects the phase corresponding to the bit string with the highesest probability. This is the most likely phase. + + + The property `qiskit.algorithms.phase_estimators.phase_estimation_result.PhaseEstimationResult.most_likely_phase` is deprecated as of qiskit-terra 0.18.0. It will be removed no earlier than 3 months after the release date. Instead, use the property `phase`, which behaves the same. + + + + +### phase + +Return the most likely phase as a number in $[0.0, 1.0)$. + +1.0 corresponds to a phase of $2\pi$. This selects the phase corresponding to the bit string with the highesest probability. This is the most likely phase. + + + +### phases + +Return all phases and their frequencies computed by QPE. + +This is an array or dict whose values correspond to weights on bit strings. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + +### filter\_phases + + + +`filter_phases(cutoff=0.0, as_float=True)` + +Return a filtered dict of phases (keys) and frequencies (values). + +Only phases with frequencies (counts) larger than cutoff are included. It is assumed that the run method has been called so that the phases have been computed. When using a noiseless, shot-based simulator to read a single phase that can be represented exactly by num\_evaluation\_qubits, all the weight will be concentrated on a single phase. In all other cases, many, or all, bit strings will have non-zero weight. This method is useful for filtering out these uninteresting bit strings. + +**Parameters** + +* **cutoff** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Minimum weight of number of counts required to keep a bit string. The default value is 0.0. +* **as\_float** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, returned keys are floats in $[0.0, 1.0)$. If False returned keys are bit strings. + +**Returns** + +A filtered dict of phases (keys) and frequencies (values). + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationScale.md b/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationScale.md new file mode 100644 index 00000000000..ecbf2957b8f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.PhaseEstimationScale.md @@ -0,0 +1,116 @@ +--- +title: PhaseEstimationScale +description: API reference for qiskit.algorithms.PhaseEstimationScale +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.PhaseEstimationScale +--- + +# PhaseEstimationScale + + + +`qiskit.algorithms.PhaseEstimationScale(bound)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/phase_estimators/phase_estimation_scale.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Set and use a bound on eigenvalues of a Hermitian operator in order to ensure phases are in the desired range and to convert measured phases into eigenvectors. + +The `bound` is set when constructing this class. Then the method `scale` is used to find the factor by which to scale the operator. + +If `bound` is equal exactly to the largest eigenvalue, and the smallest eigenvalue is minus the largest, then these two eigenvalues will not be distinguished. For example, if the Hermitian operator is the Pauli Z operator with eigenvalues $1$ and $-1$, and `bound` is $1$, then both eigenvalues will be mapped to $1$. This can be avoided by making `bound` a bit larger. + +Increasing `bound` decreases the part of the interval $[0, 1)$ that is used to map eigenvalues to `phi`. However, sometimes this results in a better determination of the eigenvalues, because 1) although there are fewer discrete phases in the useful range, it may shift one of the discrete phases closer to the actual phase. And, 2) If one of the discrete phases is close to, or exactly equal to the actual phase, then artifacts (probability) in neighboring phases will be reduced. This is important because the artifacts may be larger than the probability in a phase representing another eigenvalue of interest whose corresponding eigenstate has a relatively small weight in the input state. + +**Parameters** + +**bound** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – an upper bound on the absolute value of the eigenvalues of a Hermitian operator. (The operator is not needed here.) + +## Attributes + + + +### scale + +Return the Hamiltonian scaling factor. + +Return the scale factor by which a Hermitian operator must be multiplied so that the phase of the corresponding unitary is restricted to $[-\pi, \pi]$. This factor is computed from the bound on the absolute values of the eigenvalues of the operator. The methods `scale_phase` and `scale_phases` are used recover the eigenvalues corresponding the original (unscaled) Hermitian operator. + +**Returns** + +The scale factor. + +## Methods + +### from\_pauli\_sum + + + +`classmethod from_pauli_sum(pauli_sum)` + +Create a PhaseEstimationScale from a SummedOp representing a sum of Pauli Operators. + +It is assumed that the `pauli_sum` is the sum of `PauliOp` objects. The bound on the absolute value of the eigenvalues of the sum is obtained as the sum of the absolute values of the coefficients of the terms. This is the best bound available in the generic case. A `PhaseEstimationScale` object is instantiated using this bound. + +**Parameters** + +**pauli\_sum** ([*SummedOp*](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp") *|*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") *|*[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – A `SummedOp` whose terms are `PauliOp` objects. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if `pauli_sum` is not a sum of Pauli operators. + +**Returns** + +A `PhaseEstimationScale` object + +**Return type** + +‘PhaseEstimationScale’ | [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### scale\_phase + + + +`scale_phase(phi, id_coefficient=0.0)` + +Convert a phase into an eigenvalue. + +The input phase `phi` corresponds to the eigenvalue of a unitary obtained by exponentiating a scaled Hermitian operator. Recall that the phase is obtained from `phi` as $2\pi\phi$. Furthermore, the Hermitian operator was scaled so that `phi` is restricted to $[-1/2, 1/2]$, corresponding to phases in $[-\pi, \pi]$. But the values of phi read from the phase-readout register are in $[0, 1)$. Any value of `phi` greater than $1/2$ corresponds to a raw phase of minus the complement with respect to 1. After this possible shift, the phase is scaled by the inverse of the factor by which the Hermitian operator was scaled to recover the eigenvalue of the Hermitian operator. + +**Parameters** + +* **phi** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Normalized phase in $[0, 1)$ to be converted to an eigenvalue. +* **id\_coefficient** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – All eigenvalues are shifted by this value. + +**Returns** + +An eigenvalue computed from the input phase. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### scale\_phases + + + +`scale_phases(phases, id_coefficient=0.0)` + +Convert a list or dict of phases to eigenvalues. + +The values in the list, or keys in the dict, are values of ```phi` and are converted as described in the description of ``scale_phase```. In case `phases` is a dict, the values of the dict are passed unchanged. + +**Parameters** + +* **phases** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – a list or dict of values of `phi`. +* **id\_coefficient** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – All eigenvalues are shifted by this value. + +**Returns** + +Eigenvalues computed from phases. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") | [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.QAOA.md b/docs/api/qiskit/0.46/qiskit.algorithms.QAOA.md new file mode 100644 index 00000000000..6f1fb3443bc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.QAOA.md @@ -0,0 +1,252 @@ +--- +title: QAOA +description: API reference for qiskit.algorithms.QAOA +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.QAOA +--- + +# QAOA + + + +`qiskit.algorithms.QAOA(optimizer=None, reps=1, initial_state=None, mixer=None, initial_point=None, gradient=None, expectation=None, include_custom=False, max_evals_grouped=1, callback=None, quantum_instance=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigen_solvers/qaoa.py "view source code") + +Bases: [`VQE`](qiskit.algorithms.VQE "qiskit.algorithms.minimum_eigen_solvers.vqe.VQE") + +Deprecated: Quantum Approximate Optimization Algorithm. + +The QAOA class has been superseded by the [`qiskit.algorithms.minimum_eigensolvers.QAOA`](qiskit.algorithms.minimum_eigensolvers.QAOA "qiskit.algorithms.minimum_eigensolvers.QAOA") class. This class will be deprecated in a future release and subsequently removed after that. + +[QAOA](https://arxiv.org/abs/1411.4028) is a well-known algorithm for finding approximate solutions to combinatorial-optimization problems. + +The QAOA implementation directly extends [`VQE`](qiskit.algorithms.VQE "qiskit.algorithms.VQE") and inherits VQE’s optimization structure. However, unlike VQE, which can be configured with arbitrary ansatzes, QAOA uses its own fine-tuned ansatz, which comprises $p$ parameterized global $x$ rotations and $p$ different parameterizations of the problem hamiltonian. QAOA is thus principally configured by the single integer parameter, *p*, which dictates the depth of the ansatz, and thus affects the approximation quality. + +An optional array of $2p$ parameter values, as the *initial\_point*, may be provided as the starting **beta** and **gamma** parameters (as identically named in the original [QAOA paper](https://arxiv.org/abs/1411.4028)) for the QAOA ansatz. + +An operator or a parameterized quantum circuit may optionally also be provided as a custom mixer Hamiltonian. This allows, as discussed in [this paper](https://doi.org/10.1103/PhysRevApplied.5.034007) for quantum annealing, and in [this paper](https://arxiv.org/abs/1709.03489) for QAOA, to run constrained optimization problems where the mixer constrains the evolution to a feasible subspace of the full Hilbert space. + + + The class `qiskit.algorithms.minimum_eigen_solvers.qaoa.QAOA` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.minimum_eigensolvers.QAOA`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") *| None*) – A classical optimizer, see also [`VQE`](qiskit.algorithms.VQE "qiskit.algorithms.VQE") for more details on the possible types. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the integer parameter $p$ as specified in [https://arxiv.org/abs/1411.4028](https://arxiv.org/abs/1411.4028), Has a minimum valid value of 1. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – An optional initial state to prepend the QAOA circuit with +* **mixer** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – the mixer Hamiltonian to evolve with or a custom quantum circuit. Allows support of optimizations in constrained subspaces as per [https://arxiv.org/abs/1709.03489](https://arxiv.org/abs/1709.03489) as well as warm-starting the optimization as introduced in [http://arxiv.org/abs/2009.10095](http://arxiv.org/abs/2009.10095). +* **initial\_point** (*np.ndarray | None*) – An optional initial point (i.e. initial parameter values) for the optimizer. If `None` then it will simply compute a random one. +* **gradient** ([*GradientBase*](qiskit.opflow.gradients.GradientBase "qiskit.opflow.gradients.GradientBase") *| Callable\[\[np.ndarray |*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*],* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*] | None*) – An optional gradient operator respectively a gradient function used for optimization. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase") *| None*) – The Expectation converter for taking the average value of the Observable over the ansatz state function. When None (the default) an [`ExpectationFactory`](qiskit.opflow.expectations.ExpectationFactory "qiskit.opflow.expectations.ExpectationFactory") is used to select an appropriate expectation based on the operator and backend. When using Aer qasm\_simulator backend, with paulis, it is however much faster to leverage custom Aer function for the computation but, although VQE performs much faster with it, the outcome is ideal, with no shot noise, like using a state vector simulator. If you are just looking for the quickest performance when choosing Aer qasm\_simulator and the lack of shot noise is not an issue then set include\_custom parameter here to True (defaults to False). +* **include\_custom** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When expectation parameter here is None setting this to True will allow the factory to include the custom Aer pauli expectation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of evaluations performed simultaneously. Signals the given optimizer that more than one set of parameters can be supplied so that potentially the expectation values can be computed in parallel. Typically this is possible when a finite difference gradient is used by the optimizer such that multiple points to compute the gradient can be passed and if computed in parallel improve overall execution time. Ignored if a gradient operator or function is given. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.ndarray,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*], None] | None*) – a callback that can access the intermediate data during the optimization. Four parameter values are passed to the callback as follows during each evaluation by the optimizer for its current set of parameters as it works towards the minimum. These are: the evaluation count, the optimizer parameters for the ansatz, the evaluated mean and the evaluated standard deviation. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Quantum Instance or Backend + +## Attributes + + + +### ansatz + +Returns the ansatz. + + + +### callback + +Returns callback + + + +### expectation + +The expectation value algorithm used to construct the expectation measurement from the observable. + + + +### gradient + +Returns the gradient. + + + +### include\_custom + +Returns include\_custom + + + +### initial\_point + +Returns initial point + + + +### initial\_state + +Returns: Returns the initial state. + + + +### max\_evals\_grouped + +Returns max\_evals\_grouped + + + +### mixer + +Returns: Returns the mixer. + + + +### optimizer + +Returns optimizer + + + +### quantum\_instance + +Returns quantum instance. + + + +### setting + +Prepare the setting of VQE as a string. + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes minimum eigenvalue. Operator and aux\_operators can be supplied here and if not None will override any already set into algorithm so it can be reused with different operators. While an operator is required by algorithms, aux\_operators are optional. To ‘remove’ a previous aux\_operators array use an empty list here. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators, total particle count operators so we can get values for these at the ground state. + +**Returns** + +MinimumEigensolverResult + +**Return type** + +[MinimumEigensolverResult](qiskit.algorithms.MinimumEigensolverResult "qiskit.algorithms.MinimumEigensolverResult") + +### construct\_circuit + + + +`construct_circuit(parameter, operator)` + +Return the circuits used to compute the expectation value. + +**Parameters** + +* **parameter** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | np.ndarray*) – Parameters for the ansatz circuit. +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable + +**Returns** + +A list of the circuits used to compute the expectation value. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")] + +### construct\_expectation + + + +`construct_expectation(parameter, operator, return_expectation=False)` + +Generate the ansatz circuit and expectation value measurement, and return their runnable composition. + +**Parameters** + +* **parameter** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | np.ndarray*) – Parameters for the ansatz circuit. +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **return\_expectation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, return the `ExpectationBase` expectation converter used in the construction of the expectation value. Useful e.g. to compute the standard deviation of the expectation value. + +**Returns** + +The Operator equalling the measurement of the ansatz `StateFn` by the Observable’s expectation `StateFn`, and, optionally, the expectation converter. + +**Raises** + +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If no operator has been provided. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If no expectation is passed and None could be inferred via the ExpectationFactory. + +**Return type** + +[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase"), [ExpectationBase](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")] + +### get\_energy\_evaluation + + + +`get_energy_evaluation(operator, return_expectation=False)` + +Returns a function handle to evaluates the energy at given parameters for the ansatz. + +This is the objective function to be passed to the optimizer that is used for evaluation. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – The operator whose energy to evaluate. +* **return\_expectation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, return the `ExpectationBase` expectation converter used in the construction of the expectation value. Useful e.g. to evaluate other operators with the same expectation value converter. + +**Returns** + +Energy of the hamiltonian of each parameter, and, optionally, the expectation converter. + +**Raises** + +[**RuntimeError**](https://docs.python.org/3/library/exceptions.html#RuntimeError "(in Python v3.12)") – If the circuit is not parameterized (i.e. has 0 free parameters). + +**Return type** + +Callable\[\[np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]] | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[Callable\[\[np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]], [ExpectationBase](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")] + +### print\_settings + + + +`print_settings()` + +Preparing the setting of VQE into a string. + +**Returns** + +the formatted setting of VQE + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenstate of the main operator then it can compute the expectation value of the aux\_operators for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.RealEvolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.RealEvolver.md new file mode 100644 index 00000000000..9f3765e6997 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.RealEvolver.md @@ -0,0 +1,48 @@ +--- +title: RealEvolver +description: API reference for qiskit.algorithms.RealEvolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.RealEvolver +--- + +# RealEvolver + + + +`qiskit.algorithms.RealEvolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/evolvers/real_evolver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Deprecated: Interface for Quantum Real Time Evolution. + +The RealEvolver interface has been superseded by the `qiskit.algorithms.time_evolvers.RealTimeEvolver` interface. This interface will be deprecated in a future release and subsequently removed after that. + + + The class `qiskit.algorithms.evolvers.real_evolver.RealEvolver` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the interface `qiskit.algorithms.time_evolvers.RealTimeEvolver`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +## Methods + +### evolve + + + +`abstract evolve(evolution_problem)` + +Perform real time evolution $\exp(-i t H)|\Psi\rangle$. + +Evolves an initial state $|\Psi\rangle$ for a time $t$ under a Hamiltonian $H$, as provided in the `evolution_problem`. + +**Parameters** + +**evolution\_problem** ([*EvolutionProblem*](qiskit.algorithms.EvolutionProblem "qiskit.algorithms.evolvers.evolution_problem.EvolutionProblem")) – The definition of the evolution problem. + +**Returns** + +Evolution result which includes an evolved quantum state. + +**Return type** + +[*EvolutionResult*](qiskit.algorithms.EvolutionResult "qiskit.algorithms.evolvers.evolution_result.EvolutionResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.RealTimeEvolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.RealTimeEvolver.md new file mode 100644 index 00000000000..9ff195c72a6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.RealTimeEvolver.md @@ -0,0 +1,42 @@ +--- +title: RealTimeEvolver +description: API reference for qiskit.algorithms.RealTimeEvolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.RealTimeEvolver +--- + +# RealTimeEvolver + + + +`qiskit.algorithms.RealTimeEvolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/real_time_evolver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Interface for Quantum Real Time Evolution. + +## Methods + +### evolve + + + +`abstract evolve(evolution_problem)` + +Perform real time evolution $\exp(-i t H)|\Psi\rangle$. + +Evolves an initial state $|\Psi\rangle$ for a time $t$ under a Hamiltonian $H$, as provided in the `evolution_problem`. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – The definition of the evolution problem. + +**Returns** + +Evolution result which includes an evolved quantum state. + +**Return type** + +[*TimeEvolutionResult*](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.time_evolvers.time_evolution_result.TimeEvolutionResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.SciPyImaginaryEvolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.SciPyImaginaryEvolver.md new file mode 100644 index 00000000000..dc36939ecd0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.SciPyImaginaryEvolver.md @@ -0,0 +1,52 @@ +--- +title: SciPyImaginaryEvolver +description: API reference for qiskit.algorithms.SciPyImaginaryEvolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.SciPyImaginaryEvolver +--- + +# SciPyImaginaryEvolver + + + +`qiskit.algorithms.SciPyImaginaryEvolver(num_timesteps)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/classical_methods/scipy_imaginary_evolver.py "view source code") + +Bases: [`ImaginaryTimeEvolver`](qiskit.algorithms.ImaginaryTimeEvolver "qiskit.algorithms.time_evolvers.imaginary_time_evolver.ImaginaryTimeEvolver") + +Classical Evolver for imaginary time evolution. + +Evolves an initial state $|\Psi\rangle$ for an imaginary time $\tau = it$ under a Hamiltonian $H$, as provided in the `evolution_problem`. Note that the precision of the evolver does not depend on the number of timesteps taken. + +**Parameters** + +**num\_timesteps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of timesteps in the simulation. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If num\_timesteps is not a positive integer. + +## Methods + +### evolve + + + +`evolve(evolution_problem)` + +Perform imaginary time evolution $\exp(-\tau H)|\Psi\rangle$. + +Evolves an initial state $|\Psi\rangle$ for an imaginary time $\tau$ under a Hamiltonian $H$, as provided in the `evolution_problem`. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – The definition of the evolution problem. + +**Returns** + +Evolution result which includes an evolved quantum state. + +**Return type** + +[*TimeEvolutionResult*](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.time_evolvers.time_evolution_result.TimeEvolutionResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.SciPyRealEvolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.SciPyRealEvolver.md new file mode 100644 index 00000000000..04b53286b88 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.SciPyRealEvolver.md @@ -0,0 +1,52 @@ +--- +title: SciPyRealEvolver +description: API reference for qiskit.algorithms.SciPyRealEvolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.SciPyRealEvolver +--- + +# SciPyRealEvolver + + + +`qiskit.algorithms.SciPyRealEvolver(num_timesteps)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/classical_methods/scipy_real_evolver.py "view source code") + +Bases: [`RealTimeEvolver`](qiskit.algorithms.RealTimeEvolver "qiskit.algorithms.time_evolvers.real_time_evolver.RealTimeEvolver") + +Classical Evolver for real time evolution. + +Evolves an initial state $|\Psi\rangle$ for a time $t$ under a Hamiltonian $H$, as provided in the `evolution_problem`. Note that the precision of the evolver does not depend on the number of timesteps taken. + +**Parameters** + +**num\_timesteps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of timesteps in the simulation. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If steps is not a positive integer. + +## Methods + +### evolve + + + +`evolve(evolution_problem)` + +Perform real time evolution $\exp(-i t H)|\Psi\rangle$. + +Evolves an initial state $|\Psi\rangle$ for a time $t$ under a Hamiltonian $H$, as provided in the `evolution_problem`. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – The definition of the evolution problem. + +**Returns** + +Evolution result which includes an evolved quantum state. + +**Return type** + +[*TimeEvolutionResult*](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.time_evolvers.time_evolution_result.TimeEvolutionResult") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionProblem.md b/docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionProblem.md new file mode 100644 index 00000000000..f19ac2c85e2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionProblem.md @@ -0,0 +1,116 @@ +--- +title: TimeEvolutionProblem +description: API reference for qiskit.algorithms.TimeEvolutionProblem +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.TimeEvolutionProblem +--- + +# TimeEvolutionProblem + + + +`qiskit.algorithms.TimeEvolutionProblem(hamiltonian, time, initial_state=None, aux_operators=None, truncation_threshold=1e-12, t_param=None, param_value_map=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/time_evolution_problem.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Time evolution problem class. + +This class is the input to time evolution algorithms and must contain information on the total evolution time, a quantum state to be evolved and under which Hamiltonian the state is evolved. + + + +### hamiltonian + +The Hamiltonian under which to evolve the system. + +**Type** + +BaseOperator | [PauliSumOp](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") + + + +### initial\_state + +The quantum state to be evolved for methods like Trotterization. For variational time evolutions, where the evolution happens in an ansatz, this argument is not required. + +**Type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") | [Statevector](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") | None + + + +### aux\_operators + +Optional list of auxiliary operators to be evaluated with the evolved `initial_state` and their expectation values returned. + +**Type** + +ListOrDict\[BaseOperator | [PauliSumOp](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")] | None + + + +### truncation\_threshold + +Defines a threshold under which values can be assumed to be 0. Used when `aux_operators` is provided. + +**Type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + + + +### t\_param + +Time parameter in case of a time-dependent Hamiltonian. This free parameter must be within the `hamiltonian`. + +**Type** + +[Parameter](qiskit.circuit.Parameter "qiskit.circuit.Parameter") | None + + + +### param\_value\_map + +Maps free parameters in the problem to values. Depending on the algorithm, it might refer to e.g. a Hamiltonian or an initial state. + +**Type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[Parameter](qiskit.circuit.Parameter "qiskit.circuit.Parameter"), [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")] | None + +**Parameters** + +* **hamiltonian** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – The Hamiltonian under which to evolve the system. +* **time** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Total time of evolution. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *| None*) – The quantum state to be evolved for methods like Trotterization. For variational time evolutions, where the evolution happens in an ansatz, this argument is not required. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the evolved `initial_state` and their expectation values returned. +* **truncation\_threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Defines a threshold under which values can be assumed to be 0. Used when `aux_operators` is provided. +* **t\_param** ([*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter") *| None*) – Time parameter in case of a time-dependent Hamiltonian. This free parameter must be within the `hamiltonian`. +* **param\_value\_map** (*Mapping\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] | None*) – Maps free parameters in the problem to values. Depending on the algorithm, it might refer to e.g. a Hamiltonian or an initial state. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If non-positive time of evolution is provided. + +## Attributes + + + +### time + +Returns time. + +## Methods + +### validate\_params + + + +`validate_params()` + +Checks if all parameters present in the Hamiltonian are also present in the dictionary that maps them to values. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If Hamiltonian parameters cannot be bound with data provided. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionResult.md new file mode 100644 index 00000000000..3000cb287b0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.TimeEvolutionResult.md @@ -0,0 +1,79 @@ +--- +title: TimeEvolutionResult +description: API reference for qiskit.algorithms.TimeEvolutionResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.TimeEvolutionResult +--- + +# TimeEvolutionResult + + + +`qiskit.algorithms.TimeEvolutionResult(evolved_state, aux_ops_evaluated=None, observables=None, times=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/time_evolution_result.py "view source code") + +Bases: `AlgorithmResult` + +Class for holding time evolution result. + + + +### evolved\_state + +An evolved quantum state. + +**Type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")|[Statevector](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + + + +### aux\_ops\_evaluated + +Optional list of observables for which expected values on an evolved state are calculated. These values are in fact tuples formatted as (mean, standard deviation). + +**Type** + +ListOrDict\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)"), [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")]] | None + + + +### observables + +Optional list of observables for which expected on an evolved state are calculated at each timestep. These values are in fact lists of tuples formatted as (mean, standard deviation). + +**Type** + +ListOrDict\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[np.ndarray, np.ndarray]] | None + + + +### times + +Optional list of times at which each observable has been evaluated. + +**Type** + +np.array | None + +**Parameters** + +* **evolved\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")) – An evolved quantum state. +* **aux\_ops\_evaluated** (*ListOrDict\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]] | None*) – Optional list of observables for which expected values on an evolved state are calculated. These values are in fact tuples formatted as (mean, standard deviation). +* **observables** (*ListOrDict\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[np.ndarray, np.ndarray]] | None*) – Optional list of observables for which expected values are calculated for each timestep. These values are in fact tuples formatted as (mean array, standard deviation array). +* **times** (*np.ndarray | None*) – Optional list of times at which each observable has been evaluated. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.TrotterQRTE.md b/docs/api/qiskit/0.46/qiskit.algorithms.TrotterQRTE.md new file mode 100644 index 00000000000..18315511224 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.TrotterQRTE.md @@ -0,0 +1,120 @@ +--- +title: TrotterQRTE +description: API reference for qiskit.algorithms.TrotterQRTE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.TrotterQRTE +--- + +# TrotterQRTE + + + +`qiskit.algorithms.TrotterQRTE(product_formula=None, expectation=None, quantum_instance=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/evolvers/trotterization/trotter_qrte.py "view source code") + +Bases: [`RealEvolver`](qiskit.algorithms.RealEvolver "qiskit.algorithms.evolvers.real_evolver.RealEvolver") + +Deprecated: Quantum Real Time Evolution using Trotterization. + +The TrotterQRTE class has been superseded by the [`qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE`](qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE "qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE") class. This class will be deprecated in a future release and subsequently removed after that. + +Type of Trotterization is defined by a ProductFormula provided. + +Examples: + +```python +from qiskit.opflow import X, Z, Zero +from qiskit.algorithms import EvolutionProblem, TrotterQRTE +from qiskit import BasicAer +from qiskit.utils import QuantumInstance + +operator = X + Z +initial_state = Zero +time = 1 +evolution_problem = EvolutionProblem(operator, 1, initial_state) +# LieTrotter with 1 rep +backend = BasicAer.get_backend("statevector_simulator") +quantum_instance = QuantumInstance(backend=backend) +trotter_qrte = TrotterQRTE(quantum_instance=quantum_instance) +evolved_state = trotter_qrte.evolve(evolution_problem).evolved_state +``` + + + The class `qiskit.algorithms.evolvers.trotterization.trotter_qrte.TrotterQRTE` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **product\_formula** ([*ProductFormula*](qiskit.synthesis.ProductFormula "qiskit.synthesis.ProductFormula") *| None*) – A Lie-Trotter-Suzuki product formula. The default is the Lie-Trotter first order product formula with a single repetition. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase") *| None*) – An instance of ExpectationBase which defines a method for calculating expectation values of EvolutionProblem.aux\_operators. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – A quantum instance used for calculating expectation values of EvolutionProblem.aux\_operators. + +## Attributes + + + +### expectation + +Returns an expectation used in the algorithm. + + + +### product\_formula + +Returns a product formula used in the algorithm. + + + +### quantum\_instance + +Returns a quantum instance used in the algorithm. + +## Methods + +### evolve + + + +`evolve(evolution_problem)` + +Evolves a quantum state for a given time using the Trotterization method based on a product formula provided. The result is provided in the form of a quantum circuit. If auxiliary operators are included in the `evolution_problem`, they are evaluated on an evolved state using a backend provided. + + + Time-dependent Hamiltonians are not yet supported. + + +**Parameters** + +**evolution\_problem** ([*EvolutionProblem*](qiskit.algorithms.EvolutionProblem "qiskit.algorithms.evolvers.evolution_problem.EvolutionProblem")) – Instance defining evolution problem. For the included Hamiltonian, `PauliOp`, `SummedOp` or `PauliSumOp` are supported by TrotterQRTE. + +**Returns** + +Evolution result that includes an evolved state as a quantum circuit and, optionally, auxiliary operators evaluated for a resulting state on a backend. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `t_param` is not set to None in the EvolutionProblem (feature not currently supported). +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the `initial_state` is not provided in the EvolutionProblem. + +**Return type** + +[*EvolutionResult*](qiskit.algorithms.EvolutionResult "qiskit.algorithms.evolvers.evolution_result.EvolutionResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +**Returns** + +**True if `aux_operators` expectations in the EvolutionProblem can be evaluated, False** + +otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.VQD.md b/docs/api/qiskit/0.46/qiskit.algorithms.VQD.md new file mode 100644 index 00000000000..1e31358f840 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.VQD.md @@ -0,0 +1,243 @@ +--- +title: VQD +description: API reference for qiskit.algorithms.VQD +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.VQD +--- + +# VQD + + + +`qiskit.algorithms.VQD(ansatz=None, k=2, betas=None, optimizer=None, initial_point=None, gradient=None, expectation=None, include_custom=False, max_evals_grouped=1, callback=None, quantum_instance=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigen_solvers/vqd.py "view source code") + +Bases: `VariationalAlgorithm`, [`Eigensolver`](qiskit.algorithms.Eigensolver "qiskit.algorithms.eigen_solvers.eigen_solver.Eigensolver") + +Deprecated: Variational Quantum Deflation algorithm. + +The VQD class has been superseded by the [`qiskit.algorithms.eigensolvers.VQD`](qiskit.algorithms.eigensolvers.VQD "qiskit.algorithms.eigensolvers.VQD") class. This class will be deprecated in a future release and subsequently removed after that. + +[VQD](https://arxiv.org/abs/1805.08138) is a quantum algorithm that uses a variational technique to find the k eigenvalues of the Hamiltonian $H$ of a given system. + +The algorithm computes excited state energies of generalised hamiltonians by optimising over a modified cost function where each succesive eigen value is calculated iteratively by introducing an overlap term with all the previously computed eigenstaes that must be minimised, thus ensuring higher energy eigen states are found. + +An instance of VQD requires defining three algorithmic sub-components: an integer k denoting the number of eigenstates to calculate, a trial state (a.k.a. ansatz)which is a `QuantumCircuit`, and one of the classical [`optimizers`](qiskit.algorithms.optimizers#module-qiskit.algorithms.optimizers "qiskit.algorithms.optimizers"). The ansatz is varied, via its set of parameters, by the optimizer, such that it works towards a state, as determined by the parameters applied to the ansatz, that will result in the minimum expectation values being measured of the input operator (Hamiltonian). The algorithm does this by iteratively refining each excited state to be orthogonal to all the previous excited states. + +An optional array of parameter values, via the *initial\_point*, may be provided as the starting point for the search of the minimum eigenvalue. This feature is particularly useful such as when there are reasons to believe that the solution point is close to a particular point. + +The length of the *initial\_point* list value must match the number of the parameters expected by the ansatz being used. If the *initial\_point* is left at the default of `None`, then VQD will look to the ansatz for a preferred value, based on its given initial state. If the ansatz returns `None`, then a random point will be generated within the parameter bounds set, as per above. If the ansatz provides `None` as the lower bound, then VQD will default it to $-2\pi$; similarly, if the ansatz returns `None` as the upper bound, the default value will be $2\pi$. + + + The class `qiskit.algorithms.eigen_solvers.vqd.VQD` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.eigensolvers.VQD`.See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A parameterized circuit used as ansatz for the wave function. +* **k** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of eigenvalues to return. Returns the lowest k eigenvalues. +* **betas** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – beta parameters in the VQD paper. Should have length k - 1, with k the number of excited states. These hyperparameters balance the contribution of each overlap term to the cost function and have a default value computed as the mean square sum of the coefficients of the observable. +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") *| None*) – A classical optimizer. Can either be a Qiskit optimizer or a callable that takes an array as input and returns a Qiskit or SciPy optimization result. +* **initial\_point** (*np.ndarray | None*) – An optional initial point (i.e. initial parameter values) for the optimizer. If `None` then VQD will look to the ansatz for a preferred point and if not will simply compute a random one. +* **gradient** ([*GradientBase*](qiskit.opflow.gradients.GradientBase "qiskit.opflow.gradients.GradientBase") *| Callable | None*) – An optional gradient function or operator for optimizer. Only used to compute the ground state at the moment. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase") *| None*) – The Expectation converter for taking the average value of the Observable over the ansatz state function. When `None` (the default) an [`ExpectationFactory`](qiskit.opflow.expectations.ExpectationFactory "qiskit.opflow.expectations.ExpectationFactory") is used to select an appropriate expectation based on the operator and backend. When using Aer qasm\_simulator backend, with paulis, it is however much faster to leverage custom Aer function for the computation but, although VQD performs much faster with it, the outcome is ideal, with no shot noise, like using a state vector simulator. If you are just looking for the quickest performance when choosing Aer qasm\_simulator and the lack of shot noise is not an issue then set include\_custom parameter here to `True` (defaults to `False`). +* **include\_custom** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When expectation parameter here is None setting this to `True` will allow the factory to include the custom Aer pauli expectation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of evaluations performed simultaneously. Signals the given optimizer that more than one set of parameters can be supplied so that multiple points to compute the gradient can be passed and if computed in parallel potentially the expectation values can be computed in parallel. Typically this is possible when a finite difference gradient is used by the optimizer such that improve overall execution time. Deprecated if a gradient operator or function is given. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.ndarray,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*], None] | None*) – a callback that can access the intermediate data during the optimization. Four parameter values are passed to the callback as follows during each evaluation by the optimizer for its current set of parameters as it works towards the minimum. These are: the evaluation count, the optimizer parameters for the ansatz, the evaluated mean, the evaluated standard deviation, and the current step. +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Quantum Instance or Backend + +## Attributes + + + +### ansatz + +Returns the ansatz. + + + +### callback + +Returns callback + + + +### expectation + +The expectation value algorithm used to construct the expectation measurement from the observable. + + + +### gradient + +Returns the gradient. + + + +### include\_custom + +Returns include\_custom + + + +### initial\_point + +Returns initial point. + + + +### max\_evals\_grouped + +Returns max\_evals\_grouped + + + +### optimizer + +Returns optimizer + + + +### quantum\_instance + +Returns quantum instance. + + + +### setting + +Prepare the setting of VQD as a string. + +## Methods + +### compute\_eigenvalues + + + +`compute_eigenvalues(operator, aux_operators=None)` + +Computes eigenvalues. Operator and aux\_operators can be supplied here and if not None will override any already set into algorithm so it can be reused with different operators. While an operator is required by algorithms, aux\_operators are optional. To ‘remove’ a previous aux\_operators array use an empty list here. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators, total particle count operators so we can get values for these at the ground state. + +**Returns** + +EigensolverResult + +**Return type** + +[EigensolverResult](qiskit.algorithms.EigensolverResult "qiskit.algorithms.EigensolverResult") + +### construct\_circuit + + + +`construct_circuit(parameter, operator)` + +Return the circuits used to compute the expectation value. + +**Parameters** + +* **parameter** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | np.ndarray*) – Parameters for the ansatz circuit. +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable + +**Returns** + +A list of the circuits used to compute the expectation value. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")] + +### construct\_expectation + + + +`construct_expectation(parameter, operator, return_expectation=False)` + +Generate the ansatz circuit and expectation value measurement, and return their runnable composition. + +**Parameters** + +* **parameter** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | np.ndarray*) – Parameters for the ansatz circuit. +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **return\_expectation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, return the `ExpectationBase` expectation converter used in the construction of the expectation value. Useful e.g. to compute the standard deviation of the expectation value. + +**Returns** + +The Operator equalling the measurement of the ansatz `StateFn` by the Observable’s expectation `StateFn`, and, optionally, the expectation converter. + +**Raises** + +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If no operator has been provided. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If no expectation is passed and None could be inferred via the ExpectationFactory. + +**Return type** + +[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase"), [ExpectationBase](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")] + +### get\_energy\_evaluation + + + +`get_energy_evaluation(step, operator, return_expectation=False, prev_states=None)` + +Returns a function handle to evaluates the energy at given parameters for the ansatz. + +This return value is the objective function to be passed to the optimizer for evaluation. + +**Parameters** + +* **step** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – level of energy being calculated. 0 for ground, 1 for first excited state… +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – The operator whose energy to evaluate. +* **return\_expectation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, return the `ExpectationBase` expectation converter used in the construction of the expectation value. Useful e.g. to evaluate other operators with the same expectation value converter. +* **prev\_states** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[np.ndarray] | None*) – List of parameters from previous rounds of optimization. + +**Returns** + +A callable that computes and returns the energy of the hamiltonian of each parameter, and, optionally, the expectation + +**Raises** + +* [**RuntimeError**](https://docs.python.org/3/library/exceptions.html#RuntimeError "(in Python v3.12)") – If the circuit is not parameterized (i.e. has 0 free parameters). +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If operator was not provided. + +**Return type** + +Callable\[\[np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]] | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[Callable\[\[np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]], [ExpectationBase](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")] + +### print\_settings + + + +`print_settings()` + +Preparing the setting of VQD into a string. + +**Returns** + +the formatted setting of VQD. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.VQDResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.VQDResult.md new file mode 100644 index 00000000000..d89e9745884 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.VQDResult.md @@ -0,0 +1,108 @@ +--- +title: VQDResult +description: API reference for qiskit.algorithms.VQDResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.VQDResult +--- + +# VQDResult + + + +`qiskit.algorithms.VQDResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigen_solvers/vqd.py "view source code") + +Bases: `VariationalResult`, [`EigensolverResult`](qiskit.algorithms.EigensolverResult "qiskit.algorithms.eigen_solvers.eigen_solver.EigensolverResult") + +Deprecated: VQD Result. + +The VQDResult class has been superseded by the [`qiskit.algorithms.eigensolvers.VQDResult`](qiskit.algorithms.eigensolvers.VQDResult "qiskit.algorithms.eigensolvers.VQDResult") class. This class will be deprecated in a future release and subsequently removed after that. + + + The class `qiskit.algorithms.eigen_solvers.vqd.VQDResult` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.eigensolvers.VQDResult`.See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +## Attributes + + + +### aux\_operator\_eigenvalues + +Return aux operator expectation values. + +These values are in fact tuples formatted as (mean, standard deviation). + + + +### cost\_function\_evals + +Returns number of cost optimizer evaluations + + + +### eigenstates + +return eigen state + + + +### eigenvalues + +returns eigen values + + + +### optimal\_circuit + +The optimal circuits. Along with the optimal parameters, these can be used to retrieve the minimum eigenstate. + + + +### optimal\_parameters + +Returns the optimal parameters in a dictionary + + + +### optimal\_point + +Returns optimal point + + + +### optimal\_value + +Returns optimal value + + + +### optimizer\_evals + +Returns number of optimizer evaluations + + + +### optimizer\_result + +Returns the optimizer result + + + +### optimizer\_time + +Returns time taken for optimization + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.VQE.md b/docs/api/qiskit/0.46/qiskit.algorithms.VQE.md new file mode 100644 index 00000000000..d021ddd4811 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.VQE.md @@ -0,0 +1,270 @@ +--- +title: VQE +description: API reference for qiskit.algorithms.VQE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.VQE +--- + +# VQE + + + +`qiskit.algorithms.VQE(ansatz=None, optimizer=None, initial_point=None, gradient=None, expectation=None, include_custom=False, max_evals_grouped=1, callback=None, quantum_instance=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigen_solvers/vqe.py "view source code") + +Bases: `VariationalAlgorithm`, [`MinimumEigensolver`](qiskit.algorithms.MinimumEigensolver "qiskit.algorithms.minimum_eigen_solvers.minimum_eigen_solver.MinimumEigensolver") + +Deprecated: Variational Quantum Eigensolver algorithm. + +The VQE class has been superseded by the [`qiskit.algorithms.minimum_eigensolvers.VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE") class. This class will be deprecated in a future release and subsequently removed after that. + +[VQE](https://arxiv.org/abs/1304.3061) is a quantum algorithm that uses a variational technique to find the minimum eigenvalue of the Hamiltonian $H$ of a given system. + +An instance of VQE requires defining two algorithmic sub-components: a trial state (a.k.a. ansatz) which is a `QuantumCircuit`, and one of the classical [`optimizers`](qiskit.algorithms.optimizers#module-qiskit.algorithms.optimizers "qiskit.algorithms.optimizers"). The ansatz is varied, via its set of parameters, by the optimizer, such that it works towards a state, as determined by the parameters applied to the ansatz, that will result in the minimum expectation value being measured of the input operator (Hamiltonian). + +An optional array of parameter values, via the *initial\_point*, may be provided as the starting point for the search of the minimum eigenvalue. This feature is particularly useful such as when there are reasons to believe that the solution point is close to a particular point. As an example, when building the dissociation profile of a molecule, it is likely that using the previous computed optimal solution as the starting initial point for the next interatomic distance is going to reduce the number of iterations necessary for the variational algorithm to converge. It provides an [initial point tutorial](https://github.com/Qiskit/qiskit-tutorials-community/blob/master/chemistry/h2_vqe_initial_point.ipynb) detailing this use case. + +The length of the *initial\_point* list value must match the number of the parameters expected by the ansatz being used. If the *initial\_point* is left at the default of `None`, then VQE will look to the ansatz for a preferred value, based on its given initial state. If the ansatz returns `None`, then a random point will be generated within the parameter bounds set, as per above. If the ansatz provides `None` as the lower bound, then VQE will default it to $-2\pi$; similarly, if the ansatz returns `None` as the upper bound, the default value will be $2\pi$. + +The optimizer can either be one of Qiskit’s optimizers, such as [`SPSA`](qiskit.algorithms.optimizers.SPSA "qiskit.algorithms.optimizers.SPSA") or a callable with the following signature: + + + The callable \_must\_ have the argument names `fun, x0, jac, bounds` as indicated in the following code block. + + +```python +from qiskit.algorithms.optimizers import OptimizerResult + +def my_minimizer(fun, x0, jac=None, bounds=None) -> OptimizerResult: + # Note that the callable *must* have these argument names! + # Args: + # fun (callable): the function to minimize + # x0 (np.ndarray): the initial point for the optimization + # jac (callable, optional): the gradient of the objective function + # bounds (list, optional): a list of tuples specifying the parameter bounds + + result = OptimizerResult() + result.x = # optimal parameters + result.fun = # optimal function value + return result +``` + +The above signature also allows to directly pass any SciPy minimizer, for instance as + +```python +from functools import partial +from scipy.optimize import minimize + +optimizer = partial(minimize, method="L-BFGS-B") +``` + + + The class `qiskit.algorithms.minimum_eigen_solvers.vqe.VQE` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. Instead, use the class `qiskit.algorithms.minimum_eigensolvers.VQE`. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A parameterized circuit used as Ansatz for the wave function. +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") *| None*) – A classical optimizer. Can either be a Qiskit optimizer or a callable that takes an array as input and returns a Qiskit or SciPy optimization result. +* **initial\_point** (*np.ndarray | None*) – An optional initial point (i.e. initial parameter values) for the optimizer. If `None` then VQE will look to the ansatz for a preferred point and if not will simply compute a random one. +* **gradient** ([*GradientBase*](qiskit.opflow.gradients.GradientBase "qiskit.opflow.gradients.GradientBase") *| Callable | None*) – An optional gradient function or operator for optimizer. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase") *| None*) – The Expectation converter for taking the average value of the Observable over the ansatz state function. When `None` (the default) an [`ExpectationFactory`](qiskit.opflow.expectations.ExpectationFactory "qiskit.opflow.expectations.ExpectationFactory") is used to select an appropriate expectation based on the operator and backend. When using Aer qasm\_simulator backend, with paulis, it is however much faster to leverage custom Aer function for the computation but, although VQE performs much faster with it, the outcome is ideal, with no shot noise, like using a state vector simulator. If you are just looking for the quickest performance when choosing Aer qasm\_simulator and the lack of shot noise is not an issue then set include\_custom parameter here to `True` (defaults to `False`). +* **include\_custom** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When expectation parameter here is None setting this to `True` will allow the factory to include the custom Aer pauli expectation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of evaluations performed simultaneously. Signals the given optimizer that more than one set of parameters can be supplied so that potentially the expectation values can be computed in parallel. Typically this is possible when a finite difference gradient is used by the optimizer such that multiple points to compute the gradient can be passed and if computed in parallel improve overall execution time. Deprecated if a gradient operator or function is given. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.ndarray,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*], None] | None*) – a callback that can access the intermediate data during the optimization. Four parameter values are passed to the callback as follows during each evaluation by the optimizer for its current set of parameters as it works towards the minimum. These are: the evaluation count, the optimizer parameters for the ansatz, the evaluated mean and the evaluated standard deviation.\` +* **quantum\_instance** ([*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *|*[*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *| None*) – Quantum Instance or Backend + +## Attributes + + + +### ansatz + +Returns the ansatz. + + + +### callback + +Returns callback + + + +### expectation + +The expectation value algorithm used to construct the expectation measurement from the observable. + + + +### gradient + +Returns the gradient. + + + +### include\_custom + +Returns include\_custom + + + +### initial\_point + +Returns initial point + + + +### max\_evals\_grouped + +Returns max\_evals\_grouped + + + +### optimizer + +Returns optimizer + + + +### quantum\_instance + +Returns quantum instance. + + + +### setting + +Prepare the setting of VQE as a string. + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes minimum eigenvalue. Operator and aux\_operators can be supplied here and if not None will override any already set into algorithm so it can be reused with different operators. While an operator is required by algorithms, aux\_operators are optional. To ‘remove’ a previous aux\_operators array use an empty list here. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **aux\_operators** (*ListOrDict\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators, total particle count operators so we can get values for these at the ground state. + +**Returns** + +MinimumEigensolverResult + +**Return type** + +[MinimumEigensolverResult](qiskit.algorithms.MinimumEigensolverResult "qiskit.algorithms.MinimumEigensolverResult") + +### construct\_circuit + + + +`construct_circuit(parameter, operator)` + +Return the circuits used to compute the expectation value. + +**Parameters** + +* **parameter** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | np.ndarray*) – Parameters for the ansatz circuit. +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable + +**Returns** + +A list of the circuits used to compute the expectation value. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")] + +### construct\_expectation + + + +`construct_expectation(parameter, operator, return_expectation=False)` + +Generate the ansatz circuit and expectation value measurement, and return their runnable composition. + +**Parameters** + +* **parameter** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | np.ndarray*) – Parameters for the ansatz circuit. +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – Qubit operator of the Observable +* **return\_expectation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, return the `ExpectationBase` expectation converter used in the construction of the expectation value. Useful e.g. to compute the standard deviation of the expectation value. + +**Returns** + +The Operator equalling the measurement of the ansatz `StateFn` by the Observable’s expectation `StateFn`, and, optionally, the expectation converter. + +**Raises** + +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If no operator has been provided. +* [**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If no expectation is passed and None could be inferred via the ExpectationFactory. + +**Return type** + +[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase"), [ExpectationBase](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")] + +### get\_energy\_evaluation + + + +`get_energy_evaluation(operator, return_expectation=False)` + +Returns a function handle to evaluates the energy at given parameters for the ansatz. + +This is the objective function to be passed to the optimizer that is used for evaluation. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")) – The operator whose energy to evaluate. +* **return\_expectation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, return the `ExpectationBase` expectation converter used in the construction of the expectation value. Useful e.g. to evaluate other operators with the same expectation value converter. + +**Returns** + +Energy of the hamiltonian of each parameter, and, optionally, the expectation converter. + +**Raises** + +[**RuntimeError**](https://docs.python.org/3/library/exceptions.html#RuntimeError "(in Python v3.12)") – If the circuit is not parameterized (i.e. has 0 free parameters). + +**Return type** + +Callable\[\[np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]] | [tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[Callable\[\[np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]], [ExpectationBase](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")] + +### print\_settings + + + +`print_settings()` + +Preparing the setting of VQE into a string. + +**Returns** + +the formatted setting of VQE + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenstate of the main operator then it can compute the expectation value of the aux\_operators for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.VarQITE.md b/docs/api/qiskit/0.46/qiskit.algorithms.VarQITE.md new file mode 100644 index 00000000000..811c71c96c2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.VarQITE.md @@ -0,0 +1,56 @@ +--- +title: VarQITE +description: API reference for qiskit.algorithms.VarQITE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.VarQITE +--- + +# VarQITE + + + +`qiskit.algorithms.VarQITE(ansatz, initial_parameters, variational_principle=None, estimator=None, ode_solver=, lse_solver=None, num_timesteps=None, imag_part_tol=1e-07, num_instability_tol=1e-07)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/var_qite.py "view source code") + +Bases: `VarQTE`, [`ImaginaryTimeEvolver`](qiskit.algorithms.ImaginaryTimeEvolver "qiskit.algorithms.time_evolvers.imaginary_time_evolver.ImaginaryTimeEvolver") + +Variational Quantum Imaginary Time Evolution algorithm. + +**Parameters** + +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Ansatz to be used for variational time evolution. +* **initial\_parameters** (*Mapping\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Initial parameter values for the ansatz. +* **variational\_principle** ([*ImaginaryVariationalPrinciple*](qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple "qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple") *| None*) – Variational Principle to be used. Defaults to `ImaginaryMcLachlanPrinciple`. +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") *| None*) – An estimator primitive used for calculating expectation values of TimeEvolutionProblem.aux\_operators. +* **ode\_solver** ([*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")*\[OdeSolver] |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – ODE solver callable that implements a SciPy `OdeSolver` interface or a string indicating a valid method offered by SciPy. +* **lse\_solver** (*Callable\[\[np.ndarray, np.ndarray], np.ndarray] | None*) – Linear system of equations solver callable. It accepts `A` and `b` to solve `Ax=b` and returns `x`. If `None`, the default `np.linalg.lstsq` solver is used. +* **num\_timesteps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of timesteps to take. If `None`, it is automatically selected to achieve a timestep of approximately 0.01. Only relevant in case of the `ForwardEulerSolver`. +* **imag\_part\_tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Allowed value of an imaginary part that can be neglected if no imaginary part is expected. +* **num\_instability\_tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The amount of negative value that is allowed to be rounded up to 0 for quantities that are expected to be non-negative. + +## Methods + +### evolve + + + +`evolve(evolution_problem)` + +Apply Variational Quantum Time Evolution to the given operator. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – Instance defining an evolution problem. + +**Returns** + +Result of the evolution which includes a quantum circuit with bound parameters as an evolved state and, if provided, observables evaluated on the evolved state. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `initial_state` is included in the `evolution_problem`. + +**Return type** + +*VarQTEResult* + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.VarQRTE.md b/docs/api/qiskit/0.46/qiskit.algorithms.VarQRTE.md new file mode 100644 index 00000000000..7f82404a884 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.VarQRTE.md @@ -0,0 +1,56 @@ +--- +title: VarQRTE +description: API reference for qiskit.algorithms.VarQRTE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.VarQRTE +--- + +# VarQRTE + + + +`qiskit.algorithms.VarQRTE(ansatz, initial_parameters, variational_principle=None, estimator=None, ode_solver=, lse_solver=None, num_timesteps=None, imag_part_tol=1e-07, num_instability_tol=1e-07)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/var_qrte.py "view source code") + +Bases: `VarQTE`, [`RealTimeEvolver`](qiskit.algorithms.RealTimeEvolver "qiskit.algorithms.time_evolvers.real_time_evolver.RealTimeEvolver") + +Variational Quantum Real Time Evolution algorithm. + +**Parameters** + +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Ansatz to be used for variational time evolution. +* **initial\_parameters** (*Mapping\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Initial parameter values for an ansatz. +* **variational\_principle** ([*RealVariationalPrinciple*](qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple "qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple") *| None*) – Variational Principle to be used. Defaults to `RealMcLachlanPrinciple`. +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") *| None*) – An estimator primitive used for calculating expectation values of TimeEvolutionProblem.aux\_operators. +* **ode\_solver** ([*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")*\[OdeSolver] |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – ODE solver callable that implements a SciPy `OdeSolver` interface or a string indicating a valid method offered by SciPy. +* **lse\_solver** (*Callable\[\[np.ndarray, np.ndarray], np.ndarray] | None*) – Linear system of equations solver callable. It accepts `A` and `b` to solve `Ax=b` and returns `x`. If `None`, the default `np.linalg.lstsq` solver is used. +* **num\_timesteps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of timesteps to take. If `None`, it is automatically selected to achieve a timestep of approximately 0.01. Only relevant in case of the `ForwardEulerSolver`. +* **imag\_part\_tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Allowed value of an imaginary part that can be neglected if no imaginary part is expected. +* **num\_instability\_tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The amount of negative value that is allowed to be rounded up to 0 for quantities that are expected to be non-negative. + +## Methods + +### evolve + + + +`evolve(evolution_problem)` + +Apply Variational Quantum Time Evolution to the given operator. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – Instance defining an evolution problem. + +**Returns** + +Result of the evolution which includes a quantum circuit with bound parameters as an evolved state and, if provided, observables evaluated on the evolved state. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `initial_state` is included in the `evolution_problem`. + +**Return type** + +*VarQTEResult* + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.Eigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.Eigensolver.md new file mode 100644 index 00000000000..d5b2ed3ab00 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.Eigensolver.md @@ -0,0 +1,61 @@ +--- +title: Eigensolver +description: API reference for qiskit.algorithms.eigensolvers.Eigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.eigensolvers.Eigensolver +--- + +# Eigensolver + + + +`qiskit.algorithms.eigensolvers.Eigensolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigensolvers/eigensolver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +The eigensolver interface. + +Algorithms that can compute eigenvalues for an operator may implement this interface to allow different algorithms to be used interchangeably. + +## Methods + +### compute\_eigenvalues + + + +`abstract compute_eigenvalues(operator, aux_operators=None)` + +Computes the minimum eigenvalue. The `operator` and `aux_operators` are supplied here. While an `operator` is required by algorithms, `aux_operators` are optional. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Qubit operator of the observable. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance, in chemistry, these can be dipole operators and total particle count operators, so we can get values for these at the ground state. + +**Returns** + +An eigensolver result. + +**Return type** + +[EigensolverResult](qiskit.algorithms.eigensolvers.EigensolverResult "qiskit.algorithms.eigensolvers.EigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the eigensolver computes the eigenvalues of the main operator, then it can compute the expectation value of the `aux_operators` for that state. Otherwise they will be ignored. + +**Returns** + +`True` if `aux_operator` expectations can be evaluated, `False` otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.EigensolverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.EigensolverResult.md new file mode 100644 index 00000000000..c1264ba5c4d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.EigensolverResult.md @@ -0,0 +1,48 @@ +--- +title: EigensolverResult +description: API reference for qiskit.algorithms.eigensolvers.EigensolverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.eigensolvers.EigensolverResult +--- + +# EigensolverResult + + + +`qiskit.algorithms.eigensolvers.EigensolverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigensolvers/eigensolver.py "view source code") + +Bases: `AlgorithmResult` + +Eigensolver result. + +## Attributes + + + +### aux\_operators\_evaluated + +Return the aux operator expectation values. + +These values are in fact tuples formatted as (mean, metadata). + + + +### eigenvalues + +Return the eigenvalues. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolver.md new file mode 100644 index 00000000000..f3b0e4a0977 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolver.md @@ -0,0 +1,84 @@ +--- +title: NumPyEigensolver +description: API reference for qiskit.algorithms.eigensolvers.NumPyEigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.eigensolvers.NumPyEigensolver +--- + +# NumPyEigensolver + + + +`qiskit.algorithms.eigensolvers.NumPyEigensolver(k=1, filter_criterion=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigensolvers/numpy_eigensolver.py "view source code") + +Bases: [`Eigensolver`](qiskit.algorithms.eigensolvers.Eigensolver "qiskit.algorithms.eigensolvers.eigensolver.Eigensolver") + +The NumPy eigensolver algorithm. + +The NumPy Eigensolver computes up to the first $k$ eigenvalues of a complex-valued square matrix of dimension $n \times n$, with $k \leq n$. + + + Operators are automatically converted to SciPy’s `spmatrix` as needed and this conversion can be costly in terms of memory and performance as the operator size, mostly in terms of number of qubits it represents, gets larger. + + +**Parameters** + +* **k** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of eigenvalues are to be computed, with a minimum value of 1. +* **filter\_criterion** (*FilterType | None*) – Callable that allows to filter eigenvalues/eigenstates. Only feasible eigenstates are returned in the results. The callable has the signature `filter(eigenstate, eigenvalue, aux_values)` and must return a boolean to indicate whether to keep this value in the final returned result or not. If the number of elements that satisfies the criterion is smaller than `k`, then the returned list will have fewer elements and can even be empty. + +## Attributes + + + +### filter\_criterion + +Return the filter criterion if set. + + + +### k + +Return k (number of eigenvalues requested). + +## Methods + +### compute\_eigenvalues + + + +`compute_eigenvalues(operator, aux_operators=None)` + +Computes the minimum eigenvalue. The `operator` and `aux_operators` are supplied here. While an `operator` is required by algorithms, `aux_operators` are optional. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Qubit operator of the observable. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance, in chemistry, these can be dipole operators and total particle count operators, so we can get values for these at the ground state. + +**Returns** + +An eigensolver result. + +**Return type** + +[NumPyEigensolverResult](qiskit.algorithms.eigensolvers.NumPyEigensolverResult "qiskit.algorithms.eigensolvers.NumPyEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the eigensolver computes the eigenvalues of the main operator, then it can compute the expectation value of the `aux_operators` for that state. Otherwise they will be ignored. + +**Returns** + +`True` if `aux_operator` expectations can be evaluated, `False` otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolverResult.md new file mode 100644 index 00000000000..2a492983aa9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.NumPyEigensolverResult.md @@ -0,0 +1,54 @@ +--- +title: NumPyEigensolverResult +description: API reference for qiskit.algorithms.eigensolvers.NumPyEigensolverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.eigensolvers.NumPyEigensolverResult +--- + +# NumPyEigensolverResult + + + +`qiskit.algorithms.eigensolvers.NumPyEigensolverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigensolvers/numpy_eigensolver.py "view source code") + +Bases: [`EigensolverResult`](qiskit.algorithms.eigensolvers.EigensolverResult "qiskit.algorithms.eigensolvers.eigensolver.EigensolverResult") + +NumPy eigensolver result. + +## Attributes + + + +### aux\_operators\_evaluated + +Return the aux operator expectation values. + +These values are in fact tuples formatted as (mean, metadata). + + + +### eigenstates + +Return eigenstates. + + + +### eigenvalues + +Return the eigenvalues. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQD.md b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQD.md new file mode 100644 index 00000000000..aa9f706b38c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQD.md @@ -0,0 +1,173 @@ +--- +title: VQD +description: API reference for qiskit.algorithms.eigensolvers.VQD +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.eigensolvers.VQD +--- + +# VQD + + + +`qiskit.algorithms.eigensolvers.VQD(estimator, fidelity, ansatz, optimizer, *, k=2, betas=None, initial_point=None, callback=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigensolvers/vqd.py "view source code") + +Bases: `VariationalAlgorithm`, [`Eigensolver`](qiskit.algorithms.eigensolvers.Eigensolver "qiskit.algorithms.eigensolvers.eigensolver.Eigensolver") + +The Variational Quantum Deflation algorithm. Implementation using primitives. + +[VQD](https://arxiv.org/abs/1805.08138) is a quantum algorithm that uses a variational technique to find the k eigenvalues of the Hamiltonian $H$ of a given system. + +The algorithm computes excited state energies of generalised hamiltonians by optimising over a modified cost function where each succesive eigenvalue is calculated iteratively by introducing an overlap term with all the previously computed eigenstates that must be minimised, thus ensuring higher energy eigenstates are found. + +An instance of VQD requires defining three algorithmic sub-components: an integer k denoting the number of eigenstates to calculate, a trial state (a.k.a. ansatz) which is a `QuantumCircuit`, and one instance (or list of) classical [`optimizers`](qiskit.algorithms.optimizers#module-qiskit.algorithms.optimizers "qiskit.algorithms.optimizers"). The optimizer varies the circuit parameters The trial state $|\psi(\vec\theta)\rangle$ is varied by the optimizer, which modifies the set of ansatz parameters $\vec\theta$ such that the expectation value of the operator on the corresponding state approaches a minimum. The algorithm does this by iteratively refining each excited state to be orthogonal to all the previous excited states. + +An optional array of parameter values, via the *initial\_point*, may be provided as the starting point for the search of the minimum eigenvalue. This feature is particularly useful when there are reasons to believe that the solution point is close to a particular point. + +The length of the *initial\_point* list value must match the number of the parameters expected by the ansatz. If the *initial\_point* is left at the default of `None`, then VQD will look to the ansatz for a preferred value, based on its given initial state. If the ansatz returns `None`, then a random point will be generated within the parameter bounds set, as per above. It is also possible to give a list of initial points, one for every kth eigenvalue. If the ansatz provides `None` as the lower bound, then VQD will default it to $-2\pi$; similarly, if the ansatz returns `None` as the upper bound, the default value will be $2\pi$. + +The following attributes can be set via the initializer but can also be read and updated once the VQD object has been constructed. + + + +### estimator + +The primitive instance used to perform the expectation estimation as indicated in the VQD paper. + +**Type** + +[BaseEstimator](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") + + + +### fidelity + +The fidelity class instance used to compute the overlap estimation as indicated in the VQD paper. + +**Type** + +[BaseStateFidelity](qiskit.algorithms.state_fidelities.BaseStateFidelity "qiskit.algorithms.state_fidelities.BaseStateFidelity") + + + +### ansatz + +A parameterized circuit used as ansatz for the wave function. + +**Type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + +### optimizer + +A classical optimizer or a list of optimizers, + +**Type** + +[Optimizer](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") | Sequence\[[Optimizer](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer")] + +### one for every k-th eigenvalue. Can either be a Qiskit optimizer or a callable + +that takes an array as input and returns a Qiskit or SciPy optimization result. + + + +### k + +the number of eigenvalues to return. Returns the lowest k eigenvalues. + +**Type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### betas + +Beta parameters in the VQD paper. Should have length k - 1, with k the number of excited states. These hyper-parameters balance the contribution of each overlap term to the cost function and have a default value computed as the mean square sum of the coefficients of the observable. + +**Type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### initial point + +An optional initial point (i.e. initial parameter values) or a list of initial points (one for every k-th eigenvalue) for the optimizer. If `None` then VQD will look to the ansatz for a preferred point and if not will simply compute a random one. + +**Type** + +Sequence\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] | Sequence\[Sequence\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]] | None + + + +### callback + +A callback that can access the intermediate data during the optimization. Four parameter values are passed to the callback as follows during each evaluation by the optimizer: the evaluation count, the optimizer parameters for the ansatz, the estimated value, the estimation metadata, and the current step. + +**Type** + +Callable\[\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), np.ndarray, [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), Any]], None] | None + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator primitive. +* **fidelity** ([*BaseStateFidelity*](qiskit.algorithms.state_fidelities.BaseStateFidelity "qiskit.algorithms.state_fidelities.BaseStateFidelity")) – The fidelity class using primitives. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A parameterized circuit used as ansatz for the wave function. +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") *| Sequence\[*[*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer")*]*) – A classical optimizer or a list of optimizers, one for every k-th eigenvalue. +* **callable** (*Can either be a Qiskit optimizer or a*) – that takes an array as input and returns a Qiskit or SciPy optimization result. +* **k** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of eigenvalues to return. Returns the lowest k eigenvalues. +* **betas** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Beta parameters in the VQD paper. Should have length k - 1, with k the number of excited states. These hyperparameters balance the contribution of each overlap term to the cost function and have a default value computed as the mean square sum of the coefficients of the observable. +* **initial\_point** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – An optional initial point (i.e. initial parameter values) or a list of initial points (one for every k-th eigenvalue) for the optimizer. If `None` then VQD will look to the ansatz for a preferred point and if not will simply compute a random one. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.ndarray,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any]], None] | None*) – A callback that can access the intermediate data during the optimization. Four parameter values are passed to the callback as follows during each evaluation by the optimizer: the evaluation count, the optimizer parameters for the ansatz, the estimated value, the estimation metadata, and the current step. + +## Attributes + + + +### initial\_point + +Returns initial point. + +## Methods + +### compute\_eigenvalues + + + +`compute_eigenvalues(operator, aux_operators=None)` + +Computes the minimum eigenvalue. The `operator` and `aux_operators` are supplied here. While an `operator` is required by algorithms, `aux_operators` are optional. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Qubit operator of the observable. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the eigenstate of the minimum eigenvalue main result and their expectation values returned. For instance, in chemistry, these can be dipole operators and total particle count operators, so we can get values for these at the ground state. + +**Returns** + +An eigensolver result. + +**Return type** + +[VQDResult](qiskit.algorithms.eigensolvers.VQDResult "qiskit.algorithms.eigensolvers.VQDResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the eigensolver computes the eigenvalues of the main operator, then it can compute the expectation value of the `aux_operators` for that state. Otherwise they will be ignored. + +**Returns** + +`True` if `aux_operator` expectations can be evaluated, `False` otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQDResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQDResult.md new file mode 100644 index 00000000000..58c1ff70950 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.VQDResult.md @@ -0,0 +1,90 @@ +--- +title: VQDResult +description: API reference for qiskit.algorithms.eigensolvers.VQDResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.eigensolvers.VQDResult +--- + +# VQDResult + + + +`qiskit.algorithms.eigensolvers.VQDResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/eigensolvers/vqd.py "view source code") + +Bases: [`EigensolverResult`](qiskit.algorithms.eigensolvers.EigensolverResult "qiskit.algorithms.eigensolvers.eigensolver.EigensolverResult") + +VQD Result. + +## Attributes + + + +### aux\_operators\_evaluated + +Return the aux operator expectation values. + +These values are in fact tuples formatted as (mean, metadata). + + + +### cost\_function\_evals + +Returns number of cost optimizer evaluations + + + +### eigenvalues + +Return the eigenvalues. + + + +### optimal\_circuits + +The optimal circuits. Along with the optimal parameters, these can be used to retrieve the different eigenstates. + + + +### optimal\_parameters + +Returns the optimal parameters for each step + + + +### optimal\_points + +Returns optimal point for each step + + + +### optimal\_values + +Returns optimal value for each step + + + +### optimizer\_results + +Returns the optimizer results for each step + + + +### optimizer\_times + +Returns time taken for optimization for each step + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.md b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.md new file mode 100644 index 00000000000..a1fac22f05f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.eigensolvers.md @@ -0,0 +1,38 @@ +--- +title: eigensolvers +description: API reference for qiskit.algorithms.eigensolvers +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.eigensolvers +--- + + + + + +# qiskit.algorithms.eigensolvers + + + +## Eigensolvers Package + + + +`qiskit.algorithms.eigensolvers` + +### Eigensolvers + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------ | -------------------------------------------- | +| [`Eigensolver`](qiskit.algorithms.eigensolvers.Eigensolver "qiskit.algorithms.eigensolvers.Eigensolver")() | The eigensolver interface. | +| [`NumPyEigensolver`](qiskit.algorithms.eigensolvers.NumPyEigensolver "qiskit.algorithms.eigensolvers.NumPyEigensolver")(\[k, filter\_criterion]) | The NumPy eigensolver algorithm. | +| [`VQD`](qiskit.algorithms.eigensolvers.VQD "qiskit.algorithms.eigensolvers.VQD")(estimator, fidelity, ansatz, optimizer, \*) | The Variational Quantum Deflation algorithm. | + +### Results + +> | | | +> | ------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------- | +> | [`EigensolverResult`](qiskit.algorithms.eigensolvers.EigensolverResult "qiskit.algorithms.eigensolvers.EigensolverResult")() | Eigensolver result. | +> | [`NumPyEigensolverResult`](qiskit.algorithms.eigensolvers.NumPyEigensolverResult "qiskit.algorithms.eigensolvers.NumPyEigensolverResult")() | NumPy eigensolver result. | +> | [`VQDResult`](qiskit.algorithms.eigensolvers.VQDResult "qiskit.algorithms.eigensolvers.VQDResult")() | VQD Result. | + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseEstimatorGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseEstimatorGradient.md new file mode 100644 index 00000000000..9e6baec477b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseEstimatorGradient.md @@ -0,0 +1,98 @@ +--- +title: BaseEstimatorGradient +description: API reference for qiskit.algorithms.gradients.BaseEstimatorGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.BaseEstimatorGradient +--- + +# BaseEstimatorGradient + + + +`qiskit.algorithms.gradients.BaseEstimatorGradient(estimator, options=None, derivative_type=DerivativeType.REAL)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/base/base_estimator_gradient.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class for an `EstimatorGradient` to compute the gradients of the expectation value. + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator used to compute the gradients. + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +* **derivative\_type** (*DerivativeType*) – + + The type of derivative. Can be either `DerivativeType.REAL` `DerivativeType.IMAG`, or `DerivativeType.COMPLEX`. + + > * `DerivativeType.REAL` computes $2 \mathrm{Re}[⟨ψ(ω)|O(θ)|dω ψ(ω)〉]$. + > * `DerivativeType.IMAG` computes $2 \mathrm{Im}[⟨ψ(ω)|O(θ)|dω ψ(ω)〉]$. + > * `DerivativeType.COMPLEX` computes $2 ⟨ψ(ω)|O(θ)|dω ψ(ω)〉$. + + Defaults to `DerivativeType.REAL`, as this yields e.g. the commonly-used energy gradient and this type is the only supported type for function-level schemes like finite difference. + +## Attributes + + + +### derivative\_type + +Return the derivative type (real, imaginary or complex). + +**Returns** + +The derivative type. + + + +### options + +Return the union of estimator options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + estimator options. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values, parameters=None, **options)` + +Run the job of the estimator gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*]*) – The list of observables. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th element of the i-th result corresponds to the gradient of the i-th circuit with respect to the j-th parameter. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseQGT.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseQGT.md new file mode 100644 index 00000000000..8e24e88cd72 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseQGT.md @@ -0,0 +1,115 @@ +--- +title: BaseQGT +description: API reference for qiskit.algorithms.gradients.BaseQGT +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.BaseQGT +--- + +# BaseQGT + + + +`qiskit.algorithms.gradients.BaseQGT(estimator, phase_fix=True, derivative_type=DerivativeType.COMPLEX, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/base/base_qgt.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class to computes the Quantum Geometric Tensor (QGT) given a pure, parameterized quantum state. QGT is defined as: + +$$ +\mathrm{QGT}_{ij}= \langle \partial_i \psi | \partial_j \psi \rangle + - \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle. +$$ + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator used to compute the QGT. + +* **phase\_fix** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to calculate the second term (phase fix) of the QGT, which is $\langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle$. Defaults to `True`. + +* **derivative\_type** (*DerivativeType*) – + + The type of derivative. Can be either `DerivativeType.REAL` `DerivativeType.IMAG`, or `DerivativeType.COMPLEX`. Defaults to `DerivativeType.REAL`. + + * `DerivativeType.REAL` computes + + $$ + \mathrm{Re(QGT)}_{ij}= \mathrm{Re}[\langle \partial_i \psi | \partial_j \psi \rangle + - \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle]. + $$ + + * `DerivativeType.IMAG` computes + + $$ + \mathrm{Im(QGT)}_{ij}= \mathrm{Im}[\langle \partial_i \psi | \partial_j \psi \rangle + - \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle]. + $$ + + * `DerivativeType.COMPLEX` computes + + $$ + \mathrm{QGT}_{ij}= [\langle \partial_i \psi | \partial_j \psi \rangle + - \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle]. + $$ + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Backend runtime options used for circuit execution. The order of priority is: options in `run` method > QGT’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +## Attributes + + + +### derivative\_type + +The derivative type. + + + +### options + +Return the union of estimator options setting and QGT default options, where, if the same field is set in both, the QGT’s default options override the primitive’s default setting. + +**Returns** + +The QGT default + estimator options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the QGTs on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the QGTs. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the QGTs of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the QGTs of all parameters in each circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > QGT’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +**Returns** + +The job object of the QGTs of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseSamplerGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseSamplerGradient.md new file mode 100644 index 00000000000..ea964ae2633 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.BaseSamplerGradient.md @@ -0,0 +1,76 @@ +--- +title: BaseSamplerGradient +description: API reference for qiskit.algorithms.gradients.BaseSamplerGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.BaseSamplerGradient +--- + +# BaseSamplerGradient + + + +`qiskit.algorithms.gradients.BaseSamplerGradient(sampler, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/base/base_sampler_gradient.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class for a `SamplerGradient` to compute the gradients of the sampling probability. + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – The sampler used to compute the gradients. +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +## Attributes + + + +### options + +Return the union of sampler options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + sampler options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the sampler gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the sampling probability. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th quasi-probability distribution in the i-th result corresponds to the gradients of the sampling probability for the j-th parameter in `circuits[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.EstimatorGradientResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.EstimatorGradientResult.md new file mode 100644 index 00000000000..c9f73e02483 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.EstimatorGradientResult.md @@ -0,0 +1,44 @@ +--- +title: EstimatorGradientResult +description: API reference for qiskit.algorithms.gradients.EstimatorGradientResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.EstimatorGradientResult +--- + +# EstimatorGradientResult + + + +`qiskit.algorithms.gradients.EstimatorGradientResult(gradients, metadata, options)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/base/estimator_gradient_result.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Result of EstimatorGradient. + +## Attributes + + + +### gradients + +`list[numpy.ndarray]` + +The gradients of the expectation values. + + + +### metadata + +`list[dict[str, Any]]` + +Additional information about the job. + + + +### options + +`Options` + +Primitive runtime options for the execution of the job. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffEstimatorGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffEstimatorGradient.md new file mode 100644 index 00000000000..6ce94f07798 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffEstimatorGradient.md @@ -0,0 +1,107 @@ +--- +title: FiniteDiffEstimatorGradient +description: API reference for qiskit.algorithms.gradients.FiniteDiffEstimatorGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.FiniteDiffEstimatorGradient +--- + +# FiniteDiffEstimatorGradient + + + +`qiskit.algorithms.gradients.FiniteDiffEstimatorGradient(estimator, epsilon, options=None, *, method='central')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/finite_diff/finite_diff_estimator_gradient.py "view source code") + +Bases: [`BaseEstimatorGradient`](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.base.base_estimator_gradient.BaseEstimatorGradient") + +Compute the gradients of the expectation values by finite difference method \[1]. + +**Reference:** \[1] [Finite difference method](https://en.wikipedia.org/wiki/Finite_difference_method) + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator used to compute the gradients. + +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The offset size for the finite difference gradients. + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +* **method** (*Literal\['central', 'forward', 'backward']*) – + + The computation method of the gradients. + + > * `central` computes $\frac{f(x+e)-f(x-e)}{2e}$, + > * `forward` computes $\frac{f(x+e) - f(x)}{e}$, + > * `backward` computes $\frac{f(x)-f(x-e)}{e}$ + + where $e$ is epsilon. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `epsilon` is not positive. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `method` is invalid. + +## Attributes + + + +### derivative\_type + +Return the derivative type (real, imaginary or complex). + +**Returns** + +The derivative type. + + + +### options + +Return the union of estimator options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + estimator options. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values, parameters=None, **options)` + +Run the job of the estimator gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*]*) – The list of observables. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th element of the i-th result corresponds to the gradient of the i-th circuit with respect to the j-th parameter. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffSamplerGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffSamplerGradient.md new file mode 100644 index 00000000000..13d46349162 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.FiniteDiffSamplerGradient.md @@ -0,0 +1,96 @@ +--- +title: FiniteDiffSamplerGradient +description: API reference for qiskit.algorithms.gradients.FiniteDiffSamplerGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.FiniteDiffSamplerGradient +--- + +# FiniteDiffSamplerGradient + + + +`qiskit.algorithms.gradients.FiniteDiffSamplerGradient(sampler, epsilon, options=None, *, method='central')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/finite_diff/finite_diff_sampler_gradient.py "view source code") + +Bases: [`BaseSamplerGradient`](qiskit.algorithms.gradients.BaseSamplerGradient "qiskit.algorithms.gradients.base.base_sampler_gradient.BaseSamplerGradient") + +Compute the gradients of the sampling probability by finite difference method \[1]. + +**Reference:** \[1] [Finite difference method](https://en.wikipedia.org/wiki/Finite_difference_method) + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – The sampler used to compute the gradients. + +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The offset size for the finite difference gradients. + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +* **method** (*Literal\['central', 'forward', 'backward']*) – + + The computation method of the gradients. + + > * `central` computes $\frac{f(x+e)-f(x-e)}{2e}$, + > * `forward` computes $\frac{f(x+e) - f(x)}{e}$, + > * `backward` computes $\frac{f(x)-f(x-e)}{e}$ + + where $e$ is epsilon. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `epsilon` is not positive. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `method` is invalid. + +## Attributes + + + +### options + +Return the union of sampler options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + sampler options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the sampler gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the sampling probability. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th quasi-probability distribution in the i-th result corresponds to the gradients of the sampling probability for the j-th parameter in `circuits[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombEstimatorGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombEstimatorGradient.md new file mode 100644 index 00000000000..ddb39859b71 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombEstimatorGradient.md @@ -0,0 +1,104 @@ +--- +title: LinCombEstimatorGradient +description: API reference for qiskit.algorithms.gradients.LinCombEstimatorGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.LinCombEstimatorGradient +--- + +# LinCombEstimatorGradient + + + +`qiskit.algorithms.gradients.LinCombEstimatorGradient(estimator, derivative_type=DerivativeType.REAL, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/lin_comb/lin_comb_estimator_gradient.py "view source code") + +Bases: [`BaseEstimatorGradient`](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.base.base_estimator_gradient.BaseEstimatorGradient") + +Compute the gradients of the expectation values. This method employs a linear combination of unitaries \[1]. + +**Reference:** \[1] Schuld et al., Evaluating analytic gradients on quantum hardware, 2018 [arXiv:1811.11184](https://arxiv.org/pdf/1811.11184.pdf) + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator used to compute the gradients. + +* **derivative\_type** (*DerivativeType*) – + + The type of derivative. Can be either `DerivativeType.REAL` `DerivativeType.IMAG`, or `DerivativeType.COMPLEX`. Defaults to `DerivativeType.REAL`. + + > * `DerivativeType.REAL` computes $2 \mathrm{Re}[⟨ψ(ω)|O(θ)|dω ψ(ω)〉]$. + > * `DerivativeType.IMAG` computes $2 \mathrm{Im}[⟨ψ(ω)|O(θ)|dω ψ(ω)〉]$. + > * `DerivativeType.COMPLEX` computes $2 ⟨ψ(ω)|O(θ)|dω ψ(ω)〉$. + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +## Attributes + + + +### SUPPORTED\_GATES + +`= ['rx', 'ry', 'rz', 'rzx', 'rzz', 'ryy', 'rxx', 'cx', 'cy', 'cz', 'ccx', 'swap', 'iswap', 'h', 't', 's', 'sdg', 'x', 'y', 'z']` + + + +### derivative\_type + +Return the derivative type (real, imaginary or complex). + +**Returns** + +The derivative type. + + + +### options + +Return the union of estimator options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + estimator options. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values, parameters=None, **options)` + +Run the job of the estimator gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*]*) – The list of observables. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th element of the i-th result corresponds to the gradient of the i-th circuit with respect to the j-th parameter. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombQGT.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombQGT.md new file mode 100644 index 00000000000..1e928f2d2ff --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombQGT.md @@ -0,0 +1,124 @@ +--- +title: LinCombQGT +description: API reference for qiskit.algorithms.gradients.LinCombQGT +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.LinCombQGT +--- + +# LinCombQGT + + + +`qiskit.algorithms.gradients.LinCombQGT(estimator, phase_fix=True, derivative_type=DerivativeType.COMPLEX, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/lin_comb/lin_comb_qgt.py "view source code") + +Bases: [`BaseQGT`](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.base.base_qgt.BaseQGT") + +Computes the Quantum Geometric Tensor (QGT) given a pure, parameterized quantum state. + +This method employs a linear combination of unitaries \[1]. + +**Reference:** + +> **\[1]: Schuld et al., “Evaluating analytic gradients on quantum hardware” (2018).** +> +> [arXiv:1811.11184](https://arxiv.org/pdf/1811.11184.pdf) + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator used to compute the QGT. + +* **phase\_fix** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to calculate the second term (phase fix) of the QGT, which is $\langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle$. Default to `True`. + +* **derivative\_type** (*DerivativeType*) – + + The type of derivative. Can be either `DerivativeType.REAL` `DerivativeType.IMAG`, or `DerivativeType.COMPLEX`. Defaults to `DerivativeType.REAL`. + + * `DerivativeType.REAL` computes + + $$ + \mathrm{Re(QGT)}_{ij}= \mathrm{Re}[\langle \partial_i \psi | \partial_j \psi \rangle + - \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle]. + $$ + + * `DerivativeType.IMAG` computes + + $$ + \mathrm{Re(QGT)}_{ij}= \mathrm{Im}[\langle \partial_i \psi | \partial_j \psi \rangle + - \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle]. + $$ + + * `DerivativeType.COMPLEX` computes + + $$ + \mathrm{QGT}_{ij}= [\langle \partial_i \psi | \partial_j \psi \rangle + - \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle]. + $$ + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Backend runtime options used for circuit execution. The order of priority is: options in `run` method > QGT’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +## Attributes + + + +### SUPPORTED\_GATES + +`= ['rx', 'ry', 'rz', 'rzx', 'rzz', 'ryy', 'rxx', 'cx', 'cy', 'cz', 'ccx', 'swap', 'iswap', 'h', 't', 's', 'sdg', 'x', 'y', 'z']` + + + +### derivative\_type + +The derivative type. + + + +### options + +Return the union of estimator options setting and QGT default options, where, if the same field is set in both, the QGT’s default options override the primitive’s default setting. + +**Returns** + +The QGT default + estimator options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the QGTs on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the QGTs. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the QGTs of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the QGTs of all parameters in each circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > QGT’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +**Returns** + +The job object of the QGTs of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombSamplerGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombSamplerGradient.md new file mode 100644 index 00000000000..88d20cf0b3a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.LinCombSamplerGradient.md @@ -0,0 +1,84 @@ +--- +title: LinCombSamplerGradient +description: API reference for qiskit.algorithms.gradients.LinCombSamplerGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.LinCombSamplerGradient +--- + +# LinCombSamplerGradient + + + +`qiskit.algorithms.gradients.LinCombSamplerGradient(sampler, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/lin_comb/lin_comb_sampler_gradient.py "view source code") + +Bases: [`BaseSamplerGradient`](qiskit.algorithms.gradients.BaseSamplerGradient "qiskit.algorithms.gradients.base.base_sampler_gradient.BaseSamplerGradient") + +Compute the gradients of the sampling probability. This method employs a linear combination of unitaries \[1]. + +**Reference:** \[1] Schuld et al., Evaluating analytic gradients on quantum hardware, 2018 [arXiv:1811.11184](https://arxiv.org/pdf/1811.11184.pdf) + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – The sampler used to compute the gradients. +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +## Attributes + + + +### SUPPORTED\_GATES + +`= ['rx', 'ry', 'rz', 'rzx', 'rzz', 'ryy', 'rxx', 'cx', 'cy', 'cz', 'ccx', 'swap', 'iswap', 'h', 't', 's', 'sdg', 'x', 'y', 'z']` + + + +### options + +Return the union of sampler options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + sampler options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the sampler gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the sampling probability. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th quasi-probability distribution in the i-th result corresponds to the gradients of the sampling probability for the j-th parameter in `circuits[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftEstimatorGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftEstimatorGradient.md new file mode 100644 index 00000000000..8322b6fc9e6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftEstimatorGradient.md @@ -0,0 +1,106 @@ +--- +title: ParamShiftEstimatorGradient +description: API reference for qiskit.algorithms.gradients.ParamShiftEstimatorGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.ParamShiftEstimatorGradient +--- + +# ParamShiftEstimatorGradient + + + +`qiskit.algorithms.gradients.ParamShiftEstimatorGradient(estimator, options=None, derivative_type=DerivativeType.REAL)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/param_shift/param_shift_estimator_gradient.py "view source code") + +Bases: [`BaseEstimatorGradient`](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.base.base_estimator_gradient.BaseEstimatorGradient") + +Compute the gradients of the expectation values by the parameter shift rule \[1]. + +**Reference:** \[1] Schuld, M., Bergholm, V., Gogolin, C., Izaac, J., and Killoran, N. Evaluating analytic gradients on quantum hardware, [DOI](https://doi.org/10.1103/PhysRevA.99.032331) + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator used to compute the gradients. + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +* **derivative\_type** (*DerivativeType*) – + + The type of derivative. Can be either `DerivativeType.REAL` `DerivativeType.IMAG`, or `DerivativeType.COMPLEX`. + + > * `DerivativeType.REAL` computes $2 \mathrm{Re}[⟨ψ(ω)|O(θ)|dω ψ(ω)〉]$. + > * `DerivativeType.IMAG` computes $2 \mathrm{Im}[⟨ψ(ω)|O(θ)|dω ψ(ω)〉]$. + > * `DerivativeType.COMPLEX` computes $2 ⟨ψ(ω)|O(θ)|dω ψ(ω)〉$. + + Defaults to `DerivativeType.REAL`, as this yields e.g. the commonly-used energy gradient and this type is the only supported type for function-level schemes like finite difference. + +## Attributes + + + +### SUPPORTED\_GATES + +`= ['x', 'y', 'z', 'h', 'rx', 'ry', 'rz', 'p', 'cx', 'cy', 'cz', 'ryy', 'rxx', 'rzz', 'rzx']` + + + +### derivative\_type + +Return the derivative type (real, imaginary or complex). + +**Returns** + +The derivative type. + + + +### options + +Return the union of estimator options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + estimator options. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values, parameters=None, **options)` + +Run the job of the estimator gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*]*) – The list of observables. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th element of the i-th result corresponds to the gradient of the i-th circuit with respect to the j-th parameter. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftSamplerGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftSamplerGradient.md new file mode 100644 index 00000000000..b16ba99356d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ParamShiftSamplerGradient.md @@ -0,0 +1,84 @@ +--- +title: ParamShiftSamplerGradient +description: API reference for qiskit.algorithms.gradients.ParamShiftSamplerGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.ParamShiftSamplerGradient +--- + +# ParamShiftSamplerGradient + + + +`qiskit.algorithms.gradients.ParamShiftSamplerGradient(sampler, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/param_shift/param_shift_sampler_gradient.py "view source code") + +Bases: [`BaseSamplerGradient`](qiskit.algorithms.gradients.BaseSamplerGradient "qiskit.algorithms.gradients.base.base_sampler_gradient.BaseSamplerGradient") + +Compute the gradients of the sampling probability by the parameter shift rule \[1]. + +**Reference:** \[1] Schuld, M., Bergholm, V., Gogolin, C., Izaac, J., and Killoran, N. Evaluating analytic gradients on quantum hardware, [DOI](https://doi.org/10.1103/PhysRevA.99.032331) + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – The sampler used to compute the gradients. +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +## Attributes + + + +### SUPPORTED\_GATES + +`= ['x', 'y', 'z', 'h', 'rx', 'ry', 'rz', 'p', 'cx', 'cy', 'cz', 'ryy', 'rxx', 'rzz', 'rzx']` + + + +### options + +Return the union of sampler options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + sampler options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the sampler gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the sampling probability. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th quasi-probability distribution in the i-th result corresponds to the gradients of the sampling probability for the j-th parameter in `circuits[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFI.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFI.md new file mode 100644 index 00000000000..f2526b1b2ef --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFI.md @@ -0,0 +1,77 @@ +--- +title: QFI +description: API reference for qiskit.algorithms.gradients.QFI +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.QFI +--- + +# QFI + + + +`qiskit.algorithms.gradients.QFI(qgt, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/qfi.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Computes the Quantum Fisher Information (QFI) given a pure, parameterized quantum state. QFI is defined as: + +$$ +\mathrm{QFI}_{ij}= 4 \mathrm{Re}[\langle \partial_i \psi | \partial_j \psi \rangle +- \langle\partial_i \psi | \psi \rangle \langle\psi | \partial_j \psi \rangle]. +$$ + +**Parameters** + +* **qgt** ([*BaseQGT*](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT")) – The quantum geometric tensor used to compute the QFI. +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Backend runtime options used for circuit execution. The order of priority is: options in `run` method > QFI’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +## Attributes + + + +### options + +Return the union of QGT’s options setting and QFI’s default options, where, if the same field is set in both, the QFI’s default options override the QGT’s default setting. + +**Returns** + +The QFI default + QGT options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the QFIs on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the QFIs. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the QFIs of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the QFIs of all parameters in each circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > QFI’s default options > QGT’s default setting. Higher priority setting overrides lower priority setting. + +**Returns** + +The job object of the QFIs of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFIResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFIResult.md new file mode 100644 index 00000000000..2508cc38001 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QFIResult.md @@ -0,0 +1,44 @@ +--- +title: QFIResult +description: API reference for qiskit.algorithms.gradients.QFIResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.QFIResult +--- + +# QFIResult + + + +`qiskit.algorithms.gradients.QFIResult(qfis, metadata, options)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/qfi_result.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Result of QFI. + +## Attributes + + + +### qfis + +`list[numpy.ndarray]` + +The QFI. + + + +### metadata + +`list[dict[str, Any]]` + +Additional information about the job. + + + +### options + +`Options` + +Primitive runtime options for the execution of the job. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QGTResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QGTResult.md new file mode 100644 index 00000000000..edae6cb653a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.QGTResult.md @@ -0,0 +1,52 @@ +--- +title: QGTResult +description: API reference for qiskit.algorithms.gradients.QGTResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.QGTResult +--- + +# QGTResult + + + +`qiskit.algorithms.gradients.QGTResult(qgts, derivative_type, metadata, options)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/base/qgt_result.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Result of QGT. + +## Attributes + + + +### qgts + +`list[numpy.ndarray]` + +The QGT. + + + +### derivative\_type + +`DerivativeType` + +The type of derivative. + + + +### metadata + +`list[dict[str, Any]]` + +Additional information about the job. + + + +### options + +`Options` + +Primitive runtime options for the execution of the job. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseEstimatorGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseEstimatorGradient.md new file mode 100644 index 00000000000..de777e4f0c5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseEstimatorGradient.md @@ -0,0 +1,104 @@ +--- +title: ReverseEstimatorGradient +description: API reference for qiskit.algorithms.gradients.ReverseEstimatorGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.ReverseEstimatorGradient +--- + +# ReverseEstimatorGradient + + + +`qiskit.algorithms.gradients.ReverseEstimatorGradient(derivative_type=DerivativeType.REAL)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/reverse/reverse_gradient.py "view source code") + +Bases: [`BaseEstimatorGradient`](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.base.base_estimator_gradient.BaseEstimatorGradient") + +Estimator gradients with the classically efficient reverse mode. + + + This gradient implementation is based on statevector manipulations and scales exponentially with the number of qubits. However, for small system sizes it can be very fast compared to circuit-based gradients. + + +This class implements the calculation of the expectation gradient as described in \[1]. By keeping track of two statevectors and iteratively sweeping through each parameterized gate, this method scales only linearly with the number of parameters. + +**References:** + +> **\[1]: Jones, T. and Gacon, J. “Efficient calculation of gradients in classical simulations** +> +> of variational quantum algorithms” (2020). [arXiv:2009.02823](https://arxiv.org/abs/2009.02823). + +**Parameters** + +**derivative\_type** (*DerivativeType*) – Defines whether the real, imaginary or real plus imaginary part of the gradient is returned. + +## Attributes + + + +### SUPPORTED\_GATES + +`= ['rx', 'ry', 'rz', 'cp', 'crx', 'cry', 'crz']` + + + +### derivative\_type + +Return the derivative type (real, imaginary or complex). + +**Returns** + +The derivative type. + + + +### options + +Return the union of estimator options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + estimator options. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values, parameters=None, **options)` + +Run the job of the estimator gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*]*) – The list of observables. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th element of the i-th result corresponds to the gradient of the i-th circuit with respect to the j-th parameter. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseQGT.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseQGT.md new file mode 100644 index 00000000000..9ed09abdbcb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.ReverseQGT.md @@ -0,0 +1,100 @@ +--- +title: ReverseQGT +description: API reference for qiskit.algorithms.gradients.ReverseQGT +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.ReverseQGT +--- + +# ReverseQGT + + + +`qiskit.algorithms.gradients.ReverseQGT(phase_fix=True, derivative_type=DerivativeType.COMPLEX)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/reverse/reverse_qgt.py "view source code") + +Bases: [`BaseQGT`](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.base.base_qgt.BaseQGT") + +QGT calculation with the classically efficient reverse mode. + + + This QGT implementation is based on statevector manipulations and scales exponentially with the number of qubits. However, for small system sizes it can be very fast compared to circuit-based gradients. + + +This class implements the calculation of the QGT as described in \[1]. By keeping track of three statevectors and iteratively sweeping through each parameterized gate, this method scales only quadratically with the number of parameters. + +**References:** + +> **\[1]: Jones, T. “Efficient classical calculation of the Quantum Natural Gradient” (2020).** +> +> [arXiv:2011.02991](https://arxiv.org/abs/2011.02991). + +**Parameters** + +* **phase\_fix** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether or not to include the phase fix. +* **derivative\_type** (*DerivativeType*) – Determines whether the complex QGT or only the real or imaginary parts are calculated. + +## Attributes + + + +### SUPPORTED\_GATES + +`= ['rx', 'ry', 'rz', 'cp', 'crx', 'cry', 'crz']` + + + +### derivative\_type + +The derivative type. + + + +### options + +There are no options for the reverse QGT, returns an empty options dict. + +**Returns** + +Empty options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the QGTs on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the QGTs. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the QGTs of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the QGTs of all parameters in each circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > QGT’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +**Returns** + +The job object of the QGTs of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSAEstimatorGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSAEstimatorGradient.md new file mode 100644 index 00000000000..267dce75047 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSAEstimatorGradient.md @@ -0,0 +1,96 @@ +--- +title: SPSAEstimatorGradient +description: API reference for qiskit.algorithms.gradients.SPSAEstimatorGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.SPSAEstimatorGradient +--- + +# SPSAEstimatorGradient + + + +`qiskit.algorithms.gradients.SPSAEstimatorGradient(estimator, epsilon, batch_size=1, seed=None, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/spsa/spsa_estimator_gradient.py "view source code") + +Bases: [`BaseEstimatorGradient`](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.base.base_estimator_gradient.BaseEstimatorGradient") + +Compute the gradients of the expectation value by the Simultaneous Perturbation Stochastic Approximation (SPSA) \[1]. + +**Reference:** \[1] J. C. Spall, Adaptive stochastic approximation by the simultaneous perturbation method in IEEE Transactions on Automatic Control, vol. 45, no. 10, pp. 1839-1853, Oct 2020, [doi: 10.1109/TAC.2000.880982](https://ieeexplore.ieee.org/document/880982) + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator used to compute the gradients. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The offset size for the SPSA gradients. +* **batch\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of gradients to average. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The seed for a random perturbation vector. +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `epsilon` is not positive. + +## Attributes + + + +### derivative\_type + +Return the derivative type (real, imaginary or complex). + +**Returns** + +The derivative type. + + + +### options + +Return the union of estimator options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + estimator options. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values, parameters=None, **options)` + +Run the job of the estimator gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*]*) – The list of observables. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the expectation values. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th element of the i-th result corresponds to the gradient of the i-th circuit with respect to the j-th parameter. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSASamplerGradient.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSASamplerGradient.md new file mode 100644 index 00000000000..4925431e787 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SPSASamplerGradient.md @@ -0,0 +1,85 @@ +--- +title: SPSASamplerGradient +description: API reference for qiskit.algorithms.gradients.SPSASamplerGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.SPSASamplerGradient +--- + +# SPSASamplerGradient + + + +`qiskit.algorithms.gradients.SPSASamplerGradient(sampler, epsilon, batch_size=1, seed=None, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/spsa/spsa_sampler_gradient.py "view source code") + +Bases: [`BaseSamplerGradient`](qiskit.algorithms.gradients.BaseSamplerGradient "qiskit.algorithms.gradients.base.base_sampler_gradient.BaseSamplerGradient") + +Compute the gradients of the sampling probability by the Simultaneous Perturbation Stochastic Approximation (SPSA) \[1]. + +**Reference:** \[1] J. C. Spall, Adaptive stochastic approximation by the simultaneous perturbation method in IEEE Transactions on Automatic Control, vol. 45, no. 10, pp. 1839-1853, Oct 2020, [doi: 10.1109/TAC.2000.880982](https://ieeexplore.ieee.org/document/880982). + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – The sampler used to compute the gradients. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The offset size for the SPSA gradients. +* **batch\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of gradients to average. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The seed for a random perturbation vector. +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `epsilon` is not positive. + +## Attributes + + + +### options + +Return the union of sampler options setting and gradient default options, where, if the same field is set in both, the gradient’s default options override the primitive’s default setting. + +**Returns** + +The gradient default + sampler options. + +## Methods + +### run + + + +`run(circuits, parameter_values, parameters=None, **options)` + +Run the job of the sampler gradient on the given circuits. + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The list of quantum circuits to compute the gradients. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – The list of parameter values to be bound to the circuit. +* **parameters** (*Sequence\[Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None] | None*) – The sequence of parameters to calculate only the gradients of the specified parameters. Each sequence of parameters corresponds to a circuit in `circuits`. Defaults to None, which means that the gradients of all parameters in each circuit are calculated. None in the sequence means that the gradients of all parameters in the corresponding circuit are calculated. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > gradient’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting + +**Returns** + +The job object of the gradients of the sampling probability. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. The j-th quasi-probability distribution in the i-th result corresponds to the gradients of the sampling probability for the j-th parameter in `circuits[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the gradient’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SamplerGradientResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SamplerGradientResult.md new file mode 100644 index 00000000000..a1fceb270a5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.SamplerGradientResult.md @@ -0,0 +1,44 @@ +--- +title: SamplerGradientResult +description: API reference for qiskit.algorithms.gradients.SamplerGradientResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.gradients.SamplerGradientResult +--- + +# SamplerGradientResult + + + +`qiskit.algorithms.gradients.SamplerGradientResult(gradients, metadata, options)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/gradients/base/sampler_gradient_result.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Result of SamplerGradient. + +## Attributes + + + +### gradients + +`list[list[dict[int, float]]]` + +The gradients of the sample probabilities. + + + +### metadata + +`list[dict[str, Any]]` + +Additional information about the job. + + + +### options + +`Options` + +Primitive runtime options for the execution of the job. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.gradients.md b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.md new file mode 100644 index 00000000000..d81968d4121 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.gradients.md @@ -0,0 +1,76 @@ +--- +title: gradients +description: API reference for qiskit.algorithms.gradients +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.gradients +--- + + + + + +# qiskit.algorithms.gradients + + + +## Gradients + + + +`qiskit.algorithms.gradients` + +### Base Classes + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------- | +| [`BaseEstimatorGradient`](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient")(estimator\[, options, ...]) | Base class for an `EstimatorGradient` to compute the gradients of the expectation value. | +| [`BaseQGT`](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT")(estimator\[, phase\_fix, ...]) | Base class to computes the Quantum Geometric Tensor (QGT) given a pure, parameterized quantum state. | +| [`BaseSamplerGradient`](qiskit.algorithms.gradients.BaseSamplerGradient "qiskit.algorithms.gradients.BaseSamplerGradient")(sampler\[, options]) | Base class for a `SamplerGradient` to compute the gradients of the sampling probability. | +| [`EstimatorGradientResult`](qiskit.algorithms.gradients.EstimatorGradientResult "qiskit.algorithms.gradients.EstimatorGradientResult")(gradients, metadata, ...) | Result of EstimatorGradient. | +| [`SamplerGradientResult`](qiskit.algorithms.gradients.SamplerGradientResult "qiskit.algorithms.gradients.SamplerGradientResult")(gradients, metadata, ...) | Result of SamplerGradient. | +| [`QGTResult`](qiskit.algorithms.gradients.QGTResult "qiskit.algorithms.gradients.QGTResult")(qgts, derivative\_type, metadata, ...) | Result of QGT. | + +### Finite Differences + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- | +| [`FiniteDiffEstimatorGradient`](qiskit.algorithms.gradients.FiniteDiffEstimatorGradient "qiskit.algorithms.gradients.FiniteDiffEstimatorGradient")(estimator, epsilon) | Compute the gradients of the expectation values by finite difference method \[1]. | +| [`FiniteDiffSamplerGradient`](qiskit.algorithms.gradients.FiniteDiffSamplerGradient "qiskit.algorithms.gradients.FiniteDiffSamplerGradient")(sampler, epsilon) | Compute the gradients of the sampling probability by finite difference method \[1]. | + +### Linear Combination of Unitaries + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------ | -------------------------------------------------------------------------------------- | +| [`LinCombEstimatorGradient`](qiskit.algorithms.gradients.LinCombEstimatorGradient "qiskit.algorithms.gradients.LinCombEstimatorGradient")(estimator\[, ...]) | Compute the gradients of the expectation values. | +| [`LinCombSamplerGradient`](qiskit.algorithms.gradients.LinCombSamplerGradient "qiskit.algorithms.gradients.LinCombSamplerGradient")(sampler\[, options]) | Compute the gradients of the sampling probability. | +| [`LinCombQGT`](qiskit.algorithms.gradients.LinCombQGT "qiskit.algorithms.gradients.LinCombQGT")(estimator\[, phase\_fix, ...]) | Computes the Quantum Geometric Tensor (QGT) given a pure, parameterized quantum state. | + +### Parameter Shift Rules + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- | +| [`ParamShiftEstimatorGradient`](qiskit.algorithms.gradients.ParamShiftEstimatorGradient "qiskit.algorithms.gradients.ParamShiftEstimatorGradient")(estimator\[, ...]) | Compute the gradients of the expectation values by the parameter shift rule \[1]. | +| [`ParamShiftSamplerGradient`](qiskit.algorithms.gradients.ParamShiftSamplerGradient "qiskit.algorithms.gradients.ParamShiftSamplerGradient")(sampler\[, options]) | Compute the gradients of the sampling probability by the parameter shift rule \[1]. | + +### Quantum Fisher Information + +| | | +| --------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------- | +| [`QFIResult`](qiskit.algorithms.gradients.QFIResult "qiskit.algorithms.gradients.QFIResult")(qfis, metadata, options) | Result of QFI. | +| [`QFI`](qiskit.algorithms.gradients.QFI "qiskit.algorithms.gradients.QFI")(qgt\[, options]) | Computes the Quantum Fisher Information (QFI) given a pure, parameterized quantum state. | + +### Classical Methods + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------- | +| [`ReverseEstimatorGradient`](qiskit.algorithms.gradients.ReverseEstimatorGradient "qiskit.algorithms.gradients.ReverseEstimatorGradient")(\[derivative\_type]) | Estimator gradients with the classically efficient reverse mode. | +| [`ReverseQGT`](qiskit.algorithms.gradients.ReverseQGT "qiskit.algorithms.gradients.ReverseQGT")(\[phase\_fix, derivative\_type]) | QGT calculation with the classically efficient reverse mode. | + +### Simultaneous Perturbation Stochastic Approximation + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------ | +| [`SPSAEstimatorGradient`](qiskit.algorithms.gradients.SPSAEstimatorGradient "qiskit.algorithms.gradients.SPSAEstimatorGradient")(estimator, epsilon\[, ...]) | Compute the gradients of the expectation value by the Simultaneous Perturbation Stochastic Approximation (SPSA) \[1]. | +| [`SPSASamplerGradient`](qiskit.algorithms.gradients.SPSASamplerGradient "qiskit.algorithms.gradients.SPSASamplerGradient")(sampler, epsilon\[, ...]) | Compute the gradients of the sampling probability by the Simultaneous Perturbation Stochastic Approximation (SPSA) \[1]. | + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQE.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQE.md new file mode 100644 index 00000000000..2b818c6e3f7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQE.md @@ -0,0 +1,143 @@ +--- +title: AdaptVQE +description: API reference for qiskit.algorithms.minimum_eigensolvers.AdaptVQE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.AdaptVQE +--- + +# AdaptVQE + + + +`qiskit.algorithms.minimum_eigensolvers.AdaptVQE(solver, *, gradient_threshold=1e-05, eigenvalue_threshold=1e-05, max_iterations=None, threshold=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/adapt_vqe.py "view source code") + +Bases: `VariationalAlgorithm`, [`MinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.minimum_eigensolver.MinimumEigensolver") + +The Adaptive Variational Quantum Eigensolver algorithm. + +[AdaptVQE](https://arxiv.org/abs/1812.11173) is a quantum algorithm which creates a compact ansatz from a set of evolution operators. It iteratively extends the ansatz circuit, by selecting the building block that leads to the largest gradient from a set of candidates. In chemistry, this is usually a list of orbital excitations. Thus, a common choice of ansatz to be used with this algorithm is the Unitary Coupled Cluster ansatz implemented in Qiskit Nature. This results in a wavefunction ansatz which is uniquely adapted to the operator whose minimum eigenvalue is being determined. This class relies on a supplied instance of [`VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE") to find the minimum eigenvalue. The performance of AdaptVQE significantly depends on the minimization routine. + +```python +from qiskit.algorithms.minimum_eigensolvers import AdaptVQE, VQE +from qiskit.algorithms.optimizers import SLSQP +from qiskit.primitives import Estimator +from qiskit.circuit.library import EvolvedOperatorAnsatz + +# get your Hamiltonian +hamiltonian = ... + +# construct your ansatz +ansatz = EvolvedOperatorAnsatz(...) + +vqe = VQE(Estimator(), ansatz, SLSQP()) + +adapt_vqe = AdaptVQE(vqe) + +eigenvalue, _ = adapt_vqe.compute_minimum_eigenvalue(hamiltonian) +``` + +The following attributes can be set via the initializer but can also be read and updated once the AdaptVQE object has been constructed. + + + +### solver + +a [`VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE") instance used internally to compute the minimum eigenvalues. It is a requirement that the [`ansatz`](qiskit.algorithms.minimum_eigensolvers.VQE#ansatz "qiskit.algorithms.minimum_eigensolvers.VQE.ansatz") of this solver is of type [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz"). + + + +### gradient\_threshold + +once all gradients have an absolute value smaller than this threshold, the algorithm has converged and terminates. + + + +### eigenvalue\_threshold + +once the eigenvalue has changed by less than this threshold from one iteration to the next, the algorithm has converged and terminates. When this case occurs, the excitation included in the final iteration did not result in a significant improvement of the eigenvalue and, thus, the results from this iteration are not considered. + + + +### max\_iterations + +the maximum number of iterations for the adaptive loop. If `None`, the algorithm is not bound in its number of iterations. + + + `qiskit.algorithms.minimum_eigensolvers.adapt_vqe.AdaptVQE.__init__()`’s argument `threshold` is pending deprecation as of qiskit-terra 0.24.0. It will be marked deprecated in a future release, and then removed no earlier than 3 months after the release date. Instead, use the argument `gradient_threshold`, which behaves identically. + + +**Parameters** + +* **solver** ([*VQE*](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE")) – a [`VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE") instance used internally to compute the minimum eigenvalues. It is a requirement that the [`ansatz`](qiskit.algorithms.minimum_eigensolvers.VQE#ansatz "qiskit.algorithms.minimum_eigensolvers.VQE.ansatz") of this solver is of type [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz"). +* **gradient\_threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – once all gradients have an absolute value smaller than this threshold, the algorithm has converged and terminates. +* **eigenvalue\_threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – once the eigenvalue has changed by less than this threshold from one iteration to the next, the algorithm has converged and terminates. When this case occurs, the excitation included in the final iteration did not result in a significant improvement of the eigenvalue and, thus, the results from this iteration are not considered. +* **max\_iterations** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – the maximum number of iterations for the adaptive loop. If `None`, the algorithm is not bound in its number of iterations. +* **threshold** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – once all gradients have an absolute value smaller than this threshold, the algorithm has converged and terminates. Defaults to `1e-5`. + +## Attributes + + + +### initial\_point + +Returns the initial point of the internal [`VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE") solver. + + + +### threshold + +The threshold for the gradients. + +Once all gradients have an absolute value smaller than this threshold, the algorithm has converged and terminates. + + + The property `qiskit.algorithms.minimum_eigensolvers.adapt_vqe.AdaptVQE.threshold` is pending deprecation as of qiskit-terra 0.24.0. It will be marked deprecated in a future release, and then removed no earlier than 3 months after the release date. Instead, use the gradient\_threshold attribute. + + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes the minimum eigenvalue. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Operator whose minimum eigenvalue we want to find. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Additional auxiliary operators to evaluate. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If an ansatz other than [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.EvolvedOperatorAnsatz") is provided. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If all evaluated gradients lie below the convergence threshold in the first iteration of the algorithm. + +**Returns** + +An [`AdaptVQEResult`](qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult "qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult") which is a [`VQEResult`](qiskit.algorithms.minimum_eigensolvers.VQEResult "qiskit.algorithms.minimum_eigensolvers.VQEResult") but also but also includes runtime information about the AdaptVQE algorithm like the number of iterations, termination criterion, and the final maximum gradient. + +**Return type** + +[AdaptVQEResult](qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult "qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenvalue of the main `operator` then it can compute the expectation value of the `aux_operators` for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult.md new file mode 100644 index 00000000000..df1b52a7773 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult.md @@ -0,0 +1,122 @@ +--- +title: AdaptVQEResult +description: API reference for qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult +--- + +# AdaptVQEResult + + + +`qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/adapt_vqe.py "view source code") + +Bases: [`VQEResult`](qiskit.algorithms.minimum_eigensolvers.VQEResult "qiskit.algorithms.minimum_eigensolvers.vqe.VQEResult") + +AdaptVQE Result. + +## Attributes + + + +### aux\_operators\_evaluated + +The aux operator expectation values. + +These values are in fact tuples formatted as (mean, (variance, shots)). + + + +### cost\_function\_evals + +The number of cost optimizer evaluations. + + + +### eigenvalue + +The computed minimum eigenvalue. + + + +### eigenvalue\_history + +Returns the history of computed eigenvalues. + +The history’s length matches the number of iterations and includes the final computed value. + + + +### final\_max\_gradient + +Returns the final maximum gradient. + + + +### num\_iterations + +Returns the number of iterations. + + + +### optimal\_circuit + +The optimal circuits. Along with the optimal parameters, these can be used to retrieve the minimum eigenstate. + + + +### optimal\_parameters + +Returns the optimal parameters in a dictionary + + + +### optimal\_point + +Returns optimal point + + + +### optimal\_value + +Returns optimal value + + + +### optimizer\_evals + +Returns number of optimizer evaluations + + + +### optimizer\_result + +Returns the optimizer result + + + +### optimizer\_time + +Returns time taken for optimization + + + +### termination\_criterion + +Returns the termination criterion. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver.md new file mode 100644 index 00000000000..24547fd50b7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver.md @@ -0,0 +1,61 @@ +--- +title: MinimumEigensolver +description: API reference for qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver +--- + +# MinimumEigensolver + + + +`qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/minimum_eigensolver.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +The minimum eigensolver interface. + +Algorithms that can compute a minimum eigenvalue for an operator may implement this interface to allow different algorithms to be used interchangeably. + +## Methods + +### compute\_minimum\_eigenvalue + + + +`abstract compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes the minimum eigenvalue. The `operator` and `aux_operators` are supplied here. While an `operator` is required by algorithms, `aux_operators` are optional. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Qubit operator of the observable. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the parameters of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators and total particle count operators, so we can get values for these at the ground state. + +**Returns** + +A minimum eigensolver result. + +**Return type** + +[MinimumEigensolverResult](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenvalue of the main `operator` then it can compute the expectation value of the `aux_operators` for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult.md new file mode 100644 index 00000000000..f266555b086 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult.md @@ -0,0 +1,48 @@ +--- +title: MinimumEigensolverResult +description: API reference for qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult +--- + +# MinimumEigensolverResult + + + +`qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/minimum_eigensolver.py "view source code") + +Bases: `AlgorithmResult` + +Minimum eigensolver result. + +## Attributes + + + +### aux\_operators\_evaluated + +The aux operator expectation values. + +These values are in fact tuples formatted as (mean, (variance, shots)). + + + +### eigenvalue + +The computed minimum eigenvalue. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver.md new file mode 100644 index 00000000000..241eb954e2b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver.md @@ -0,0 +1,71 @@ +--- +title: NumPyMinimumEigensolver +description: API reference for qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver +--- + +# NumPyMinimumEigensolver + + + +`qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver(filter_criterion=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/numpy_minimum_eigensolver.py "view source code") + +Bases: [`MinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.minimum_eigensolver.MinimumEigensolver") + +The NumPy minimum eigensolver algorithm. + +**Parameters** + +**filter\_criterion** (*FilterType | None*) – Callable that allows to filter eigenvalues/eigenstates. The minimum eigensolver is only searching over feasible states and returns an eigenstate that has the smallest eigenvalue among feasible states. The callable has the signature `filter(eigenstate, eigenvalue, aux_values)` and must return a boolean to indicate whether to consider this value or not. If there is no feasible element, the result can even be empty. + +## Attributes + + + +### filter\_criterion + +Returns the criterion for filtering eigenstates/eigenvalues. + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes the minimum eigenvalue. The `operator` and `aux_operators` are supplied here. While an `operator` is required by algorithms, `aux_operators` are optional. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Qubit operator of the observable. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the parameters of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators and total particle count operators, so we can get values for these at the ground state. + +**Returns** + +A minimum eigensolver result. + +**Return type** + +[NumPyMinimumEigensolverResult](qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenvalue of the main `operator` then it can compute the expectation value of the `aux_operators` for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult.md new file mode 100644 index 00000000000..f069d8c2da4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult.md @@ -0,0 +1,54 @@ +--- +title: NumPyMinimumEigensolverResult +description: API reference for qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult +--- + +# NumPyMinimumEigensolverResult + + + +`qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/numpy_minimum_eigensolver.py "view source code") + +Bases: [`MinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.minimum_eigensolver.MinimumEigensolverResult") + +NumPy minimum eigensolver result. + +## Attributes + + + +### aux\_operators\_evaluated + +The aux operator expectation values. + +These values are in fact tuples formatted as (mean, (variance, shots)). + + + +### eigenstate + +Returns the eigenstate corresponding to the computed minimum eigenvalue. + + + +### eigenvalue + +The computed minimum eigenvalue. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.QAOA.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.QAOA.md new file mode 100644 index 00000000000..eaa30f6196f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.QAOA.md @@ -0,0 +1,172 @@ +--- +title: QAOA +description: API reference for qiskit.algorithms.minimum_eigensolvers.QAOA +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.QAOA +--- + +# QAOA + + + +`qiskit.algorithms.minimum_eigensolvers.QAOA(sampler, optimizer, *, reps=1, initial_state=None, mixer=None, initial_point=None, aggregation=None, callback=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/qaoa.py "view source code") + +Bases: [`SamplingVQE`](qiskit.algorithms.minimum_eigensolvers.SamplingVQE "qiskit.algorithms.minimum_eigensolvers.sampling_vqe.SamplingVQE") + +The Quantum Approximate Optimization Algorithm (QAOA). + +QAOA is a well-known algorithm for finding approximate solutions to combinatorial-optimization problems \[1]. + +The QAOA implementation directly extends [`SamplingVQE`](qiskit.algorithms.minimum_eigensolvers.SamplingVQE "qiskit.algorithms.minimum_eigensolvers.SamplingVQE") and inherits its optimization structure. However, unlike VQE, which can be configured with arbitrary ansatzes, QAOA uses its own fine-tuned ansatz, which comprises $p$ parameterized global $x$ rotations and $p$ different parameterizations of the problem hamiltonian. QAOA is thus principally configured by the single integer parameter, `reps`, which dictates the depth of the ansatz, and thus affects the approximation quality. + +An optional array of $2p$ parameter values, as the [`initial_point`](#qiskit.algorithms.minimum_eigensolvers.QAOA.initial_point "qiskit.algorithms.minimum_eigensolvers.QAOA.initial_point"), may be provided as the starting $\beta$ and $\gamma$ parameters for the QAOA ansatz \[1]. + +An operator or a parameterized quantum circuit may optionally also be provided as a custom [`mixer`](#qiskit.algorithms.minimum_eigensolvers.QAOA.mixer "qiskit.algorithms.minimum_eigensolvers.QAOA.mixer") Hamiltonian. This allows in the case of quantum annealing \[2] and QAOA \[3], to run constrained optimization problems where the mixer constrains the evolution to a feasible subspace of the full Hilbert space. + +The following attributes can be set via the initializer but can also be read and updated once the QAOA object has been constructed. + + + +### sampler + +The sampler primitive to sample the circuits. + +**Type** + +[BaseSampler](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") + + + +### optimizer + +A classical optimizer to find the minimum energy. This can either be a Qiskit [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") or a callable implementing the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol. + +**Type** + +[Optimizer](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") | [Minimizer](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") + + + +### reps + +The integer parameter $p$. Has a minimum valid value of 1. + +**Type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### initial\_state + +An optional initial state to prepend the QAOA circuit with. + + + +### mixer + +The mixer Hamiltonian to evolve with or a custom quantum circuit. Allows support of optimizations in constrained subspaces \[2, 3] as well as warm-starting the optimization \[4]. + +**Type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") | BaseOperator | [PauliSumOp](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") + + + +### aggregation + +A float or callable to specify how the objective function evaluated on the basis states should be aggregated. If a float, this specifies the $\alpha \in [0,1]$ parameter for a CVaR expectation value. + +**Type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | Callable\[\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] | None + + + +### callback + +A callback that can access the intermediate data at each optimization step. These data are: the evaluation count, the optimizer parameters for the ansatz, the evaluated value, the the metadata dictionary, and the best measurement. + +**Type** + +Callable\[\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), np.ndarray, [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), Any]], None] | None + +**References** + +**\[1]: Farhi, E., Goldstone, J., Gutmann, S., “A Quantum Approximate Optimization Algorithm”** + +[arXiv:1411.4028](https://arxiv.org/abs/1411.4028) + +**\[2]: Hen, I., Spedalieri, F. M., “Quantum Annealing for Constrained Optimization”** + +[PhysRevApplied.5.034007](https://doi.org/10.1103/PhysRevApplied.5.034007) + +**\[3]: Hadfield, S. et al, “From the Quantum Approximate Optimization Algorithm to a Quantum** + +Alternating Operator Ansatz” [arXiv:1709.03489](https://arxiv.org/abs/1709.03489) + +**\[4]: Egger, D. J., Marecek, J., Woerner, S., “Warm-starting quantum optimization”** + +[arXiv: 2009.10095](https://arxiv.org/abs/2009.10095) + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – The sampler primitive to sample the circuits. +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer")) – A classical optimizer to find the minimum energy. This can either be a Qiskit [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") or a callable implementing the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The integer parameter $p$. Has a minimum valid value of 1. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – An optional initial state to prepend the QAOA circuit with. +* **mixer** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| BaseOperator |*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – The mixer Hamiltonian to evolve with or a custom quantum circuit. Allows support of optimizations in constrained subspaces \[2, 3] as well as warm-starting the optimization \[4]. +* **initial\_point** (*np.ndarray | None*) – An optional initial point (i.e. initial parameter values) for the optimizer. The length of the initial point must match the number of `ansatz` parameters. If `None`, a random point will be generated within certain parameter bounds. `QAOA` will look to the ansatz for these bounds. If the ansatz does not specify bounds, bounds of $-2\pi$, $2\pi$ will be used. +* **aggregation** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| Callable\[\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A float or callable to specify how the objective function evaluated on the basis states should be aggregated. If a float, this specifies the $\alpha \in [0,1]$ parameter for a CVaR expectation value. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.ndarray,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any]], None] | None*) – A callback that can access the intermediate data at each optimization step. These data are: the evaluation count, the optimizer parameters for the ansatz, the evaluated value, the metadata dictionary. + +## Attributes + + + +### initial\_point + +Return the initial point. + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Compute the minimum eigenvalue of a diagonal operator. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Diagonal qubit operator. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the final state. + +**Returns** + +A [`SamplingMinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult") containing the optimization result. + +**Return type** + +[SamplingMinimumEigensolverResult](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenstate of the main operator then it can compute the expectation value of the aux\_operators for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver.md new file mode 100644 index 00000000000..9e5c8a06871 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver.md @@ -0,0 +1,59 @@ +--- +title: SamplingMinimumEigensolver +description: API reference for qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver +--- + +# SamplingMinimumEigensolver + + + +`qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/sampling_mes.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +The Sampling Minimum Eigensolver Interface. + +## Methods + +### compute\_minimum\_eigenvalue + + + +`abstract compute_minimum_eigenvalue(operator, aux_operators=None)` + +Compute the minimum eigenvalue of a diagonal operator. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Diagonal qubit operator. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the final state. + +**Returns** + +A [`SamplingMinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult") containing the optimization result. + +**Return type** + +[SamplingMinimumEigensolverResult](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenstate of the main operator then it can compute the expectation value of the aux\_operators for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult.md new file mode 100644 index 00000000000..7151188f85a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult.md @@ -0,0 +1,66 @@ +--- +title: SamplingMinimumEigensolverResult +description: API reference for qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult +--- + +# SamplingMinimumEigensolverResult + + + +`qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/sampling_mes.py "view source code") + +Bases: `AlgorithmResult` + +Sampling Minimum Eigensolver Result. + +In contrast to the result of a `MinimumEigenSolver`, this result also contains the best measurement of the overall optimization and the samples of the final state. + +## Attributes + + + +### aux\_operators\_evaluated + +Return aux operator expectation values and metadata. + +These are formatted as (mean, metadata). + + + +### best\_measurement + +Return the best measurement over the entire optimization. + +Possesses keys: `state`, `bitstring`, `value`, `probability`. + + + +### eigenstate + +Return the quasi-distribution sampled from the final state. + +The ansatz is sampled when parameterized with the optimal parameters that where obtained computing the minimum eigenvalue. The keys represent a measured classical value and the value is a float for the quasi-probability of that result. + + + +### eigenvalue + +Return the approximation to the eigenvalue. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQE.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQE.md new file mode 100644 index 00000000000..111a7b339d0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQE.md @@ -0,0 +1,168 @@ +--- +title: SamplingVQE +description: API reference for qiskit.algorithms.minimum_eigensolvers.SamplingVQE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.SamplingVQE +--- + +# SamplingVQE + + + +`qiskit.algorithms.minimum_eigensolvers.SamplingVQE(sampler, ansatz, optimizer, *, initial_point=None, aggregation=None, callback=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/sampling_vqe.py "view source code") + +Bases: `VariationalAlgorithm`, [`SamplingMinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.sampling_mes.SamplingMinimumEigensolver") + +The Variational Quantum Eigensolver algorithm, optimized for diagonal Hamiltonians. + +VQE is a hybrid quantum-classical algorithm that uses a variational technique to find the minimum eigenvalue of a given diagonal Hamiltonian operator $H_{\text{diag}}$. + +In contrast to the [`VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE") class, the `SamplingVQE` algorithm is executed using a [`sampler`](#qiskit.algorithms.minimum_eigensolvers.SamplingVQE.sampler "qiskit.algorithms.minimum_eigensolvers.SamplingVQE.sampler") primitive. + +An instance of `SamplingVQE` also requires an [`ansatz`](#qiskit.algorithms.minimum_eigensolvers.SamplingVQE.ansatz "qiskit.algorithms.minimum_eigensolvers.SamplingVQE.ansatz"), a parameterized [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), to prepare the trial state $|\psi(\vec\theta)\rangle$. It also needs a classical [`optimizer`](#qiskit.algorithms.minimum_eigensolvers.SamplingVQE.optimizer "qiskit.algorithms.minimum_eigensolvers.SamplingVQE.optimizer") which varies the circuit parameters $\vec\theta$ to minimize the objective function, which depends on the chosen [`aggregation`](#qiskit.algorithms.minimum_eigensolvers.SamplingVQE.aggregation "qiskit.algorithms.minimum_eigensolvers.SamplingVQE.aggregation"). + +The optimizer can either be one of Qiskit’s optimizers, such as [`SPSA`](qiskit.algorithms.optimizers.SPSA "qiskit.algorithms.optimizers.SPSA") or a callable with the following signature: + +```python +from qiskit.algorithms.optimizers import OptimizerResult + +def my_minimizer(fun, x0, jac=None, bounds=None) -> OptimizerResult: + # Note that the callable *must* have these argument names! + # Args: + # fun (callable): the function to minimize + # x0 (np.ndarray): the initial point for the optimization + # jac (callable, optional): the gradient of the objective function + # bounds (list, optional): a list of tuples specifying the parameter bounds + + result = OptimizerResult() + result.x = # optimal parameters + result.fun = # optimal function value + return result +``` + +The above signature also allows one to use any SciPy minimizer, for instance as + +```python +from functools import partial +from scipy.optimize import minimize + +optimizer = partial(minimize, method="L-BFGS-B") +``` + +The following attributes can be set via the initializer but can also be read and updated once the `SamplingVQE` object has been constructed. + + + +### sampler + +The sampler primitive to sample the circuits. + +**Type** + +[BaseSampler](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") + + + +### ansatz + +A parameterized quantum circuit to prepare the trial state. + +**Type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + +### optimizer + +A classical optimizer to find the minimum energy. This can either be a Qiskit [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") or a callable implementing the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol. + +**Type** + +[Optimizer](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") | [Minimizer](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") + + + +### aggregation + +A float or callable to specify how the objective function evaluated on the basis states should be aggregated. If a float, this specifies the $\alpha \in [0,1]$ parameter for a CVaR expectation value \[1]. If a callable, it takes a list of basis state measurements specified as `[(probability, objective_value)]` and return an objective value as float. If None, all an ordinary expectation value is calculated. + +**Type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | Callable\[\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")]], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] | None + + + +### callback + +A callback that can access the intermediate data at each optimization step. These data are: the evaluation count, the optimizer parameters for the ansatz, the evaluated value, and the metadata dictionary. + +**Type** + +Callable\[\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), np.ndarray, [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), Any]], None] | None + +**References** + +**\[1]: Barkoutsos, P. K., Nannicini, G., Robert, A., Tavernelli, I., and Woerner, S.,** + +“Improving Variational Quantum Optimization using CVaR” [arXiv:1907.04769](https://arxiv.org/abs/1907.04769) + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – The sampler primitive to sample the circuits. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A parameterized quantum circuit to prepare the trial state. +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer")) – A classical optimizer to find the minimum energy. This can either be a Qiskit [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") or a callable implementing the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol. +* **initial\_point** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – An optional initial point (i.e. initial parameter values) for the optimizer. The length of the initial point must match the number of [`ansatz`](#qiskit.algorithms.minimum_eigensolvers.SamplingVQE.ansatz "qiskit.algorithms.minimum_eigensolvers.SamplingVQE.ansatz") parameters. If `None`, a random point will be generated within certain parameter bounds. `SamplingVQE` will look to the ansatz for these bounds. If the ansatz does not specify bounds, bounds of $-2\pi$, $2\pi$ will be used. +* **aggregation** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| Callable\[\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A float or callable to specify how the objective function evaluated on the basis states should be aggregated. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.ndarray,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any]], None] | None*) – A callback that can access the intermediate data at each optimization step. These data are: the evaluation count, the optimizer parameters for the ansatz, the estimated value, and the metadata dictionary. + +## Attributes + + + +### initial\_point + +Return the initial point. + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Compute the minimum eigenvalue of a diagonal operator. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Diagonal qubit operator. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the final state. + +**Returns** + +A [`SamplingMinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult") containing the optimization result. + +**Return type** + +[SamplingMinimumEigensolverResult](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenstate of the main operator then it can compute the expectation value of the aux\_operators for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult.md new file mode 100644 index 00000000000..7d26c4b94bd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult.md @@ -0,0 +1,112 @@ +--- +title: SamplingVQEResult +description: API reference for qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult +--- + +# SamplingVQEResult + + + +`qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/sampling_vqe.py "view source code") + +Bases: `VariationalResult`, [`SamplingMinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.sampling_mes.SamplingMinimumEigensolverResult") + +VQE Result. + +## Attributes + + + +### aux\_operators\_evaluated + +Return aux operator expectation values and metadata. + +These are formatted as (mean, metadata). + + + +### best\_measurement + +Return the best measurement over the entire optimization. + +Possesses keys: `state`, `bitstring`, `value`, `probability`. + + + +### cost\_function\_evals + +Returns number of cost optimizer evaluations + + + +### eigenstate + +Return the quasi-distribution sampled from the final state. + +The ansatz is sampled when parameterized with the optimal parameters that where obtained computing the minimum eigenvalue. The keys represent a measured classical value and the value is a float for the quasi-probability of that result. + + + +### eigenvalue + +Return the approximation to the eigenvalue. + + + +### optimal\_circuit + +The optimal circuits. Along with the optimal parameters, these can be used to retrieve the minimum eigenstate. + + + +### optimal\_parameters + +Returns the optimal parameters in a dictionary + + + +### optimal\_point + +Returns optimal point + + + +### optimal\_value + +Returns optimal value + + + +### optimizer\_evals + +Returns number of optimizer evaluations + + + +### optimizer\_result + +Returns the optimizer result + + + +### optimizer\_time + +Returns time taken for optimization + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQE.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQE.md new file mode 100644 index 00000000000..cf602d09778 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQE.md @@ -0,0 +1,172 @@ +--- +title: VQE +description: API reference for qiskit.algorithms.minimum_eigensolvers.VQE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.VQE +--- + +# VQE + + + +`qiskit.algorithms.minimum_eigensolvers.VQE(estimator, ansatz, optimizer, *, gradient=None, initial_point=None, callback=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/vqe.py "view source code") + +Bases: `VariationalAlgorithm`, [`MinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.minimum_eigensolver.MinimumEigensolver") + +The variational quantum eigensolver (VQE) algorithm. + +VQE is a hybrid quantum-classical algorithm that uses a variational technique to find the minimum eigenvalue of a given Hamiltonian operator $H$. + +The `VQE` algorithm is executed using an [`estimator`](#qiskit.algorithms.minimum_eigensolvers.VQE.estimator "qiskit.algorithms.minimum_eigensolvers.VQE.estimator") primitive, which computes expectation values of operators (observables). + +An instance of `VQE` also requires an [`ansatz`](#qiskit.algorithms.minimum_eigensolvers.VQE.ansatz "qiskit.algorithms.minimum_eigensolvers.VQE.ansatz"), a parameterized [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), to prepare the trial state $|\psi(\vec\theta)\rangle$. It also needs a classical [`optimizer`](#qiskit.algorithms.minimum_eigensolvers.VQE.optimizer "qiskit.algorithms.minimum_eigensolvers.VQE.optimizer") which varies the circuit parameters $\vec\theta$ such that the expectation value of the operator on the corresponding state approaches a minimum, + +$$ +\min_{\vec\theta} \langle\psi(\vec\theta)|H|\psi(\vec\theta)\rangle. +$$ + +The [`estimator`](#qiskit.algorithms.minimum_eigensolvers.VQE.estimator "qiskit.algorithms.minimum_eigensolvers.VQE.estimator") is used to compute this expectation value for every optimization step. + +The optimizer can either be one of Qiskit’s optimizers, such as [`SPSA`](qiskit.algorithms.optimizers.SPSA "qiskit.algorithms.optimizers.SPSA") or a callable with the following signature: + +```python +from qiskit.algorithms.optimizers import OptimizerResult + +def my_minimizer(fun, x0, jac=None, bounds=None) -> OptimizerResult: + # Note that the callable *must* have these argument names! + # Args: + # fun (callable): the function to minimize + # x0 (np.ndarray): the initial point for the optimization + # jac (callable, optional): the gradient of the objective function + # bounds (list, optional): a list of tuples specifying the parameter bounds + + result = OptimizerResult() + result.x = # optimal parameters + result.fun = # optimal function value + return result +``` + +The above signature also allows one to use any SciPy minimizer, for instance as + +```python +from functools import partial +from scipy.optimize import minimize + +optimizer = partial(minimize, method="L-BFGS-B") +``` + +The following attributes can be set via the initializer but can also be read and updated once the VQE object has been constructed. + + + +### estimator + +The estimator primitive to compute the expectation value of the Hamiltonian operator. + +**Type** + +[BaseEstimator](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") + + + +### ansatz + +A parameterized quantum circuit to prepare the trial state. + +**Type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + +### optimizer + +A classical optimizer to find the minimum energy. This can either be a Qiskit [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") or a callable implementing the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol. + +**Type** + +[Optimizer](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") | [Minimizer](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") + + + +### gradient + +An optional estimator gradient to be used with the optimizer. + +**Type** + +[BaseEstimatorGradient](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient") | None + + + +### callback + +A callback that can access the intermediate data at each optimization step. These data are: the evaluation count, the optimizer parameters for the ansatz, the evaluated mean, and the metadata dictionary. + +**Type** + +Callable\[\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), np.ndarray, [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), Any]], None] | None + +**References** + +**\[1]: Peruzzo, A., et al, “A variational eigenvalue solver on a quantum processor”** + +[arXiv:1304.3061](https://arxiv.org/abs/1304.3061) + +**Parameters** + +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator")) – The estimator primitive to compute the expectation value of the Hamiltonian operator. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A parameterized quantum circuit to prepare the trial state. +* **optimizer** ([*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *|*[*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer")) – A classical optimizer to find the minimum energy. This can either be a Qiskit [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") or a callable implementing the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol. +* **gradient** ([*BaseEstimatorGradient*](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient") *| None*) – An optional estimator gradient to be used with the optimizer. +* **initial\_point** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – An optional initial point (i.e. initial parameter values) for the optimizer. The length of the initial point must match the number of [`ansatz`](#qiskit.algorithms.minimum_eigensolvers.VQE.ansatz "qiskit.algorithms.minimum_eigensolvers.VQE.ansatz") parameters. If `None`, a random point will be generated within certain parameter bounds. `VQE` will look to the ansatz for these bounds. If the ansatz does not specify bounds, bounds of $-2\pi$, $2\pi$ will be used. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.ndarray,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any]], None] | None*) – A callback that can access the intermediate data at each optimization step. These data are: the evaluation count, the optimizer parameters for the ansatz, the estimated value, and the metadata dictionary. + +## Attributes + + + +### initial\_point + +## Methods + +### compute\_minimum\_eigenvalue + + + +`compute_minimum_eigenvalue(operator, aux_operators=None)` + +Computes the minimum eigenvalue. The `operator` and `aux_operators` are supplied here. While an `operator` is required by algorithms, `aux_operators` are optional. + +**Parameters** + +* **operator** (*BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")) – Qubit operator of the observable. +* **aux\_operators** (*ListOrDict\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")*] | None*) – Optional list of auxiliary operators to be evaluated with the parameters of the minimum eigenvalue main result and their expectation values returned. For instance in chemistry these can be dipole operators and total particle count operators, so we can get values for these at the ground state. + +**Returns** + +A minimum eigensolver result. + +**Return type** + +[VQEResult](qiskit.algorithms.minimum_eigensolvers.VQEResult "qiskit.algorithms.minimum_eigensolvers.VQEResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +If the minimum eigensolver computes an eigenvalue of the main `operator` then it can compute the expectation value of the `aux_operators` for that state. Otherwise they will be ignored. + +**Returns** + +True if aux\_operator expectations can be evaluated, False otherwise + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQEResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQEResult.md new file mode 100644 index 00000000000..8a66a5b25c7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.VQEResult.md @@ -0,0 +1,96 @@ +--- +title: VQEResult +description: API reference for qiskit.algorithms.minimum_eigensolvers.VQEResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.minimum_eigensolvers.VQEResult +--- + +# VQEResult + + + +`qiskit.algorithms.minimum_eigensolvers.VQEResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/minimum_eigensolvers/vqe.py "view source code") + +Bases: `VariationalResult`, [`MinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.minimum_eigensolver.MinimumEigensolverResult") + +Variational quantum eigensolver result. + +## Attributes + + + +### aux\_operators\_evaluated + +The aux operator expectation values. + +These values are in fact tuples formatted as (mean, (variance, shots)). + + + +### cost\_function\_evals + +The number of cost optimizer evaluations. + + + +### eigenvalue + +The computed minimum eigenvalue. + + + +### optimal\_circuit + +The optimal circuits. Along with the optimal parameters, these can be used to retrieve the minimum eigenstate. + + + +### optimal\_parameters + +Returns the optimal parameters in a dictionary + + + +### optimal\_point + +Returns optimal point + + + +### optimal\_value + +Returns optimal value + + + +### optimizer\_evals + +Returns number of optimizer evaluations + + + +### optimizer\_result + +Returns the optimizer result + + + +### optimizer\_time + +Returns time taken for optimization + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.md b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.md new file mode 100644 index 00000000000..a3bf30ea50c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.minimum_eigensolvers.md @@ -0,0 +1,43 @@ +--- +title: minimum_eigensolvers +description: API reference for qiskit.algorithms.minimum_eigensolvers +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.minimum_eigensolvers +--- + + + + + +# qiskit.algorithms.minimum\_eigensolvers + + + +## Minimum Eigensolvers Package + + + +`qiskit.algorithms.minimum_eigensolvers` + +### Minimum Eigensolvers + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- | +| [`MinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.MinimumEigensolver")() | The minimum eigensolver interface. | +| [`NumPyMinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolver")(\[filter\_criterion]) | The NumPy minimum eigensolver algorithm. | +| [`VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE")(estimator, ansatz, optimizer, \*\[, ...]) | The variational quantum eigensolver (VQE) algorithm. | +| [`AdaptVQE`](qiskit.algorithms.minimum_eigensolvers.AdaptVQE "qiskit.algorithms.minimum_eigensolvers.AdaptVQE")(solver, \*\[, gradient\_threshold, ...]) | The Adaptive Variational Quantum Eigensolver algorithm. | +| [`SamplingMinimumEigensolver`](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolver")() | The Sampling Minimum Eigensolver Interface. | +| [`SamplingVQE`](qiskit.algorithms.minimum_eigensolvers.SamplingVQE "qiskit.algorithms.minimum_eigensolvers.SamplingVQE")(sampler, ansatz, optimizer, \*\[, ...]) | The Variational Quantum Eigensolver algorithm, optimized for diagonal Hamiltonians. | +| [`QAOA`](qiskit.algorithms.minimum_eigensolvers.QAOA "qiskit.algorithms.minimum_eigensolvers.QAOA")(sampler, optimizer, \*\[, reps, ...]) | The Quantum Approximate Optimization Algorithm (QAOA). | + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------- | +| [`MinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.MinimumEigensolverResult")() | Minimum eigensolver result. | +| [`NumPyMinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.NumPyMinimumEigensolverResult")() | NumPy minimum eigensolver result. | +| [`VQEResult`](qiskit.algorithms.minimum_eigensolvers.VQEResult "qiskit.algorithms.minimum_eigensolvers.VQEResult")() | Variational quantum eigensolver result. | +| [`AdaptVQEResult`](qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult "qiskit.algorithms.minimum_eigensolvers.AdaptVQEResult")() | AdaptVQE Result. | +| [`SamplingMinimumEigensolverResult`](qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult "qiskit.algorithms.minimum_eigensolvers.SamplingMinimumEigensolverResult")() | Sampling Minimum Eigensolver Result. | +| [`SamplingVQEResult`](qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult "qiskit.algorithms.minimum_eigensolvers.SamplingVQEResult")() | VQE Result. | + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ADAM.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ADAM.md new file mode 100644 index 00000000000..29caff17444 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ADAM.md @@ -0,0 +1,282 @@ +--- +title: ADAM +description: API reference for qiskit.algorithms.optimizers.ADAM +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.ADAM +--- + +# ADAM + + + +`qiskit.algorithms.optimizers.ADAM(maxiter=10000, tol=1e-06, lr=0.001, beta_1=0.9, beta_2=0.99, noise_factor=1e-08, eps=1e-10, amsgrad=False, snapshot_dir=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/adam_amsgrad.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Adam and AMSGRAD optimizers. + +Adam \[1] is a gradient-based optimization algorithm that is relies on adaptive estimates of lower-order moments. The algorithm requires little memory and is invariant to diagonal rescaling of the gradients. Furthermore, it is able to cope with non-stationary objective functions and noisy and/or sparse gradients. + +AMSGRAD \[2] (a variant of Adam) uses a ‘long-term memory’ of past gradients and, thereby, improves convergence properties. + +**References** + +**\[1]: Kingma, Diederik & Ba, Jimmy (2014), Adam: A Method for Stochastic Optimization.** + +[arXiv:1412.6980](https://arxiv.org/abs/1412.6980) + +**\[2]: Sashank J. Reddi and Satyen Kale and Sanjiv Kumar (2018),** + +On the Convergence of Adam and Beyond. [arXiv:1904.09237](https://arxiv.org/abs/1904.09237) + + + This component has some function that is normally random. If you want to reproduce behavior then you should set the random number generator seed in the algorithm\_globals (`qiskit.utils.algorithm_globals.random_seed = seed`). + + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of iterations +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Tolerance for termination +* **lr** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value >= 0, Learning rate. +* **beta\_1** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value in range 0 to 1, Generally close to 1. +* **beta\_2** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value in range 0 to 1, Generally close to 1. +* **noise\_factor** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value >= 0, Noise factor +* **eps** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value >=0, Epsilon to be used for finite differences if no analytic gradient method is given. +* **amsgrad** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True to use AMSGRAD, False if not +* **snapshot\_dir** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – If not None save the optimizer’s parameter after every step to the given directory + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### load\_params + + + +`load_params(load_dir)` + +Load iteration parameters for a file called `adam_params.csv`. + +**Parameters** + +**load\_dir** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The directory containing `adam_params.csv`. + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None, objective_function=None, initial_point=None, gradient_function=None)` + +Minimize the scalar function. + + + `qiskit.algorithms.optimizers.adam_amsgrad.ADAM.minimize()`’s argument `gradient_function` is deprecated as of qiskit-terra 0.19.0. It will be removed no earlier than 3 months after the release date. Instead, use the argument `jac`, which behaves identically. + + + + `qiskit.algorithms.optimizers.adam_amsgrad.ADAM.minimize()`’s argument `initial_point` is deprecated as of qiskit-terra 0.19.0. It will be removed no earlier than 3 months after the release date. Instead, use the argument `fun`, which behaves identically. + + + + `qiskit.algorithms.optimizers.adam_amsgrad.ADAM.minimize()`’s argument `objective_function` is deprecated as of qiskit-terra 0.19.0. It will be removed no earlier than 3 months after the release date. Instead, use the argument `fun`, which behaves identically. + + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. +* **objective\_function** (*Callable\[\[np.ndarray],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – DEPRECATED. A function handle to the objective function. +* **initial\_point** (*np.ndarray | None*) – DEPRECATED. The initial iteration point. +* **gradient\_function** (*Callable\[\[np.ndarray],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – DEPRECATED. A function handle to the gradient of the objective function. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### save\_params + + + +`save_params(snapshot_dir)` + +Save the current iteration parameters to a file called `adam_params.csv`. + + + The current parameters are appended to the file, if it exists already. The file is not overwritten. + + +**Parameters** + +**snapshot\_dir** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The directory to store the file in. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AQGD.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AQGD.md new file mode 100644 index 00000000000..65fa59ebbed --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AQGD.md @@ -0,0 +1,241 @@ +--- +title: AQGD +description: API reference for qiskit.algorithms.optimizers.AQGD +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.AQGD +--- + +# AQGD + + + +`qiskit.algorithms.optimizers.AQGD(maxiter=1000, eta=1.0, tol=1e-06, momentum=0.25, param_tol=1e-06, averaging=10)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/aqgd.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Analytic Quantum Gradient Descent (AQGD) with Epochs optimizer. Performs gradient descent optimization with a momentum term, analytic gradients, and customized step length schedule for parameterized quantum gates, i.e. Pauli Rotations. See, for example: + +* K. Mitarai, M. Negoro, M. Kitagawa, and K. Fujii. (2018). Quantum circuit learning. Phys. Rev. A 98, 032309. [https://arxiv.org/abs/1803.00745](https://arxiv.org/abs/1803.00745) +* Maria Schuld, Ville Bergholm, Christian Gogolin, Josh Izaac, Nathan Killoran. (2019). Evaluating analytic gradients on quantum hardware. Phys. Rev. A 99, 032331. [https://arxiv.org/abs/1811.11184](https://arxiv.org/abs/1811.11184) + +for further details on analytic gradients of parameterized quantum gates. + +Gradients are computed “analytically” using the quantum circuit when evaluating the objective function. + +Performs Analytical Quantum Gradient Descent (AQGD) with Epochs. + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Maximum number of iterations (full gradient steps) +* **eta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The coefficient of the gradient update. Increasing this value results in larger step sizes: param = previous\_param - eta \* deriv +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Tolerance for change in windowed average of objective values. Convergence occurs when either objective tolerance is met OR parameter tolerance is met. +* **momentum** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Bias towards the previous gradient momentum in current update. Must be within the bounds: \[0,1) +* **param\_tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Tolerance for change in norm of parameters. +* **averaging** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Length of window over which to average objective values for objective convergence criterion + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If the length of `maxiter`, momentum\`, and `eta` is not the same. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Support level dictionary + +**Returns** + +**gradient, bounds and initial point** + +support information that is ignored/required. + +**Return type** + +Dict\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AskData.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AskData.md new file mode 100644 index 00000000000..4de4e0e5852 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.AskData.md @@ -0,0 +1,43 @@ +--- +title: AskData +description: API reference for qiskit.algorithms.optimizers.AskData +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.AskData +--- + +# AskData + + + +`qiskit.algorithms.optimizers.AskData(x_fun=None, x_jac=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/steppable_optimizer.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class for return type of [`ask()`](qiskit.algorithms.optimizers.SteppableOptimizer#ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask"). + +**Parameters** + +* **x\_fun** (*POINT |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[POINT] | None*) – Point or list of points where the function needs to be evaluated to compute the next +* **optimizer.** (*the next state of the*) – +* **x\_jac** (*POINT |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[POINT] | None*) – Point or list of points where the gradient/jacobian needs to be evaluated to compute +* **optimizer.** – + +## Attributes + + + +### x\_fun + +`POINT | list[POINT] | None` + +`= None` + + + +### x\_jac + +`POINT | list[POINT] | None` + +`= None` + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.BOBYQA.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.BOBYQA.md new file mode 100644 index 00000000000..b29803aece4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.BOBYQA.md @@ -0,0 +1,221 @@ +--- +title: BOBYQA +description: API reference for qiskit.algorithms.optimizers.BOBYQA +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.BOBYQA +--- + +# BOBYQA + + + +`qiskit.algorithms.optimizers.BOBYQA(maxiter=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/bobyqa.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Bound Optimization BY Quadratic Approximation algorithm. + +BOBYQA finds local solutions to nonlinear, non-convex minimization problems with optional bound constraints, without requirement of derivatives of the objective function. + +Uses skquant.opt installed with pip install scikit-quant. For further detail, please refer to [https://github.com/scikit-quant/scikit-quant](https://github.com/scikit-quant/scikit-quant) and [https://qat4chem.lbl.gov/software](https://qat4chem.lbl.gov/software). + +**Parameters** + +**maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluations. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – scikit-quant not installed + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Returns support level dictionary. + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CG.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CG.md new file mode 100644 index 00000000000..bf3d7b248dc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CG.md @@ -0,0 +1,224 @@ +--- +title: CG +description: API reference for qiskit.algorithms.optimizers.CG +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.CG +--- + +# CG + + + +`qiskit.algorithms.optimizers.CG(maxiter=20, disp=False, gtol=1e-05, tol=None, eps=1.4901161193847656e-08, options=None, max_evals_grouped=1, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/cg.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Conjugate Gradient optimizer. + +CG is an algorithm for the numerical solution of systems of linear equations whose matrices are symmetric and positive-definite. It is an *iterative algorithm* in that it uses an initial guess to generate a sequence of improving approximate solutions for a problem, in which each approximation is derived from the previous ones. It is often used to solve unconstrained optimization problems, such as energy minimization. + +Uses scipy.optimize.minimize CG. For further detail, please refer to [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of iterations to perform. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True to print convergence messages. +* **gtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gradient norm must be less than gtol before successful termination. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Tolerance for termination. +* **eps** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – If jac is approximated, use this value for the step size. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of default gradient evaluations performed simultaneously. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.COBYLA.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.COBYLA.md new file mode 100644 index 00000000000..5efae1d656e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.COBYLA.md @@ -0,0 +1,222 @@ +--- +title: COBYLA +description: API reference for qiskit.algorithms.optimizers.COBYLA +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.COBYLA +--- + +# COBYLA + + + +`qiskit.algorithms.optimizers.COBYLA(maxiter=1000, disp=False, rhobeg=1.0, tol=None, options=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/cobyla.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Constrained Optimization By Linear Approximation optimizer. + +COBYLA is a numerical optimization method for constrained problems where the derivative of the objective function is not known. + +Uses scipy.optimize.minimize COBYLA. For further detail, please refer to [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluations. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True to print convergence messages. +* **rhobeg** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Reasonable initial changes to the variables. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Final accuracy in the optimization (not precisely guaranteed). This is a lower bound on the size of the trust region. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CRS.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CRS.md new file mode 100644 index 00000000000..edefeb1c72a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.CRS.md @@ -0,0 +1,233 @@ +--- +title: CRS +description: API reference for qiskit.algorithms.optimizers.CRS +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.CRS +--- + +# CRS + + + +`qiskit.algorithms.optimizers.CRS(max_evals=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/nlopts/crs.py "view source code") + +Bases: `NLoptOptimizer` + +Controlled Random Search (CRS) with local mutation optimizer. + +Controlled Random Search (CRS) with local mutation is part of the family of the CRS optimizers. The CRS optimizers start with a random population of points, and randomly evolve these points by heuristic rules. In the case of CRS with local mutation, the evolution is a randomized version of the [`NELDER_MEAD`](qiskit.algorithms.optimizers.NELDER_MEAD "qiskit.algorithms.optimizers.NELDER_MEAD") local optimizer. + +NLopt global optimizer, derivative-free. For further detail, please refer to [https://nlopt.readthedocs.io/en/latest/NLopt\_Algorithms/#controlled-random-search-crs-with-local-mutation](https://nlopt.readthedocs.io/en/latest/NLopt_Algorithms/#controlled-random-search-crs-with-local-mutation) + +**Parameters** + +**max\_evals** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum allowed number of function evaluations. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – NLopt library not installed. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_nlopt\_optimizer + + + +`get_nlopt_optimizer()` + +Return NLopt optimizer type + +**Return type** + +*NLoptOptimizerType* + +### get\_support\_level + + + +`get_support_level()` + +return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L.md new file mode 100644 index 00000000000..9a6af11a6dc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L.md @@ -0,0 +1,235 @@ +--- +title: DIRECT_L +description: API reference for qiskit.algorithms.optimizers.DIRECT_L +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.DIRECT_L +--- + + + +# DIRECT\_L + + + +`qiskit.algorithms.optimizers.DIRECT_L(max_evals=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/nlopts/direct_l.py "view source code") + +Bases: `NLoptOptimizer` + +DIviding RECTangles Locally-biased optimizer. + +DIviding RECTangles (DIRECT) is a deterministic-search algorithms based on systematic division of the search domain into increasingly smaller hyper-rectangles. The DIRECT-L version is a “locally biased” variant of DIRECT that makes the algorithm more biased towards local search, so that it is more efficient for functions with few local minima. + +NLopt global optimizer, derivative-free. For further detail, please refer to [http://nlopt.readthedocs.io/en/latest/NLopt\_Algorithms/#direct-and-direct-l](http://nlopt.readthedocs.io/en/latest/NLopt_Algorithms/#direct-and-direct-l) + +**Parameters** + +**max\_evals** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum allowed number of function evaluations. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – NLopt library not installed. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_nlopt\_optimizer + + + +`get_nlopt_optimizer()` + +Return NLopt optimizer type + +**Return type** + +*NLoptOptimizerType* + +### get\_support\_level + + + +`get_support_level()` + +return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L_RAND.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L_RAND.md new file mode 100644 index 00000000000..c45a5f38af2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.DIRECT_L_RAND.md @@ -0,0 +1,235 @@ +--- +title: DIRECT_L_RAND +description: API reference for qiskit.algorithms.optimizers.DIRECT_L_RAND +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.DIRECT_L_RAND +--- + + + +# DIRECT\_L\_RAND + + + +`qiskit.algorithms.optimizers.DIRECT_L_RAND(max_evals=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/nlopts/direct_l_rand.py "view source code") + +Bases: `NLoptOptimizer` + +DIviding RECTangles Locally-biased Randomized optimizer. + +DIRECT-L RAND is the “locally biased” variant with some randomization in near-tie decisions. See also [`DIRECT_L`](qiskit.algorithms.optimizers.DIRECT_L "qiskit.algorithms.optimizers.DIRECT_L") + +NLopt global optimizer, derivative-free. For further detail, please refer to [http://nlopt.readthedocs.io/en/latest/NLopt\_Algorithms/#direct-and-direct-l](http://nlopt.readthedocs.io/en/latest/NLopt_Algorithms/#direct-and-direct-l) + +**Parameters** + +**max\_evals** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum allowed number of function evaluations. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – NLopt library not installed. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_nlopt\_optimizer + + + +`get_nlopt_optimizer()` + +Return NLopt optimizer type + +**Return type** + +*NLoptOptimizerType* + +### get\_support\_level + + + +`get_support_level()` + +return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ESCH.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ESCH.md new file mode 100644 index 00000000000..2de46484a51 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ESCH.md @@ -0,0 +1,235 @@ +--- +title: ESCH +description: API reference for qiskit.algorithms.optimizers.ESCH +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.ESCH +--- + +# ESCH + + + +`qiskit.algorithms.optimizers.ESCH(max_evals=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/nlopts/esch.py "view source code") + +Bases: `NLoptOptimizer` + +ESCH evolutionary optimizer. + +ESCH is an evolutionary algorithm for global optimization that supports bound constraints only. Specifically, it does not support nonlinear constraints. + +NLopt global optimizer, derivative-free. For further detail, please refer to + +[http://nlopt.readthedocs.io/en/latest/NLopt\_Algorithms/#esch-evolutionary-algorithm](http://nlopt.readthedocs.io/en/latest/NLopt_Algorithms/#esch-evolutionary-algorithm) + +**Parameters** + +**max\_evals** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum allowed number of function evaluations. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – NLopt library not installed. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_nlopt\_optimizer + + + +`get_nlopt_optimizer()` + +Return NLopt optimizer type + +**Return type** + +*NLoptOptimizerType* + +### get\_support\_level + + + +`get_support_level()` + +return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GSLS.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GSLS.md new file mode 100644 index 00000000000..3b9f13d11e5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GSLS.md @@ -0,0 +1,342 @@ +--- +title: GSLS +description: API reference for qiskit.algorithms.optimizers.GSLS +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.GSLS +--- + +# GSLS + + + +`qiskit.algorithms.optimizers.GSLS(maxiter=10000, max_eval=10000, disp=False, sampling_radius=1e-06, sample_size_factor=1, initial_step_size=0.01, min_step_size=1e-10, step_size_multiplier=0.4, armijo_parameter=0.1, min_gradient_norm=1e-08, max_failed_rejection_sampling=50)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/gsls.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Gaussian-smoothed Line Search. + +An implementation of the line search algorithm described in [https://arxiv.org/pdf/1905.01332.pdf](https://arxiv.org/pdf/1905.01332.pdf), using gradient approximation based on Gaussian-smoothed samples on a sphere. + + + This component has some function that is normally random. If you want to reproduce behavior then you should set the random number generator seed in the algorithm\_globals (`qiskit.utils.algorithm_globals.random_seed = seed`). + + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of iterations. +* **max\_eval** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of evaluations. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True to display convergence messages. +* **sampling\_radius** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Sampling radius to determine gradient estimate. +* **sample\_size\_factor** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The size of the sample set at each iteration is this number multiplied by the dimension of the problem, rounded to the nearest integer. +* **initial\_step\_size** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Initial step size for the descent algorithm. +* **min\_step\_size** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Minimum step size for the descent algorithm. +* **step\_size\_multiplier** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Step size reduction after unsuccessful steps, in the interval (0, 1). +* **armijo\_parameter** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Armijo parameter for sufficient decrease criterion, in the interval (0, 1). +* **min\_gradient\_norm** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – If the gradient norm is below this threshold, the algorithm stops. +* **max\_failed\_rejection\_sampling** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of attempts to sample points within bounds. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary. + +**Returns** + +A dictionary containing the support levels for different options. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + +### gradient\_approximation + + + +`gradient_approximation(n, x, x_value, directions, sample_set_x, sample_set_y)` + +Construct gradient approximation from given sample. + +**Parameters** + +* **n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Dimension of the problem. +* **x** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Point around which the sample set was constructed. +* **x\_value** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Objective function value at x. +* **directions** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Directions of the sample points wrt the central point x, as a 2D array. +* **sample\_set\_x** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – x-coordinates of the sample set, one point per row, as a 2D array. +* **sample\_set\_y** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Objective function values of the points in sample\_set\_x, as a 1D array. + +**Returns** + +Gradient approximation at x, as a 1D array. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### ls\_optimize + + + +`ls_optimize(n, obj_fun, initial_point, var_lb, var_ub)` + +Run the line search optimization. + +**Parameters** + +* **n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Dimension of the problem. +* **obj\_fun** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)")*\[\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Objective function. +* **initial\_point** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Initial point. +* **var\_lb** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Vector of lower bounds on the decision variables. Vector elements can be -np.inf if the corresponding variable is unbounded from below. +* **var\_ub** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Vector of upper bounds on the decision variables. Vector elements can be np.inf if the corresponding variable is unbounded from below. + +**Returns** + +Final iterate as a vector, corresponding objective function value, number of evaluations, and norm of the gradient estimate. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the number of dimensions mismatches the size of the initial point or the length of the lower or upper bound. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[numpy.ndarray](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### sample\_points + + + +`sample_points(n, x, num_points)` + +Sample `num_points` points around `x` on the `n`-sphere of specified radius. + +The radius of the sphere is `self._options['sampling_radius']`. + +**Parameters** + +* **n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Dimension of the problem. +* **x** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Point around which the sample set is constructed. +* **num\_points** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of points in the sample set. + +**Returns** + +A tuple containing the sampling points and the directions. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[numpy.ndarray](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)"), [numpy.ndarray](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")] + +### sample\_set + + + +`sample_set(n, x, var_lb, var_ub, num_points)` + +Construct sample set of given size. + +**Parameters** + +* **n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Dimension of the problem. +* **x** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Point around which the sample set is constructed. +* **var\_lb** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Vector of lower bounds on the decision variables. Vector elements can be -np.inf if the corresponding variable is unbounded from below. +* **var\_ub** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – Vector of lower bounds on the decision variables. Vector elements can be np.inf if the corresponding variable is unbounded from above. +* **num\_points** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of points in the sample set. + +**Returns** + +Matrices of (unit-norm) sample directions and sample points, one per row. Both matrices are 2D arrays of floats. + +**Raises** + +[**RuntimeError**](https://docs.python.org/3/library/exceptions.html#RuntimeError "(in Python v3.12)") – If not enough samples could be generated within the bounds. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[numpy.ndarray](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)"), [numpy.ndarray](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")] + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescent.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescent.md new file mode 100644 index 00000000000..e4cb77abde0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescent.md @@ -0,0 +1,466 @@ +--- +title: GradientDescent +description: API reference for qiskit.algorithms.optimizers.GradientDescent +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.GradientDescent +--- + +# GradientDescent + + + +`qiskit.algorithms.optimizers.GradientDescent(maxiter=100, learning_rate=0.01, tol=1e-07, callback=None, perturbation=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/gradient_descent.py "view source code") + +Bases: [`SteppableOptimizer`](qiskit.algorithms.optimizers.SteppableOptimizer "qiskit.algorithms.optimizers.steppable_optimizer.SteppableOptimizer") + +The gradient descent minimization routine. + +For a function $f$ and an initial point $\vec\theta_0$, the standard (or “vanilla”) gradient descent method is an iterative scheme to find the minimum $\vec\theta^*$ of $f$ by updating the parameters in the direction of the negative gradient of $f$ + +$$ +\vec\theta_{n+1} = \vec\theta_{n} - \eta_n \vec\nabla f(\vec\theta_{n}), +$$ + +for a small learning rate $\eta_n > 0$. + +You can either provide the analytic gradient $\vec\nabla f$ as `jac` in the [`minimize()`](#qiskit.algorithms.optimizers.GradientDescent.minimize "qiskit.algorithms.optimizers.GradientDescent.minimize") method, or, if you do not provide it, use a finite difference approximation of the gradient. To adapt the size of the perturbation in the finite difference gradients, set the `perturbation` property in the initializer. + +This optimizer supports a callback function. If provided in the initializer, the optimizer will call the callback in each iteration with the following information in this order: current number of function values, current parameters, current function value, norm of current gradient. + +**Examples** + +A minimum example that will use finite difference gradients with a default perturbation of 0.01 and a default learning rate of 0.01. + +```python +from qiskit.algorithms.optimizers import GradientDescent + +def f(x): + return (np.linalg.norm(x) - 1) ** 2 + +initial_point = np.array([1, 0.5, -0.2]) + +optimizer = GradientDescent(maxiter=100) + +result = optimizer.minimize(fun=fun, x0=initial_point) + +print(f"Found minimum {result.x} at a value" + "of {result.fun} using {result.nfev} evaluations.") +``` + +An example where the learning rate is an iterator and we supply the analytic gradient. Note how much faster this convergences (i.e. less `nfev`) compared to the previous example. + +```python +from qiskit.algorithms.optimizers import GradientDescent + +def learning_rate(): + power = 0.6 + constant_coeff = 0.1 + def powerlaw(): + n = 0 + while True: + yield constant_coeff * (n ** power) + n += 1 + + return powerlaw() + +def f(x): + return (np.linalg.norm(x) - 1) ** 2 + +def grad_f(x): + return 2 * (np.linalg.norm(x) - 1) * x / np.linalg.norm(x) + +initial_point = np.array([1, 0.5, -0.2]) + +optimizer = GradientDescent(maxiter=100, learning_rate=learning_rate) +result = optimizer.minimize(fun=fun, jac=grad_f, x0=initial_point) + +print(f"Found minimum {result.x} at a value" +"of {result.fun} using {result.nfev} evaluations.") +``` + +An other example where the evaluation of the function has a chance of failing. The user, with specific knowledge about his function can catch this errors and handle them before passing the result to the optimizer. + +> ```python +> import random +> import numpy as np +> from qiskit.algorithms.optimizers import GradientDescent +> +> def objective(x): +> if random.choice([True, False]): +> return None +> else: +> return (np.linalg.norm(x) - 1) ** 2 +> +> def grad(x): +> if random.choice([True, False]): +> return None +> else: +> return 2 * (np.linalg.norm(x) - 1) * x / np.linalg.norm(x) +> +> +> initial_point = np.random.normal(0, 1, size=(100,)) +> +> optimizer = GradientDescent(maxiter=20) +> optimizer.start(x0=initial_point, fun=objective, jac=grad) +> +> while optimizer.continue_condition(): +> ask_data = optimizer.ask() +> evaluated_gradient = None +> +> while evaluated_gradient is None: +> evaluated_gradient = grad(ask_data.x_center) +> optimizer.state.njev += 1 +> +> optmizer.state.nit += 1 +> +> tell_data = TellData(eval_jac=evaluated_gradient) +> optimizer.tell(ask_data=ask_data, tell_data=tell_data) +> +> result = optimizer.create_result() +> ``` + +Users that aren’t dealing with complicated functions and who are more familiar with step by step optimization algorithms can use the [`step()`](#qiskit.algorithms.optimizers.GradientDescent.step "qiskit.algorithms.optimizers.GradientDescent.step") method which wraps the [`ask()`](#qiskit.algorithms.optimizers.GradientDescent.ask "qiskit.algorithms.optimizers.GradientDescent.ask") and [`tell()`](#qiskit.algorithms.optimizers.GradientDescent.tell "qiskit.algorithms.optimizers.GradientDescent.tell") methods. In the same spirit the method [`minimize()`](#qiskit.algorithms.optimizers.GradientDescent.minimize "qiskit.algorithms.optimizers.GradientDescent.minimize") will optimize the function and return the result. + +To see other libraries that use this interface one can visit: [https://optuna.readthedocs.io/en/stable/tutorial/20\_recipes/009\_ask\_and\_tell.html](https://optuna.readthedocs.io/en/stable/tutorial/20_recipes/009_ask_and_tell.html) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of iterations. +* **learning\_rate** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | np.ndarray | Callable\[\[], Generator\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*, None, None]]*) – A constant, list, array or factory of generators yielding learning rates for the parameter updates. See the docstring for an example. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – If the norm of the parameter update is smaller than this threshold, the optimizer has converged. +* **perturbation** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – If no gradient is passed to [`minimize()`](#qiskit.algorithms.optimizers.GradientDescent.minimize "qiskit.algorithms.optimizers.GradientDescent.minimize") the gradient is approximated with a forward finite difference scheme with `perturbation` perturbation in both directions (defaults to 1e-2 if required). Ignored when we have an explicit function for the gradient. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `learning_rate` is an array and its length is less than `maxiter`. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### perturbation + +Returns the perturbation. + +This is the perturbation used in the finite difference gradient approximation. + + + +### setting + +Return setting + + + +### settings + + + +### state + +Return the current state of the optimizer. + + + +### tol + +Returns the tolerance of the optimizer. + +Any step with smaller stepsize than this value will stop the optimization. + +## Methods + +### ask + + + +`ask()` + +Returns an object with the data needed to evaluate the gradient. + +If this object contains a gradient function the gradient can be evaluated directly. Otherwise approximate it with a finite difference scheme. + +**Return type** + +[*AskData*](qiskit.algorithms.optimizers.AskData "qiskit.algorithms.optimizers.steppable_optimizer.AskData") + +### continue\_condition + + + +`continue_condition()` + +Condition that indicates the optimization process should come to an end. + +When the stepsize is smaller than the tolerance, the optimization process is considered finished. + +**Returns** + +`True` if the optimization process should continue, `False` otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### create\_result + + + +`create_result()` + +Creates a result of the optimization process. + +This result contains the best point, the best function value, the number of function/gradient evaluations and the number of iterations. + +**Returns** + +The result of the optimization process. + +**Return type** + +[*OptimizerResult*](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.optimizer.OptimizerResult") + +### evaluate + + + +`evaluate(ask_data)` + +Evaluates the gradient. + +It does so either by evaluating an analytic gradient or by approximating it with a finite difference scheme. It will either add `1` to the number of gradient evaluations or add `N+1` to the number of function evaluations (Where N is the dimension of the gradient). + +**Parameters** + +**ask\_data** ([*AskData*](qiskit.algorithms.optimizers.AskData "qiskit.algorithms.optimizers.steppable_optimizer.AskData")) – It contains the point where the gradient is to be evaluated and the gradient function or, in its absence, the objective function to perform a finite difference approximation. + +**Returns** + +The data containing the gradient evaluation. + +**Return type** + +[*TellData*](qiskit.algorithms.optimizers.TellData "qiskit.algorithms.optimizers.steppable_optimizer.TellData") + +### get\_support\_level + + + +`get_support_level()` + +Get the support level dictionary. + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimizes the function. + +For well behaved functions the user can call this method to minimize a function. If the user wants more control on how to evaluate the function a custom loop can be created using [`ask()`](#qiskit.algorithms.optimizers.GradientDescent.ask "qiskit.algorithms.optimizers.GradientDescent.ask") and [`tell()`](#qiskit.algorithms.optimizers.GradientDescent.tell "qiskit.algorithms.optimizers.GradientDescent.tell") and evaluating the function manually. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Function to minimize. +* **x0** (*POINT*) – Initial point. +* **jac** (*Callable\[\[POINT], POINT] | None*) – Function to compute the gradient. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds of the search space. + +**Returns** + +Object containing the result of the optimization. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### start + + + +`start(fun, x0, jac=None, bounds=None)` + +Populates the state of the optimizer with the data provided and sets all the counters to 0. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Function to minimize. +* **x0** (*POINT*) – Initial point. +* **jac** (*Callable\[\[POINT], POINT] | None*) – Function to compute the gradient. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds of the search space. + +### step + + + +`step()` + +Performs one step in the optimization process. + +This method composes [`ask()`](#qiskit.algorithms.optimizers.GradientDescent.ask "qiskit.algorithms.optimizers.GradientDescent.ask"), [`evaluate()`](#qiskit.algorithms.optimizers.GradientDescent.evaluate "qiskit.algorithms.optimizers.GradientDescent.evaluate"), and [`tell()`](#qiskit.algorithms.optimizers.GradientDescent.tell "qiskit.algorithms.optimizers.GradientDescent.tell") to make a “step” in the optimization process. + +### tell + + + +`tell(ask_data, tell_data)` + +Updates `x` by an amount proportional to the learning rate and value of the gradient at that point. + +**Parameters** + +* **ask\_data** ([*AskData*](qiskit.algorithms.optimizers.AskData "qiskit.algorithms.optimizers.steppable_optimizer.AskData")) – The data used to evaluate the function. +* **tell\_data** ([*TellData*](qiskit.algorithms.optimizers.TellData "qiskit.algorithms.optimizers.steppable_optimizer.TellData")) – The data from the function evaluation. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the gradient passed doesn’t have the right dimension. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescentState.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescentState.md new file mode 100644 index 00000000000..1a51659e5f3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.GradientDescentState.md @@ -0,0 +1,88 @@ +--- +title: GradientDescentState +description: API reference for qiskit.algorithms.optimizers.GradientDescentState +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.GradientDescentState +--- + +# GradientDescentState + + + +`qiskit.algorithms.optimizers.GradientDescentState(x, fun, jac, nfev, njev, nit, stepsize, learning_rate)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/gradient_descent.py "view source code") + +Bases: [`OptimizerState`](qiskit.algorithms.optimizers.OptimizerState "qiskit.algorithms.optimizers.steppable_optimizer.OptimizerState") + +State of [`GradientDescent`](qiskit.algorithms.optimizers.GradientDescent "qiskit.algorithms.optimizers.GradientDescent"). + +Dataclass with all the information of an optimizer plus the learning\_rate and the stepsize. + +## Attributes + + + +### stepsize + +`float | None` + +Norm of the gradient on the last step. + + + +### learning\_rate + +`LearningRate` + +Learning rate at the current step of the optimization process. + +It behaves like a generator, (use `next(learning_rate)` to get the learning rate for the next step) but it can also return the current learning rate with `learning_rate.current`. + + + +### x + +`POINT` + +Current optimization parameters. + + + +### fun + +`Callable[[POINT], float] | None` + +Function being optimized. + + + +### jac + +`Callable[[POINT], POINT] | None` + +Jacobian of the function being optimized. + + + +### nfev + +`int | None` + +Number of function evaluations so far in the optimization. + + + +### njev + +`int | None` + +Number of jacobian evaluations so far in the opimization. + + + +### nit + +`int | None` + +Number of optimization steps performed so far in the optimization. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.IMFIL.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.IMFIL.md new file mode 100644 index 00000000000..5f76666454b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.IMFIL.md @@ -0,0 +1,221 @@ +--- +title: IMFIL +description: API reference for qiskit.algorithms.optimizers.IMFIL +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.IMFIL +--- + +# IMFIL + + + +`qiskit.algorithms.optimizers.IMFIL(maxiter=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/imfil.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +IMplicit FILtering algorithm. + +Implicit filtering is a way to solve bound-constrained optimization problems for which derivatives are not available. In comparison to methods that use interpolation to reconstruct the function and its higher derivatives, implicit filtering builds upon coordinate search followed by interpolation to get an approximate gradient. + +Uses skquant.opt installed with pip install scikit-quant. For further detail, please refer to [https://github.com/scikit-quant/scikit-quant](https://github.com/scikit-quant/scikit-quant) and [https://qat4chem.lbl.gov/software](https://qat4chem.lbl.gov/software). + +**Parameters** + +**maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluations. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – scikit-quant not installed + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Returns support level dictionary. + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ISRES.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ISRES.md new file mode 100644 index 00000000000..35d441762c2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.ISRES.md @@ -0,0 +1,233 @@ +--- +title: ISRES +description: API reference for qiskit.algorithms.optimizers.ISRES +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.ISRES +--- + +# ISRES + + + +`qiskit.algorithms.optimizers.ISRES(max_evals=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/nlopts/isres.py "view source code") + +Bases: `NLoptOptimizer` + +Improved Stochastic Ranking Evolution Strategy optimizer. + +Improved Stochastic Ranking Evolution Strategy (ISRES) is an algorithm for non-linearly constrained global optimization. It has heuristics to escape local optima, even though convergence to a global optima is not guaranteed. The evolution strategy is based on a combination of a mutation rule and differential variation. The fitness ranking is simply via the objective function for problems without nonlinear constraints. When nonlinear constraints are included, the [stochastic ranking proposed by Runarsson and Yao](https://notendur.hi.is/tpr/software/sres/Tec311r.pdf) is employed. This method supports arbitrary nonlinear inequality and equality constraints, in addition to the bound constraints. + +NLopt global optimizer, derivative-free. For further detail, please refer to [http://nlopt.readthedocs.io/en/latest/NLopt\_Algorithms/#isres-improved-stochastic-ranking-evolution-strategy](http://nlopt.readthedocs.io/en/latest/NLopt_Algorithms/#isres-improved-stochastic-ranking-evolution-strategy) + +**Parameters** + +**max\_evals** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum allowed number of function evaluations. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – NLopt library not installed. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_nlopt\_optimizer + + + +`get_nlopt_optimizer()` + +Return NLopt optimizer type + +**Return type** + +*NLoptOptimizerType* + +### get\_support\_level + + + +`get_support_level()` + +return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.L_BFGS_B.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.L_BFGS_B.md new file mode 100644 index 00000000000..cc4d6827eca --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.L_BFGS_B.md @@ -0,0 +1,230 @@ +--- +title: L_BFGS_B +description: API reference for qiskit.algorithms.optimizers.L_BFGS_B +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.L_BFGS_B +--- + + + +# L\_BFGS\_B + + + +`qiskit.algorithms.optimizers.L_BFGS_B(maxfun=15000, maxiter=15000, ftol=2.220446049250313e-15, iprint=-1, eps=1e-08, options=None, max_evals_grouped=1, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/l_bfgs_b.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Limited-memory BFGS Bound optimizer. + +The target goal of Limited-memory Broyden-Fletcher-Goldfarb-Shanno Bound (L-BFGS-B) is to minimize the value of a differentiable scalar function $f$. This optimizer is a quasi-Newton method, meaning that, in contrast to Newtons’s method, it does not require $f$’s Hessian (the matrix of $f$’s second derivatives) when attempting to compute $f$’s minimum value. + +Like BFGS, L-BFGS is an iterative method for solving unconstrained, non-linear optimization problems, but approximates BFGS using a limited amount of computer memory. L-BFGS starts with an initial estimate of the optimal value, and proceeds iteratively to refine that estimate with a sequence of better estimates. + +The derivatives of $f$ are used to identify the direction of steepest descent, and also to form an estimate of the Hessian matrix (second derivative) of $f$. L-BFGS-B extends L-BFGS to handle simple, per-variable bound constraints. + +Uses `scipy.optimize.fmin_l_bfgs_b`. For further detail, please refer to [https://docs.scipy.org/doc/scipy/reference/optimize.minimize-lbfgsb.html](https://docs.scipy.org/doc/scipy/reference/optimize.minimize-lbfgsb.html) + +**Parameters** + +* **maxfun** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluations. +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of iterations. +* **ftol** (*SupportsFloat*) – The iteration stops when $(f^k - f^{k+1}) / \max\{|f^k|, |f^{k+1}|,1\} \leq \text{ftol}$. +* **iprint** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Controls the frequency of output. `iprint < 0` means no output; `iprint = 0` print only one line at the last iteration; `0 < iprint < 99` print also $f$ and $|\text{proj} g|$ every iprint iterations; `iprint = 99` print details of every iteration except n-vectors; `iprint = 100` print also the changes of active set and final $x$; `iprint > 100` print details of every iteration including $x$ and $g$. +* **eps** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – If jac is approximated, use this value for the step size. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of default gradient evaluations performed simultaneously. +* **kwargs** – additional kwargs for `scipy.optimize.minimize`. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Minimizer.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Minimizer.md new file mode 100644 index 00000000000..c3a47c88765 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Minimizer.md @@ -0,0 +1,40 @@ +--- +title: Minimizer +description: API reference for qiskit.algorithms.optimizers.Minimizer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.Minimizer +--- + +# Minimizer + + + +`qiskit.algorithms.optimizers.Minimizer(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/optimizer.py "view source code") + +Bases: [`Protocol`](https://docs.python.org/3/library/typing.html#typing.Protocol "(in Python v3.12)") + +Callable Protocol for minimizer. + +This interface is based on [SciPy’s optimize module](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html). + +> This protocol defines a callable taking the following parameters: +> +> > **fun** +> > +> > The objective function to minimize (for example the energy in the case of the VQE). +> > +> > **x0** +> > +> > The initial point for the optimization. +> > +> > **jac** +> > +> > The gradient of the objective function. +> > +> > **bounds** +> > +> > Parameters bounds for the optimization. Note that these might not be supported by all optimizers. +> +> and which returns a minimization result object (either SciPy’s or Qiskit’s). + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NELDER_MEAD.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NELDER_MEAD.md new file mode 100644 index 00000000000..8bf81017151 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NELDER_MEAD.md @@ -0,0 +1,228 @@ +--- +title: NELDER_MEAD +description: API reference for qiskit.algorithms.optimizers.NELDER_MEAD +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.NELDER_MEAD +--- + + + +# NELDER\_MEAD + + + +`qiskit.algorithms.optimizers.NELDER_MEAD(maxiter=None, maxfev=1000, disp=False, xatol=0.0001, tol=None, adaptive=False, options=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/nelder_mead.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Nelder-Mead optimizer. + +The Nelder-Mead algorithm performs unconstrained optimization; it ignores bounds or constraints. It is used to find the minimum or maximum of an objective function in a multidimensional space. It is based on the Simplex algorithm. Nelder-Mead is robust in many applications, especially when the first and second derivatives of the objective function are not known. + +However, if the numerical computation of the derivatives can be trusted to be accurate, other algorithms using the first and/or second derivatives information might be preferred to Nelder-Mead for their better performance in the general case, especially in consideration of the fact that the Nelder–Mead technique is a heuristic search method that can converge to non-stationary points. + +Uses scipy.optimize.minimize Nelder-Mead. For further detail, please refer to See [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Maximum allowed number of iterations. If both maxiter and maxfev are set, minimization will stop at the first reached. +* **maxfev** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum allowed number of function evaluations. If both maxiter and maxfev are set, minimization will stop at the first reached. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True to print convergence messages. +* **xatol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Absolute error in xopt between iterations that is acceptable for convergence. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Tolerance for termination. +* **adaptive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Adapt algorithm parameters to dimensionality of problem. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NFT.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NFT.md new file mode 100644 index 00000000000..ef9ae30b9c6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.NFT.md @@ -0,0 +1,232 @@ +--- +title: NFT +description: API reference for qiskit.algorithms.optimizers.NFT +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.NFT +--- + +# NFT + + + +`qiskit.algorithms.optimizers.NFT(maxiter=None, maxfev=1024, disp=False, reset_interval=32, options=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/nft.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Nakanishi-Fujii-Todo algorithm. + +See [https://arxiv.org/abs/1903.12166](https://arxiv.org/abs/1903.12166) + +Built out using scipy framework, for details, please refer to [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html). + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Maximum number of iterations to perform. +* **maxfev** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluations to perform. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – disp +* **reset\_interval** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The minimum estimates directly once in `reset_interval` times. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +**Notes** + +In this optimization method, the optimization function have to satisfy three conditions written in [\[1\]](#id2). + +**References** + +\[[1](#id1)] + +K. M. Nakanishi, K. Fujii, and S. Todo. 2019. Sequential minimal optimization for quantum-classical hybrid algorithms. arXiv preprint arXiv:1903.12166. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Optimizer.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Optimizer.md new file mode 100644 index 00000000000..e07f5219c90 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.Optimizer.md @@ -0,0 +1,221 @@ +--- +title: Optimizer +description: API reference for qiskit.algorithms.optimizers.Optimizer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.Optimizer +--- + +# Optimizer + + + +`qiskit.algorithms.optimizers.Optimizer`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/optimizer.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class for optimization algorithm. + +Initialize the optimization algorithm, setting the support level for \_gradient\_support\_level, \_bound\_support\_level, \_initial\_point\_support\_level, and empty options. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +The optimizer settings in a dictionary format. + +The settings can for instance be used for JSON-serialization (if all settings are serializable, which e.g. doesn’t hold per default for callables), such that the optimizer object can be reconstructed as + +```python +settings = optimizer.settings +# JSON serialize and send to another server +optimizer = OptimizerClass(**settings) +``` + +## Methods + +### get\_support\_level + + + +`abstract get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`abstract minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerResult.md new file mode 100644 index 00000000000..66a6e2e79a6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerResult.md @@ -0,0 +1,70 @@ +--- +title: OptimizerResult +description: API reference for qiskit.algorithms.optimizers.OptimizerResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.OptimizerResult +--- + +# OptimizerResult + + + +`qiskit.algorithms.optimizers.OptimizerResult`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/optimizer.py "view source code") + +Bases: `AlgorithmResult` + +The result of an optimization routine. + +## Attributes + + + +### fun + +The final value of the minimization. + + + +### jac + +The final gradient of the minimization. + + + +### nfev + +The total number of function evaluations. + + + +### nit + +The total number of iterations. + + + +### njev + +The total number of gradient evaluations. + + + +### x + +The final point of the minimization. + +## Methods + +### combine + + + +`combine(result)` + +Any property from the argument that exists in the receiver is updated. :param result: Argument result with properties to be set. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Argument is None + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerState.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerState.md new file mode 100644 index 00000000000..b36bf8e5e1f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerState.md @@ -0,0 +1,70 @@ +--- +title: OptimizerState +description: API reference for qiskit.algorithms.optimizers.OptimizerState +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.OptimizerState +--- + +# OptimizerState + + + +`qiskit.algorithms.optimizers.OptimizerState(x, fun, jac, nfev, njev, nit)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/steppable_optimizer.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Base class representing the state of the optimizer. + +This class stores the current state of the optimizer, given by the current point and (optionally) information like the function value, the gradient or the number of function evaluations. This dataclass can also store any other individual variables that change during the optimization. + +## Attributes + + + +### x + +`POINT` + +Current optimization parameters. + + + +### fun + +`Callable[[POINT], float] | None` + +Function being optimized. + + + +### jac + +`Callable[[POINT], POINT] | None` + +Jacobian of the function being optimized. + + + +### nfev + +`int | None` + +Number of function evaluations so far in the optimization. + + + +### njev + +`int | None` + +Number of jacobian evaluations so far in the opimization. + + + +### nit + +`int | None` + +Number of optimization steps performed so far in the optimization. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerSupportLevel.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerSupportLevel.md new file mode 100644 index 00000000000..ad2e1630865 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.OptimizerSupportLevel.md @@ -0,0 +1,44 @@ +--- +title: OptimizerSupportLevel +description: API reference for qiskit.algorithms.optimizers.OptimizerSupportLevel +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.OptimizerSupportLevel +--- + +# OptimizerSupportLevel + + + +`qiskit.algorithms.optimizers.OptimizerSupportLevel(value)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/optimizer.py "view source code") + +Bases: [`IntEnum`](https://docs.python.org/3/library/enum.html#enum.IntEnum "(in Python v3.12)") + +Support Level enum for features such as bounds, gradient and initial point + +## Attributes + + + +### not\_supported + +`= 0` + + + +### ignored + +`= 1` + + + +### supported + +`= 2` + + + +### required + +`= 3` + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.POWELL.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.POWELL.md new file mode 100644 index 00000000000..7a464de5968 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.POWELL.md @@ -0,0 +1,223 @@ +--- +title: POWELL +description: API reference for qiskit.algorithms.optimizers.POWELL +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.POWELL +--- + +# POWELL + + + +`qiskit.algorithms.optimizers.POWELL(maxiter=None, maxfev=1000, disp=False, xtol=0.0001, tol=None, options=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/powell.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Powell optimizer. + +The Powell algorithm performs unconstrained optimization; it ignores bounds or constraints. Powell is a *conjugate direction method*: it performs sequential one-dimensional minimization along each directional vector, which is updated at each iteration of the main minimization loop. The function being minimized need not be differentiable, and no derivatives are taken. + +Uses scipy.optimize.minimize Powell. For further detail, please refer to See [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Maximum allowed number of iterations. If both maxiter and maxfev are set, minimization will stop at the first reached. +* **maxfev** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum allowed number of function evaluations. If both maxiter and maxfev are set, minimization will stop at the first reached. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True to print convergence messages. +* **xtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative error in solution xopt acceptable for convergence. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Tolerance for termination. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.P_BFGS.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.P_BFGS.md new file mode 100644 index 00000000000..301ba90656a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.P_BFGS.md @@ -0,0 +1,225 @@ +--- +title: P_BFGS +description: API reference for qiskit.algorithms.optimizers.P_BFGS +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.P_BFGS +--- + + + +# P\_BFGS + + + +`qiskit.algorithms.optimizers.P_BFGS(maxfun=1000, ftol=2.220446049250313e-15, iprint=-1, max_processes=None, options=None, max_evals_grouped=1, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/p_bfgs.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Parallelized Limited-memory BFGS optimizer. + +P-BFGS is a parallelized version of [`L_BFGS_B`](qiskit.algorithms.optimizers.L_BFGS_B "qiskit.algorithms.optimizers.L_BFGS_B") with which it shares the same parameters. P-BFGS can be useful when the target hardware is a quantum simulator running on a classical machine. This allows the multiple processes to use simulation to potentially reach a minimum faster. The parallelization may also help the optimizer avoid getting stuck at local optima. + +Uses scipy.optimize.fmin\_l\_bfgs\_b. For further detail, please refer to [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.fmin\_l\_bfgs\_b.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.fmin_l_bfgs_b.html) + +**Parameters** + +* **maxfun** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluations. +* **ftol** (*SupportsFloat*) – The iteration stops when (f^k - f^\{k+1})/max\{|f^k|,|f^\{k+1}|,1} \<= ftol. +* **iprint** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Controls the frequency of output. iprint \< 0 means no output; iprint = 0 print only one line at the last iteration; 0 \< iprint \< 99 print also f and |proj g| every iprint iterations; iprint = 99 print details of every iteration except n-vectors; iprint = 100 print also the changes of active set and final x; iprint > 100 print details of every iteration including x and g. +* **max\_processes** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – maximum number of processes allowed, has a min. value of 1 if not None. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of default gradient evaluations performed simultaneously. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.QNSPSA.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.QNSPSA.md new file mode 100644 index 00000000000..995b4054ddf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.QNSPSA.md @@ -0,0 +1,416 @@ +--- +title: QNSPSA +description: API reference for qiskit.algorithms.optimizers.QNSPSA +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.QNSPSA +--- + +# QNSPSA + + + +`qiskit.algorithms.optimizers.QNSPSA(fidelity, maxiter=100, blocking=True, allowed_increase=None, learning_rate=None, perturbation=None, resamplings=1, perturbation_dims=None, regularization=None, hessian_delay=0, lse_solver=None, initial_hessian=None, callback=None, termination_checker=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/qnspsa.py "view source code") + +Bases: [`SPSA`](qiskit.algorithms.optimizers.SPSA "qiskit.algorithms.optimizers.spsa.SPSA") + +The Quantum Natural SPSA (QN-SPSA) optimizer. + +The QN-SPSA optimizer \[1] is a stochastic optimizer that belongs to the family of gradient descent methods. This optimizer is based on SPSA but attempts to improve the convergence by sampling the **natural gradient** instead of the vanilla, first-order gradient. It achieves this by approximating Hessian of the `fidelity` of the ansatz circuit. + +Compared to natural gradients, which require $\mathcal{O}(d^2)$ expectation value evaluations for a circuit with $d$ parameters, QN-SPSA only requires $\mathcal{O}(1)$ and can therefore significantly speed up the natural gradient calculation by sacrificing some accuracy. Compared to SPSA, QN-SPSA requires 4 additional function evaluations of the fidelity. + +The stochastic approximation of the natural gradient can be systematically improved by increasing the number of `resamplings`. This leads to a Monte Carlo-style convergence to the exact, analytic value. + + + This component has some function that is normally random. If you want to reproduce behavior then you should set the random number generator seed in the algorithm\_globals (`qiskit.utils.algorithm_globals.random_seed = seed`). + + +**Examples** + +This short example runs QN-SPSA for the ground state calculation of the `Z ^ Z` observable where the ansatz is a `PauliTwoDesign` circuit. + +```python +import numpy as np +from qiskit.algorithms.optimizers import QNSPSA +from qiskit.circuit.library import PauliTwoDesign +from qiskit.primitives import Estimator, Sampler +from qiskit.quantum_info import Pauli + +# problem setup +ansatz = PauliTwoDesign(2, reps=1, seed=2) +observable = Pauli("ZZ") +initial_point = np.random.random(ansatz.num_parameters) + +# loss function +estimator = Estimator() + +def loss(x): + result = estimator.run([ansatz], [observable], [x]).result() + return np.real(result.values[0]) + +# fidelity for estimation of the geometric tensor +sampler = Sampler() +fidelity = QNSPSA.get_fidelity(ansatz, sampler) + +# run QN-SPSA +qnspsa = QNSPSA(fidelity, maxiter=300) +result = qnspsa.optimize(ansatz.num_parameters, loss, initial_point=initial_point) +``` + +This is a legacy version solving the same problem but using Qiskit Opflow instead of the Qiskit Primitives. Note however, that this usage is deprecated. + +```python +import numpy as np +from qiskit.algorithms.optimizers import QNSPSA +from qiskit.circuit.library import PauliTwoDesign +from qiskit.opflow import Z, StateFn + +ansatz = PauliTwoDesign(2, reps=1, seed=2) +observable = Z ^ Z +initial_point = np.random.random(ansatz.num_parameters) + +def loss(x): + bound = ansatz.assign_parameters(x) + return np.real((StateFn(observable, is_measurement=True) @ StateFn(bound)).eval()) + +fidelity = QNSPSA.get_fidelity(ansatz) +qnspsa = QNSPSA(fidelity, maxiter=300) +result = qnspsa.optimize(ansatz.num_parameters, loss, initial_point=initial_point) +``` + +**References** + +\[1] J. Gacon et al, “Simultaneous Perturbation Stochastic Approximation of the Quantum Fisher Information”, [arXiv:2103.09232](https://arxiv.org/abs/2103.09232) + +**Parameters** + +* **fidelity** (*FIDELITY*) – A function to compute the fidelity of the ansatz state with itself for two different sets of parameters. +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of iterations. Note that this is not the maximal number of function evaluations. +* **blocking** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, only accepts updates that improve the loss (up to some allowed increase, see next argument). +* **allowed\_increase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – If `blocking` is `True`, this argument determines by how much the loss can increase with the proposed parameters and still be accepted. If `None`, the allowed increases is calibrated automatically to be twice the approximated standard deviation of the loss function. +* **learning\_rate** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| Callable\[\[], Iterator] | None*) – The update step is the learning rate is multiplied with the gradient. If the learning rate is a float, it remains constant over the course of the optimization. It can also be a callable returning an iterator which yields the learning rates for each optimization step. If `learning_rate` is set `perturbation` must also be provided. +* **perturbation** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| Callable\[\[], Iterator] | None*) – Specifies the magnitude of the perturbation for the finite difference approximation of the gradients. Can be either a float or a generator yielding the perturbation magnitudes per step. If `perturbation` is set `learning_rate` must also be provided. +* **resamplings** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The number of times the gradient (and Hessian) is sampled using a random direction to construct a gradient estimate. Per default the gradient is estimated using only one random direction. If an integer, all iterations use the same number of resamplings. If a dictionary, this is interpreted as `{iteration: number of resamplings per iteration}`. +* **perturbation\_dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of perturbed dimensions. Per default, all dimensions are perturbed, but a smaller, fixed number can be perturbed. If set, the perturbed dimensions are chosen uniformly at random. +* **regularization** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – To ensure the preconditioner is symmetric and positive definite, the identity times a small coefficient is added to it. This generator yields that coefficient. +* **hessian\_delay** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Start multiplying the gradient with the inverse Hessian only after a certain number of iterations. The Hessian is still evaluated and therefore this argument can be useful to first get a stable average over the last iterations before using it as preconditioner. +* **lse\_solver** (*Callable\[\[np.ndarray, np.ndarray], np.ndarray] | None*) – The method to solve for the inverse of the Hessian. Per default an exact LSE solver is used, but can e.g. be overwritten by a minimization routine. +* **initial\_hessian** (*np.ndarray | None*) – The initial guess for the Hessian. By default the identity matrix is used. +* **callback** (*CALLBACK | None*) – A callback function passed information in each iteration step. The information is, in this order: the parameters, the function value, the number of function evaluations, the stepsize, whether the step was accepted. +* **termination\_checker** (*TERMINATIONCHECKER | None*) – A callback function executed at the end of each iteration step. The arguments are, in this order: the parameters, the function value, the number of function evaluations, the stepsize, whether the step was accepted. If the callback returns True, the optimization is terminated. To prevent additional evaluations of the objective method, if the objective has not yet been evaluated, the objective is estimated by taking the mean of the objective evaluations used in the estimate of the gradient. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +The optimizer settings in a dictionary format. + +## Methods + +### calibrate + + + +`static calibrate(loss, initial_point, c=0.2, stability_constant=0, target_magnitude=None, alpha=0.602, gamma=0.101, modelspace=False, max_evals_grouped=1)` + +Calibrate SPSA parameters with a powerseries as learning rate and perturbation coeffs. + +The powerseries are: + +$$ +a_k = \frac{a}{(A + k + 1)^\alpha}, c_k = \frac{c}{(k + 1)^\gamma} +$$ + +**Parameters** + +* **loss** (*Callable\[\[np.ndarray],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The loss function. +* **initial\_point** (*np.ndarray*) – The initial guess of the iteration. +* **c** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The initial perturbation magnitude. +* **stability\_constant** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The value of A. +* **target\_magnitude** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The target magnitude for the first update step, defaults to $2\pi / 10$. +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The exponent of the learning rate powerseries. +* **gamma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The exponent of the perturbation powerseries. +* **modelspace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the target magnitude is the difference of parameter values or function values (= model space). +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of grouped evaluations supported by the loss function. Defaults to 1, i.e. no grouping. + +**Returns** + +**A tuple of powerseries generators, the first one for the** + +learning rate and the second one for the perturbation. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")(generator, generator) + +### estimate\_stddev + + + +`static estimate_stddev(loss, initial_point, avg=25, max_evals_grouped=1)` + +Estimate the standard deviation of the loss function. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### get\_fidelity + + + +`static get_fidelity(circuit, backend=None, expectation=None, *, sampler=None)` + +Get a function to compute the fidelity of `circuit` with itself. + + + Using this function with a backend and expectation converter is pending deprecation, instead pass a Qiskit Primitive sampler, such as [`Sampler`](qiskit.primitives.Sampler "qiskit.primitives.Sampler"). The sampler can be passed as keyword argument or, positionally, as second argument. + + +Let `circuit` be a parameterized quantum circuit performing the operation $U(\theta)$ given a set of parameters $\theta$. Then this method returns a function to evaluate + +$$ +F(\theta, \phi) = \big|\langle 0 | U^\dagger(\theta) U(\phi) |0\rangle \big|^2. +$$ + +The output of this function can be used as input for the `fidelity` to the [`QNSPSA`](#qiskit.algorithms.optimizers.QNSPSA "qiskit.algorithms.optimizers.QNSPSA") optimizer. + + + `qiskit.algorithms.optimizers.qnspsa.QNSPSA.get_fidelity()`’s argument `expectation` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + + + `qiskit.algorithms.optimizers.qnspsa.QNSPSA.get_fidelity()`’s argument `backend` is deprecated as of qiskit-terra 0.24.0. It will be removed no earlier than 3 months after the release date. See [https://qisk.it/algo\_migration](https://qisk.it/algo_migration) for a migration guide. + + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The circuit preparing the parameterized ansatz. +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend") *|*[*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") *| None*) – Deprecated. A backend of quantum instance to evaluate the circuits. If None, plain matrix multiplication will be used. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase") *| None*) – Deprecated. An expectation converter to specify how the expected value is computed. If a shot-based readout is used this should be set to `PauliExpectation`. +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") *| None*) – A sampler primitive to sample from a quantum state. + +**Returns** + +A handle to the function $F$. + +**Return type** + +Callable\[\[np.ndarray, np.ndarray], [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### get\_support\_level + + + +`get_support_level()` + +Get the support level dictionary. + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### optimize + + + +`optimize(num_vars, objective_function, gradient_function=None, variable_bounds=None, initial_point=None)` + +Perform optimization. + + + The method `qiskit.algorithms.optimizers.spsa.SPSA.optimize()` is deprecated as of qiskit-terra 0.21.0. It will be removed no earlier than 3 months after the release date. Instead, use `SPSA.minimize` as a replacement, which supports the same arguments but follows the interface of scipy.optimize and returns a complete result object containing additional information. + + +**Parameters** + +* **num\_vars** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of parameters to be optimized. +* **objective\_function** (*callable*) – A function that computes the objective function. +* **gradient\_function** (*callable*) – Not supported for SPSA. +* **variable\_bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[(*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*)]*) – Not supported for SPSA. +* **initial\_point** ([*numpy.ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Initial point. + +**Returns** + +**point, value, nfev** + +point: is a 1D numpy.ndarray\[float] containing the solution value: is a float with the objective function value nfev: number of objective function calls made if available or None + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SLSQP.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SLSQP.md new file mode 100644 index 00000000000..c88001815d6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SLSQP.md @@ -0,0 +1,226 @@ +--- +title: SLSQP +description: API reference for qiskit.algorithms.optimizers.SLSQP +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.SLSQP +--- + +# SLSQP + + + +`qiskit.algorithms.optimizers.SLSQP(maxiter=100, disp=False, ftol=1e-06, tol=None, eps=1.4901161193847656e-08, options=None, max_evals_grouped=1, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/slsqp.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Sequential Least SQuares Programming optimizer. + +SLSQP minimizes a function of several variables with any combination of bounds, equality and inequality constraints. The method wraps the SLSQP Optimization subroutine originally implemented by Dieter Kraft. + +SLSQP is ideal for mathematical problems for which the objective function and the constraints are twice continuously differentiable. Note that the wrapper handles infinite values in bounds by converting them into large floating values. + +Uses scipy.optimize.minimize SLSQP. For further detail, please refer to See [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of iterations. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True to print convergence messages. +* **ftol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Precision goal for the value of f in the stopping criterion. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Tolerance for termination. +* **eps** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Step size used for numerical approximation of the Jacobian. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of default gradient evaluations performed simultaneously. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SNOBFIT.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SNOBFIT.md new file mode 100644 index 00000000000..aa863c5332e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SNOBFIT.md @@ -0,0 +1,225 @@ +--- +title: SNOBFIT +description: API reference for qiskit.algorithms.optimizers.SNOBFIT +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.SNOBFIT +--- + +# SNOBFIT + + + +`qiskit.algorithms.optimizers.SNOBFIT(maxiter=1000, maxfail=10, maxmp=None, verbose=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/snobfit.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Stable Noisy Optimization by Branch and FIT algorithm. + +SnobFit is used for the optimization of derivative-free, noisy objective functions providing robust and fast solutions of problems with continuous variables varying within bound. + +Uses skquant.opt installed with pip install scikit-quant. For further detail, please refer to [https://github.com/scikit-quant/scikit-quant](https://github.com/scikit-quant/scikit-quant) and [https://qat4chem.lbl.gov/software](https://qat4chem.lbl.gov/software). + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluations. +* **maxmp** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of model points requested for the local fit. Default = 2 \* number of parameters + 6 set to this value when None. +* **maxfail** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of failures to improve the solution. Stops the algorithm after maxfail is reached. +* **verbose** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Provide verbose (debugging) output. + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – scikit-quant or SQSnobFit not installed +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If NumPy 1.24.0 or above is installed. See [https://github.com/scikit-quant/scikit-quant/issues/24](https://github.com/scikit-quant/scikit-quant/issues/24) for more details. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Returns support level dictionary. + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SPSA.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SPSA.md new file mode 100644 index 00000000000..b54d9c6e73d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SPSA.md @@ -0,0 +1,399 @@ +--- +title: SPSA +description: API reference for qiskit.algorithms.optimizers.SPSA +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.SPSA +--- + +# SPSA + + + +`qiskit.algorithms.optimizers.SPSA(maxiter=100, blocking=False, allowed_increase=None, trust_region=False, learning_rate=None, perturbation=None, last_avg=1, resamplings=1, perturbation_dims=None, second_order=False, regularization=None, hessian_delay=0, lse_solver=None, initial_hessian=None, callback=None, termination_checker=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/spsa.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Simultaneous Perturbation Stochastic Approximation (SPSA) optimizer. + +SPSA \[1] is an gradient descent method for optimizing systems with multiple unknown parameters. As an optimization method, it is appropriately suited to large-scale population models, adaptive modeling, and simulation optimization. + + + Many examples are presented at the [SPSA Web site](http://www.jhuapl.edu/SPSA). + + +The main feature of SPSA is the stochastic gradient approximation, which requires only two measurements of the objective function, regardless of the dimension of the optimization problem. + +Additionally to standard, first-order SPSA, where only gradient information is used, this implementation also allows second-order SPSA (2-SPSA) \[2]. In 2-SPSA we also estimate the Hessian of the loss with a stochastic approximation and multiply the gradient with the inverse Hessian to take local curvature into account and improve convergence. Notably this Hessian estimate requires only a constant number of function evaluations unlike an exact evaluation of the Hessian, which scales quadratically in the number of function evaluations. + + + SPSA can be used in the presence of noise, and it is therefore indicated in situations involving measurement uncertainty on a quantum computation when finding a minimum. If you are executing a variational algorithm using an OpenQASM simulator or a real device, SPSA would be the most recommended choice among the optimizers provided here. + + +The optimization process can includes a calibration phase if neither the `learning_rate` nor `perturbation` is provided, which requires additional functional evaluations. (Note that either both or none must be set.) For further details on the automatic calibration, please refer to the supplementary information section IV. of \[3]. + + + This component has some function that is normally random. If you want to reproduce behavior then you should set the random number generator seed in the algorithm\_globals (`qiskit.utils.algorithm_globals.random_seed = seed`). + + +**Examples** + +This short example runs SPSA for the ground state calculation of the `Z ^ Z` observable where the ansatz is a `PauliTwoDesign` circuit. + +```python +import numpy as np +from qiskit.algorithms.optimizers import SPSA +from qiskit.circuit.library import PauliTwoDesign +from qiskit.opflow import Z, StateFn + +ansatz = PauliTwoDesign(2, reps=1, seed=2) +observable = Z ^ Z +initial_point = np.random.random(ansatz.num_parameters) + +def loss(x): + bound = ansatz.assign_parameters(x) + return np.real((StateFn(observable, is_measurement=True) @ StateFn(bound)).eval()) + +spsa = SPSA(maxiter=300) +result = spsa.optimize(ansatz.num_parameters, loss, initial_point=initial_point) +``` + +To use the Hessian information, i.e. 2-SPSA, you can add second\_order=True to the initializer of the SPSA class, the rest of the code remains the same. + +```python +two_spsa = SPSA(maxiter=300, second_order=True) +result = two_spsa.optimize(ansatz.num_parameters, loss, initial_point=initial_point) +``` + +The termination\_checker can be used to implement a custom termination criterion. + +```python +import numpy as np +from qiskit.algorithms.optimizers import SPSA + +def objective(x): + return np.linalg.norm(x) + .04*np.random.rand(1) + +class TerminationChecker: + + def __init__(self, N : int): + self.N = N + self.values = [] + + def __call__(self, nfev, parameters, value, stepsize, accepted) -> bool: + self.values.append(value) + + if len(self.values) > self.N: + last_values = self.values[-self.N:] + pp = np.polyfit(range(self.N), last_values, 1) + slope = pp[0] / self.N + + if slope > 0: + return True + return False + +spsa = SPSA(maxiter=200, termination_checker=TerminationChecker(10)) +parameters, value, niter = spsa.optimize(2, objective, initial_point=[0.5, 0.5]) +print(f'SPSA completed after {niter} iterations') +``` + +**References** + +\[1]: J. C. Spall (1998). An Overview of the Simultaneous Perturbation Method for Efficient Optimization, Johns Hopkins APL Technical Digest, 19(4), 482–492. [Online at jhuapl.edu.](https://www.jhuapl.edu/SPSA/PDF-SPSA/Spall_An_Overview.PDF) + +\[2]: J. C. Spall (1997). Accelerated second-order stochastic optimization using only function measurements, Proceedings of the 36th IEEE Conference on Decision and Control, 1417-1424 vol.2. [Online at IEEE.org.](https://ieeexplore.ieee.org/document/657661) + +\[3]: A. Kandala et al. (2017). Hardware-efficient Variational Quantum Eigensolver for Small Molecules and Quantum Magnets. Nature 549, pages242–246(2017). [arXiv:1704.05018v2](https://arxiv.org/pdf/1704.05018v2.pdf#section*.11) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of iterations. Note that this is not the maximal number of function evaluations. +* **blocking** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, only accepts updates that improve the loss (up to some allowed increase, see next argument). +* **allowed\_increase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – If `blocking` is `True`, this argument determines by how much the loss can increase with the proposed parameters and still be accepted. If `None`, the allowed increases is calibrated automatically to be twice the approximated standard deviation of the loss function. +* **trust\_region** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, restricts the norm of the update step to be $\leq 1$. +* **learning\_rate** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| np.ndarray | Callable\[\[], Iterator] | None*) – The update step is the learning rate is multiplied with the gradient. If the learning rate is a float, it remains constant over the course of the optimization. If a NumPy array, the $i$-th element is the learning rate for the $i$-th iteration. It can also be a callable returning an iterator which yields the learning rates for each optimization step. If `learning_rate` is set `perturbation` must also be provided. +* **perturbation** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| np.ndarray | Callable\[\[], Iterator] | None*) – Specifies the magnitude of the perturbation for the finite difference approximation of the gradients. See `learning_rate` for the supported types. If `perturbation` is set `learning_rate` must also be provided. +* **last\_avg** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Return the average of the `last_avg` parameters instead of just the last parameter values. +* **resamplings** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The number of times the gradient (and Hessian) is sampled using a random direction to construct a gradient estimate. Per default the gradient is estimated using only one random direction. If an integer, all iterations use the same number of resamplings. If a dictionary, this is interpreted as `{iteration: number of resamplings per iteration}`. +* **perturbation\_dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of perturbed dimensions. Per default, all dimensions are perturbed, but a smaller, fixed number can be perturbed. If set, the perturbed dimensions are chosen uniformly at random. +* **second\_order** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, use 2-SPSA instead of SPSA. In 2-SPSA, the Hessian is estimated additionally to the gradient, and the gradient is preconditioned with the inverse of the Hessian to improve convergence. +* **regularization** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – To ensure the preconditioner is symmetric and positive definite, the identity times a small coefficient is added to it. This generator yields that coefficient. +* **hessian\_delay** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Start multiplying the gradient with the inverse Hessian only after a certain number of iterations. The Hessian is still evaluated and therefore this argument can be useful to first get a stable average over the last iterations before using it as preconditioner. +* **lse\_solver** (*Callable\[\[np.ndarray, np.ndarray], np.ndarray] | None*) – The method to solve for the inverse of the Hessian. Per default an exact LSE solver is used, but can e.g. be overwritten by a minimization routine. +* **initial\_hessian** (*np.ndarray | None*) – The initial guess for the Hessian. By default the identity matrix is used. +* **callback** (*CALLBACK | None*) – A callback function passed information in each iteration step. The information is, in this order: the number of function evaluations, the parameters, the function value, the stepsize, whether the step was accepted. +* **termination\_checker** (*TERMINATIONCHECKER | None*) – A callback function executed at the end of each iteration step. The arguments are, in this order: the parameters, the function value, the number of function evaluations, the stepsize, whether the step was accepted. If the callback returns True, the optimization is terminated. To prevent additional evaluations of the objective method, if the objective has not yet been evaluated, the objective is estimated by taking the mean of the objective evaluations used in the estimate of the gradient. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `learning_rate` or `perturbation` is an array with less elements than the number of iterations. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### calibrate + + + +`static calibrate(loss, initial_point, c=0.2, stability_constant=0, target_magnitude=None, alpha=0.602, gamma=0.101, modelspace=False, max_evals_grouped=1)` + +Calibrate SPSA parameters with a powerseries as learning rate and perturbation coeffs. + +The powerseries are: + +$$ +a_k = \frac{a}{(A + k + 1)^\alpha}, c_k = \frac{c}{(k + 1)^\gamma} +$$ + +**Parameters** + +* **loss** (*Callable\[\[np.ndarray],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The loss function. +* **initial\_point** (*np.ndarray*) – The initial guess of the iteration. +* **c** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The initial perturbation magnitude. +* **stability\_constant** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The value of A. +* **target\_magnitude** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The target magnitude for the first update step, defaults to $2\pi / 10$. +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The exponent of the learning rate powerseries. +* **gamma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The exponent of the perturbation powerseries. +* **modelspace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the target magnitude is the difference of parameter values or function values (= model space). +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of grouped evaluations supported by the loss function. Defaults to 1, i.e. no grouping. + +**Returns** + +**A tuple of powerseries generators, the first one for the** + +learning rate and the second one for the perturbation. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")(generator, generator) + +### estimate\_stddev + + + +`static estimate_stddev(loss, initial_point, avg=25, max_evals_grouped=1)` + +Estimate the standard deviation of the loss function. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### get\_support\_level + + + +`get_support_level()` + +Get the support level dictionary. + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### optimize + + + +`optimize(num_vars, objective_function, gradient_function=None, variable_bounds=None, initial_point=None)` + +Perform optimization. + + + The method `qiskit.algorithms.optimizers.spsa.SPSA.optimize()` is deprecated as of qiskit-terra 0.21.0. It will be removed no earlier than 3 months after the release date. Instead, use `SPSA.minimize` as a replacement, which supports the same arguments but follows the interface of scipy.optimize and returns a complete result object containing additional information. + + +**Parameters** + +* **num\_vars** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of parameters to be optimized. +* **objective\_function** (*callable*) – A function that computes the objective function. +* **gradient\_function** (*callable*) – Not supported for SPSA. +* **variable\_bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[(*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*)]*) – Not supported for SPSA. +* **initial\_point** ([*numpy.ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Initial point. + +**Returns** + +**point, value, nfev** + +point: is a 1D numpy.ndarray\[float] containing the solution value: is a float with the objective function value nfev: number of objective function calls made if available or None + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SciPyOptimizer.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SciPyOptimizer.md new file mode 100644 index 00000000000..ee2ab0af1a6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SciPyOptimizer.md @@ -0,0 +1,218 @@ +--- +title: SciPyOptimizer +description: API reference for qiskit.algorithms.optimizers.SciPyOptimizer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.SciPyOptimizer +--- + +# SciPyOptimizer + + + +`qiskit.algorithms.optimizers.SciPyOptimizer(method, options=None, max_evals_grouped=1, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/scipy_optimizer.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +A general Qiskit Optimizer wrapping scipy.optimize.minimize. + +For further detail, please refer to [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html) + +**Parameters** + +* **method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| Callable*) – Type of solver. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any] | None*) – A dictionary of solver options. +* **kwargs** – additional kwargs for scipy.optimize.minimize. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of default gradient evaluations performed simultaneously. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SteppableOptimizer.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SteppableOptimizer.md new file mode 100644 index 00000000000..e121b675a63 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.SteppableOptimizer.md @@ -0,0 +1,396 @@ +--- +title: SteppableOptimizer +description: API reference for qiskit.algorithms.optimizers.SteppableOptimizer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.SteppableOptimizer +--- + +# SteppableOptimizer + + + +`qiskit.algorithms.optimizers.SteppableOptimizer(maxiter=100)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/steppable_optimizer.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Base class for a steppable optimizer. + +This family of optimizers uses the [ask and tell interface](https://optuna.readthedocs.io/en/stable/tutorial/20_recipes/009_ask_and_tell.html). When using this interface the user has to call [`ask()`](#qiskit.algorithms.optimizers.SteppableOptimizer.ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask") to get information about how to evaluate the function (we are asking the optimizer about how to do the evaluation). This information is typically the next points at which the function is evaluated, but depending on the optimizer it can also determine whether to evaluate the function or its gradient. Once the function has been evaluated, the user calls the method `tell()` to tell the optimizer what the result of the function evaluation(s) is. The optimizer then updates its state accordingly and the user can decide whether to stop the optimization process or to repeat a step. + +This interface is more customizable, and allows the user to have full control over the evaluation of the function. + +**Examples** + +An example where the evaluation of the function has a chance of failing. The user, with specific knowledge about his function can catch this errors and handle them before passing the result to the optimizer. + +```python +import random +import numpy as np +from qiskit.algorithms.optimizers import GradientDescent + +def objective(x): + if random.choice([True, False]): + return None + else: + return (np.linalg.norm(x) - 1) ** 2 + +def grad(x): + if random.choice([True, False]): + return None + else: + return 2 * (np.linalg.norm(x) - 1) * x / np.linalg.norm(x) + + +initial_point = np.random.normal(0, 1, size=(100,)) + +optimizer = GradientDescent(maxiter=20) +optimizer.start(x0=initial_point, fun=objective, jac=grad) + +while optimizer.continue_condition(): + ask_data = optimizer.ask() + evaluated_gradient = None + + while evaluated_gradient is None: + evaluated_gradient = grad(ask_data.x_center) + optimizer.state.njev += 1 + + optmizer.state.nit += 1 + + cf = TellData(eval_jac=evaluated_gradient) + optimizer.tell(ask_data=ask_data, tell_data=tell_data) + +result = optimizer.create_result() +``` + +Users that aren’t dealing with complicated functions and who are more familiar with step by step optimization algorithms can use the [`step()`](#qiskit.algorithms.optimizers.SteppableOptimizer.step "qiskit.algorithms.optimizers.SteppableOptimizer.step") method which wraps the [`ask()`](#qiskit.algorithms.optimizers.SteppableOptimizer.ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask") and [`tell()`](#qiskit.algorithms.optimizers.SteppableOptimizer.tell "qiskit.algorithms.optimizers.SteppableOptimizer.tell") methods. In the same spirit the method [`minimize()`](#qiskit.algorithms.optimizers.SteppableOptimizer.minimize "qiskit.algorithms.optimizers.SteppableOptimizer.minimize") will optimize the function and return the result. + +To see other libraries that use this interface one can visit: [https://optuna.readthedocs.io/en/stable/tutorial/20\_recipes/009\_ask\_and\_tell.html](https://optuna.readthedocs.io/en/stable/tutorial/20_recipes/009_ask_and_tell.html) + +**Parameters** + +**maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of steps in the optimization process before ending the loop. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +The optimizer settings in a dictionary format. + +The settings can for instance be used for JSON-serialization (if all settings are serializable, which e.g. doesn’t hold per default for callables), such that the optimizer object can be reconstructed as + +```python +settings = optimizer.settings +# JSON serialize and send to another server +optimizer = OptimizerClass(**settings) +``` + + + +### state + +Return the current state of the optimizer. + +## Methods + +### ask + + + +`ask()` + +Ask the optimizer for a set of points to evaluate. + +This method asks the optimizer which are the next points to evaluate. These points can, e.g., correspond to function values and/or its derivative. It may also correspond to variables that let the user infer which points to evaluate. It is the first method inside of a [`step()`](#qiskit.algorithms.optimizers.SteppableOptimizer.step "qiskit.algorithms.optimizers.SteppableOptimizer.step") in the optimization process. + +**Returns** + +An object containing the data needed to make the function evaluation to advance the optimization process. + +**Return type** + +[*AskData*](qiskit.algorithms.optimizers.AskData "qiskit.algorithms.optimizers.steppable_optimizer.AskData") + +### continue\_condition + + + +`continue_condition()` + +Condition that indicates the optimization process should continue. + +**Returns** + +`True` if the optimization process should continue, `False` otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### create\_result + + + +`abstract create_result()` + +Returns the result of the optimization. + +All the information needed to create such a result should be stored in the optimizer state and will typically contain the best point found, the function value and gradient at that point, the number of function and gradient evaluation and the number of iterations in the optimization. + +**Returns** + +The result of the optimization process. + +**Return type** + +[*OptimizerResult*](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.optimizer.OptimizerResult") + +### evaluate + + + +`abstract evaluate(ask_data)` + +Evaluates the function according to the instructions contained in `ask_data`. + +If the user decides to use [`step()`](#qiskit.algorithms.optimizers.SteppableOptimizer.step "qiskit.algorithms.optimizers.SteppableOptimizer.step") instead of [`ask()`](#qiskit.algorithms.optimizers.SteppableOptimizer.ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask") and [`tell()`](#qiskit.algorithms.optimizers.SteppableOptimizer.tell "qiskit.algorithms.optimizers.SteppableOptimizer.tell") this function will contain the logic on how to evaluate the function. + +**Parameters** + +**ask\_data** ([*AskData*](qiskit.algorithms.optimizers.AskData "qiskit.algorithms.optimizers.steppable_optimizer.AskData")) – Contains the information on how to do the evaluation. + +**Returns** + +Data of all relevant information about the function evaluation. + +**Return type** + +[*TellData*](qiskit.algorithms.optimizers.TellData "qiskit.algorithms.optimizers.steppable_optimizer.TellData") + +### get\_support\_level + + + +`abstract get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimizes the function. + +For well behaved functions the user can call this method to minimize a function. If the user wants more control on how to evaluate the function a custom loop can be created using [`ask()`](#qiskit.algorithms.optimizers.SteppableOptimizer.ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask") and [`tell()`](#qiskit.algorithms.optimizers.SteppableOptimizer.tell "qiskit.algorithms.optimizers.SteppableOptimizer.tell") and evaluating the function manually. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Function to minimize. +* **x0** (*POINT*) – Initial point. +* **jac** (*Callable\[\[POINT], POINT] | None*) – Function to compute the gradient. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds of the search space. + +**Returns** + +Object containing the result of the optimization. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### start + + + +`abstract start(fun, x0, jac=None, bounds=None)` + +Populates the state of the optimizer with the data provided and sets all the counters to 0. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Function to minimize. +* **x0** (*POINT*) – Initial point. +* **jac** (*Callable\[\[POINT], POINT] | None*) – Function to compute the gradient. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds of the search space. + +### step + + + +`step()` + +Performs one step in the optimization process. + +This method composes [`ask()`](#qiskit.algorithms.optimizers.SteppableOptimizer.ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask"), [`evaluate()`](#qiskit.algorithms.optimizers.SteppableOptimizer.evaluate "qiskit.algorithms.optimizers.SteppableOptimizer.evaluate"), and [`tell()`](#qiskit.algorithms.optimizers.SteppableOptimizer.tell "qiskit.algorithms.optimizers.SteppableOptimizer.tell") to make a “step” in the optimization process. + +### tell + + + +`tell(ask_data, tell_data)` + +Updates the optimization state using the results of the function evaluation. + +A canonical optimization example using [`ask()`](#qiskit.algorithms.optimizers.SteppableOptimizer.ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask") and [`tell()`](#qiskit.algorithms.optimizers.SteppableOptimizer.tell "qiskit.algorithms.optimizers.SteppableOptimizer.tell") can be seen in [`step()`](#qiskit.algorithms.optimizers.SteppableOptimizer.step "qiskit.algorithms.optimizers.SteppableOptimizer.step"). + +**Parameters** + +* **ask\_data** ([*AskData*](qiskit.algorithms.optimizers.AskData "qiskit.algorithms.optimizers.steppable_optimizer.AskData")) – Contains the information on how the evaluation was done. +* **tell\_data** ([*TellData*](qiskit.algorithms.optimizers.TellData "qiskit.algorithms.optimizers.steppable_optimizer.TellData")) – Contains all relevant information about the evaluation of the objective function. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TNC.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TNC.md new file mode 100644 index 00000000000..4d9718336d5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TNC.md @@ -0,0 +1,227 @@ +--- +title: TNC +description: API reference for qiskit.algorithms.optimizers.TNC +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.TNC +--- + +# TNC + + + +`qiskit.algorithms.optimizers.TNC(maxiter=100, disp=False, accuracy=0, ftol=-1, xtol=-1, gtol=-1, tol=None, eps=1e-08, options=None, max_evals_grouped=1, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/tnc.py "view source code") + +Bases: [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.scipy_optimizer.SciPyOptimizer") + +Truncated Newton (TNC) optimizer. + +TNC uses a truncated Newton algorithm to minimize a function with variables subject to bounds. This algorithm uses gradient information; it is also called Newton Conjugate-Gradient. It differs from the [`CG`](qiskit.algorithms.optimizers.CG "qiskit.algorithms.optimizers.CG") method as it wraps a C implementation and allows each variable to be given upper and lower bounds. + +Uses scipy.optimize.minimize TNC For further detail, please refer to See [https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html](https://docs.scipy.org/doc/scipy/reference/generated/scipy.optimize.minimize.html) + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of function evaluation. +* **disp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True to print convergence messages. +* **accuracy** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative precision for finite difference calculations. If \<= machine\_precision, set to sqrt(machine\_precision). Defaults to 0. +* **ftol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Precision goal for the value of f in the stopping criterion. If ftol \< 0.0, ftol is set to 0.0 defaults to -1. +* **xtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Precision goal for the value of x in the stopping criterion (after applying x scaling factors). If xtol \< 0.0, xtol is set to sqrt(machine\_precision). Defaults to -1. +* **gtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Precision goal for the value of the projected gradient in the stopping criterion (after applying x scaling factors). If gtol \< 0.0, gtol is set to 1e-2 \* sqrt(accuracy). Setting it to 0.0 is not recommended. Defaults to -1. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Tolerance for termination. +* **eps** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Step size used for numerical approximation of the Jacobian. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – A dictionary of solver options. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Max number of default gradient evaluations performed simultaneously. +* **kwargs** – additional kwargs for scipy.optimize.minimize. + +## Attributes + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### setting + +Return setting + + + +### settings + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Return support level dictionary + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TellData.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TellData.md new file mode 100644 index 00000000000..18be7da16fd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.TellData.md @@ -0,0 +1,41 @@ +--- +title: TellData +description: API reference for qiskit.algorithms.optimizers.TellData +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.TellData +--- + +# TellData + + + +`qiskit.algorithms.optimizers.TellData(eval_fun=None, eval_jac=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/steppable_optimizer.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class for argument type of [`tell()`](qiskit.algorithms.optimizers.SteppableOptimizer#tell "qiskit.algorithms.optimizers.SteppableOptimizer.tell"). + +**Parameters** + +* **eval\_fun** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Image of the function at `x_fun`. +* **eval\_jac** (*POINT |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[POINT] | None*) – Image of the gradient-jacobian at `x_jac`. + +## Attributes + + + +### eval\_fun + +`float | list[float] | None` + +`= None` + + + +### eval\_jac + +`POINT | list[POINT] | None` + +`= None` + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.UMDA.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.UMDA.md new file mode 100644 index 00000000000..73efcb24dea --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.UMDA.md @@ -0,0 +1,307 @@ +--- +title: UMDA +description: API reference for qiskit.algorithms.optimizers.UMDA +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.UMDA +--- + +# UMDA + + + +`qiskit.algorithms.optimizers.UMDA(maxiter=100, size_gen=20, alpha=0.5, callback=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/umda.py "view source code") + +Bases: [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.optimizer.Optimizer") + +Continuous Univariate Marginal Distribution Algorithm (UMDA). + +UMDA \[1] is a specific type of Estimation of Distribution Algorithm (EDA) where new individuals are sampled from univariate normal distributions and are updated in each iteration of the algorithm by the best individuals found in the previous iteration. + + + This original implementation of the UDMA optimizer for Qiskit was inspired by my (Vicente P. Soloviev) work on the EDAspy Python package \[2]. + + +EDAs are stochastic search algorithms and belong to the family of the evolutionary algorithms. The main difference is that EDAs have a probabilistic model which is updated in each iteration from the best individuals of previous generations (elite selection). Depending on the complexity of the probabilistic model, EDAs can be classified in different ways. In this case, UMDA is a univariate EDA as the embedded probabilistic model is univariate. + +UMDA has been compared to some of the already implemented algorithms in Qiskit library to optimize the parameters of variational algorithms such as QAOA or VQE and competitive results have been obtained \[1]. UMDA seems to provide very good solutions for those circuits in which the number of layers is not big. + +The optimization process can be personalized depending on the parameters chosen in the initialization. The main parameter is the population size. The bigger it is, the final result will be better. However, this increases the complexity of the algorithm and the runtime will be much heavier. In the work \[1] different experiments have been performed where population size has been set to 20 - 30. + + + The UMDA implementation has more parameters but these have default values for the initialization for better understanding of the user. For example, `lpha` parameter has been set to 0.5 and is the percentage of the population which is selected in each iteration to update the probabilistic model. + + +**Example** + +This short example runs UMDA to optimize the parameters of a variational algorithm. Here we will use the same operator as used in the algorithms introduction, which was originally computed by Qiskit Nature for an H2 molecule. The minimum energy of the H2 Hamiltonian can be found quite easily so we are able to set maxiters to a small value. + +```python +from qiskit.opflow import X, Z, I +from qiskit_aer import Aer +from qiskit.algorithms.optimizers import UMDA +from qiskit.algorithms import QAOA +from qiskit.utils import QuantumInstance + + +H2_op = (-1.052373245772859 * I ^ I) + (0.39793742484318045 * I ^ Z) + (-0.39793742484318045 * Z ^ I) + (-0.01128010425623538 * Z ^ Z) + (0.18093119978423156 * X ^ X) + +p = 2 # Toy example: 2 layers with 2 parameters in each layer: 4 variables + +opt = UMDA(maxiter=100, size_gen=20) + +backend = Aer.get_backend('statevector_simulator') +vqe = QAOA(opt, + quantum_instance=QuantumInstance(backend=backend), + reps=p) + +result = vqe.compute_minimum_eigenvalue(operator=H2_op) +``` + +If it is desired to modify the percentage of individuals considered to update the probabilistic model, then this code can be used. Here for example we set the 60% instead of the 50% predefined. + +```python +opt = UMDA(maxiter=100, size_gen=20, alpha = 0.6) + +backend = Aer.get_backend('statevector_simulator') +vqe = QAOA(opt, + quantum_instance=QuantumInstance(backend=backend), + reps=p) + +result = vqe.compute_minimum_eigenvalue(operator=qubit_op) +``` + +**References** + +\[1]: Vicente P. Soloviev, Pedro Larrañaga and Concha Bielza (2022, July). Quantum Parametric Circuit Optimization with Estimation of Distribution Algorithms. In 2022 The Genetic and Evolutionary Computation Conference (GECCO). DOI: [https://doi.org/10.1145/3520304.3533963](https://doi.org/10.1145/3520304.3533963) + +\[2]: Vicente P. Soloviev. Python package EDAspy. [https://github.com/VicentePerezSoloviev/EDAspy](https://github.com/VicentePerezSoloviev/EDAspy). + +**Parameters** + +* **maxiter** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Maximum number of iterations. +* **size\_gen** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Population size of each generation. +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Percentage (0, 1] of the population to be selected as elite selection. +* **callback** (*Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, np.array,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*], None] | None*) – A callback function passed information in each iteration step. The information is, in this order: the number of function evaluations, the parameters, the best function value in this iteration. + +## Attributes + + + +### ELITE\_FACTOR + +`= 0.4` + + + +### STD\_BOUND + +`= 0.3` + + + +### alpha + +Returns the alpha parameter value (percentage of population selected to update probabilistic model) + + + +### bounds\_support\_level + +Returns bounds support level + + + +### gradient\_support\_level + +Returns gradient support level + + + +### initial\_point\_support\_level + +Returns initial point support level + + + +### is\_bounds\_ignored + +Returns is bounds ignored + + + +### is\_bounds\_required + +Returns is bounds required + + + +### is\_bounds\_supported + +Returns is bounds supported + + + +### is\_gradient\_ignored + +Returns is gradient ignored + + + +### is\_gradient\_required + +Returns is gradient required + + + +### is\_gradient\_supported + +Returns is gradient supported + + + +### is\_initial\_point\_ignored + +Returns is initial point ignored + + + +### is\_initial\_point\_required + +Returns is initial point required + + + +### is\_initial\_point\_supported + +Returns is initial point supported + + + +### maxiter + +Returns the maximum number of iterations + + + +### setting + +Return setting + + + +### settings + + + +### size\_gen + +Returns the size of the generations (number of individuals per generation) + +## Methods + +### get\_support\_level + + + +`get_support_level()` + +Get the support level dictionary. + +### gradient\_num\_diff + + + +`static gradient_num_diff(x_center, f, epsilon, max_evals_grouped=None)` + +We compute the gradient with the numeric differentiation in the parallel way, around the point x\_center. + +**Parameters** + +* **x\_center** (*ndarray*) – point around which we compute the gradient +* **f** (*func*) – the function of which the gradient is to be computed. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the epsilon used in the numeric differentiation. +* **max\_evals\_grouped** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max evals grouped, defaults to 1 (i.e. no batching). + +**Returns** + +the gradient computed + +**Return type** + +grad + +### minimize + + + +`minimize(fun, x0, jac=None, bounds=None)` + +Minimize the scalar function. + +**Parameters** + +* **fun** (*Callable\[\[POINT],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The scalar function to minimize. +* **x0** (*POINT*) – The initial point for the minimization. +* **jac** (*Callable\[\[POINT], POINT] | None*) – The gradient of the scalar function `fun`. +* **bounds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Bounds for the variables of `fun`. This argument might be ignored if the optimizer does not support bounds. + +**Returns** + +The result of the optimization, containing e.g. the result as attribute `x`. + +**Return type** + +[OptimizerResult](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") + +### print\_options + + + +`print_options()` + +Print algorithm-specific options. + +### set\_max\_evals\_grouped + + + +`set_max_evals_grouped(limit)` + +Set max evals grouped + +### set\_options + + + +`set_options(**kwargs)` + +Sets or updates values in the options dictionary. + +The options dictionary may be used internally by a given optimizer to pass additional optional values for the underlying optimizer/optimization function used. The options dictionary may be initially populated with a set of key/values when the given optimizer is constructed. + +**Parameters** + +**kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – options, given as name=value. + +### wrap\_function + + + +`static wrap_function(function, args)` + +Wrap the function to implicitly inject the args at the call of the function. + +**Parameters** + +* **function** (*func*) – the target function +* **args** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the args to be injected + +**Returns** + +wrapper + +**Return type** + +function\_wrapper + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.md new file mode 100644 index 00000000000..a0d332af743 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.md @@ -0,0 +1,97 @@ +--- +title: optimizers +description: API reference for qiskit.algorithms.optimizers +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.optimizers +--- + + + + + +# qiskit.algorithms.optimizers + + + +## Optimizers + + + +`qiskit.algorithms.optimizers` + +It contains a variety of classical optimizers for use by quantum variational algorithms, such as [`VQE`](qiskit.algorithms.VQE "qiskit.algorithms.VQE"). Logically, these optimizers can be divided into two categories: + +**[Local Optimizers](#local-optimizers)** + +Given an optimization problem, a **local optimizer** is a function that attempts to find an optimal value within the neighboring set of a candidate solution. + +**[Global Optimizers](#global-optimizers)** + +Given an optimization problem, a **global optimizer** is a function that attempts to find an optimal value among all possible solutions. + +## Optimizer Base Class + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------- | +| [`OptimizerResult`](qiskit.algorithms.optimizers.OptimizerResult "qiskit.algorithms.optimizers.OptimizerResult") | The result of an optimization routine. | +| [`OptimizerSupportLevel`](qiskit.algorithms.optimizers.OptimizerSupportLevel "qiskit.algorithms.optimizers.OptimizerSupportLevel") | Support Level enum for features such as bounds, gradient and initial point | +| [`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") | Base class for optimization algorithm. | +| [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") | Callable Protocol for minimizer. | + +## Steppable Optimizer Base Class + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------- | +| [`optimizer_utils`](qiskit.algorithms.optimizers.optimizer_utils#module-qiskit.algorithms.optimizers.optimizer_utils "qiskit.algorithms.optimizers.optimizer_utils") | Utils for optimizers | + +| | | +| ------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`SteppableOptimizer`](qiskit.algorithms.optimizers.SteppableOptimizer "qiskit.algorithms.optimizers.SteppableOptimizer") | Base class for a steppable optimizer. | +| [`AskData`](qiskit.algorithms.optimizers.AskData "qiskit.algorithms.optimizers.AskData") | Base class for return type of [`ask()`](qiskit.algorithms.optimizers.SteppableOptimizer#ask "qiskit.algorithms.optimizers.SteppableOptimizer.ask"). | +| [`TellData`](qiskit.algorithms.optimizers.TellData "qiskit.algorithms.optimizers.TellData") | Base class for argument type of [`tell()`](qiskit.algorithms.optimizers.SteppableOptimizer#tell "qiskit.algorithms.optimizers.SteppableOptimizer.tell"). | +| [`OptimizerState`](qiskit.algorithms.optimizers.OptimizerState "qiskit.algorithms.optimizers.OptimizerState") | Base class representing the state of the optimizer. | + +## Local Optimizers + +| | | +| ------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------- | +| [`ADAM`](qiskit.algorithms.optimizers.ADAM "qiskit.algorithms.optimizers.ADAM") | Adam and AMSGRAD optimizers. | +| [`AQGD`](qiskit.algorithms.optimizers.AQGD "qiskit.algorithms.optimizers.AQGD") | Analytic Quantum Gradient Descent (AQGD) with Epochs optimizer. | +| [`CG`](qiskit.algorithms.optimizers.CG "qiskit.algorithms.optimizers.CG") | Conjugate Gradient optimizer. | +| [`COBYLA`](qiskit.algorithms.optimizers.COBYLA "qiskit.algorithms.optimizers.COBYLA") | Constrained Optimization By Linear Approximation optimizer. | +| [`L_BFGS_B`](qiskit.algorithms.optimizers.L_BFGS_B "qiskit.algorithms.optimizers.L_BFGS_B") | Limited-memory BFGS Bound optimizer. | +| [`GSLS`](qiskit.algorithms.optimizers.GSLS "qiskit.algorithms.optimizers.GSLS") | Gaussian-smoothed Line Search. | +| [`GradientDescent`](qiskit.algorithms.optimizers.GradientDescent "qiskit.algorithms.optimizers.GradientDescent") | The gradient descent minimization routine. | +| [`GradientDescentState`](qiskit.algorithms.optimizers.GradientDescentState "qiskit.algorithms.optimizers.GradientDescentState") | State of [`GradientDescent`](qiskit.algorithms.optimizers.GradientDescent "qiskit.algorithms.optimizers.GradientDescent"). | +| [`NELDER_MEAD`](qiskit.algorithms.optimizers.NELDER_MEAD "qiskit.algorithms.optimizers.NELDER_MEAD") | Nelder-Mead optimizer. | +| [`NFT`](qiskit.algorithms.optimizers.NFT "qiskit.algorithms.optimizers.NFT") | Nakanishi-Fujii-Todo algorithm. | +| [`P_BFGS`](qiskit.algorithms.optimizers.P_BFGS "qiskit.algorithms.optimizers.P_BFGS") | Parallelized Limited-memory BFGS optimizer. | +| [`POWELL`](qiskit.algorithms.optimizers.POWELL "qiskit.algorithms.optimizers.POWELL") | Powell optimizer. | +| [`SLSQP`](qiskit.algorithms.optimizers.SLSQP "qiskit.algorithms.optimizers.SLSQP") | Sequential Least SQuares Programming optimizer. | +| [`SPSA`](qiskit.algorithms.optimizers.SPSA "qiskit.algorithms.optimizers.SPSA") | Simultaneous Perturbation Stochastic Approximation (SPSA) optimizer. | +| [`QNSPSA`](qiskit.algorithms.optimizers.QNSPSA "qiskit.algorithms.optimizers.QNSPSA") | The Quantum Natural SPSA (QN-SPSA) optimizer. | +| [`TNC`](qiskit.algorithms.optimizers.TNC "qiskit.algorithms.optimizers.TNC") | Truncated Newton (TNC) optimizer. | +| [`SciPyOptimizer`](qiskit.algorithms.optimizers.SciPyOptimizer "qiskit.algorithms.optimizers.SciPyOptimizer") | A general Qiskit Optimizer wrapping scipy.optimize.minimize. | +| [`UMDA`](qiskit.algorithms.optimizers.UMDA "qiskit.algorithms.optimizers.UMDA") | Continuous Univariate Marginal Distribution Algorithm (UMDA). | + +Qiskit also provides the following optimizers, which are built-out using the optimizers from the scikit-quant package. The scikit-quant package is not installed by default but must be explicitly installed, if desired, by the user - the optimizers therein are provided under various licenses so it has been made an optional install for the end user to choose whether to do so or not. To install the scikit-quant dependent package you can use pip install scikit-quant. + +| | | +| ---------------------------------------------------------------------------------------- | -------------------------------------------------------- | +| [`BOBYQA`](qiskit.algorithms.optimizers.BOBYQA "qiskit.algorithms.optimizers.BOBYQA") | Bound Optimization BY Quadratic Approximation algorithm. | +| [`IMFIL`](qiskit.algorithms.optimizers.IMFIL "qiskit.algorithms.optimizers.IMFIL") | IMplicit FILtering algorithm. | +| [`SNOBFIT`](qiskit.algorithms.optimizers.SNOBFIT "qiskit.algorithms.optimizers.SNOBFIT") | Stable Noisy Optimization by Branch and FIT algorithm. | + +## Global Optimizers + +The global optimizers here all use NLopt for their core function and can only be used if their dependent NLopt package is manually installed. + +| | | +| ---------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------- | +| [`CRS`](qiskit.algorithms.optimizers.CRS "qiskit.algorithms.optimizers.CRS") | Controlled Random Search (CRS) with local mutation optimizer. | +| [`DIRECT_L`](qiskit.algorithms.optimizers.DIRECT_L "qiskit.algorithms.optimizers.DIRECT_L") | DIviding RECTangles Locally-biased optimizer. | +| [`DIRECT_L_RAND`](qiskit.algorithms.optimizers.DIRECT_L_RAND "qiskit.algorithms.optimizers.DIRECT_L_RAND") | DIviding RECTangles Locally-biased Randomized optimizer. | +| [`ESCH`](qiskit.algorithms.optimizers.ESCH "qiskit.algorithms.optimizers.ESCH") | ESCH evolutionary optimizer. | +| [`ISRES`](qiskit.algorithms.optimizers.ISRES "qiskit.algorithms.optimizers.ISRES") | Improved Stochastic Ranking Evolution Strategy optimizer. | + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.LearningRate.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.LearningRate.md new file mode 100644 index 00000000000..911e13ad1b8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.LearningRate.md @@ -0,0 +1,56 @@ +--- +title: LearningRate +description: API reference for qiskit.algorithms.optimizers.optimizer_utils.LearningRate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.optimizers.optimizer_utils.LearningRate +--- + +# LearningRate + + + +`qiskit.algorithms.optimizers.optimizer_utils.LearningRate(learning_rate)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/optimizers/optimizer_utils/learning_rate.py "view source code") + +Bases: [`Generator`](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)") + +Represents a Learning Rate. Will be an attribute of [`GradientDescentState`](qiskit.algorithms.optimizers.GradientDescentState "qiskit.algorithms.optimizers.GradientDescentState"). Note that [`GradientDescent`](qiskit.algorithms.optimizers.GradientDescent "qiskit.algorithms.optimizers.GradientDescent") also has a learning rate. That learning rate can be a float, a list, an array, a function returning a generator and will be used to create a generator to be used during the optimization process. This class wraps `Generator` so that we can also access the last yielded value. + +**Parameters** + +**learning\_rate** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | np.ndarray | Callable\[\[], Generator\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*, None, None]]*) – Used to create a generator to iterate on. + +## Attributes + + + +### current + +Returns the current value of the learning rate. + +## Methods + +### close + + + +`close()` + +Raise GeneratorExit inside generator. + +### send + + + +`send(value)` + +Send a value into the generator. Return next yielded value or raise StopIteration. + +### throw + + + +`throw(typ, val=None, tb=None)` + +Raise an exception in the generator. Return next yielded value or raise StopIteration. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.md b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.md new file mode 100644 index 00000000000..3a8255470b0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.optimizers.optimizer_utils.md @@ -0,0 +1,28 @@ +--- +title: optimizer_utils +description: API reference for qiskit.algorithms.optimizers.optimizer_utils +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.optimizers.optimizer_utils +--- + + + + + +# qiskit.algorithms.optimizers.optimizer\_utils + +Utils for optimizers + + + +## Optimizer Utils + + + +`qiskit.algorithms.optimizers.optimizer_utils` + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------- | --------------------------- | +| [`LearningRate`](qiskit.algorithms.optimizers.optimizer_utils.LearningRate "qiskit.algorithms.optimizers.optimizer_utils.LearningRate") | Represents a Learning Rate. | + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.BaseStateFidelity.md b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.BaseStateFidelity.md new file mode 100644 index 00000000000..a3722fff2cd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.BaseStateFidelity.md @@ -0,0 +1,71 @@ +--- +title: BaseStateFidelity +description: API reference for qiskit.algorithms.state_fidelities.BaseStateFidelity +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.state_fidelities.BaseStateFidelity +--- + +# BaseStateFidelity + + + +`qiskit.algorithms.state_fidelities.BaseStateFidelity`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/state_fidelities/base_state_fidelity.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +An interface to calculate state fidelities (state overlaps) for pairs of (parametrized) quantum circuits. The calculation depends on the particular fidelity method implementation, but can be always defined as the state overlap: + +$$ +|\langle\psi(x)|\phi(y)\rangle|^2 +$$ + +where $x$ and $y$ are optional parametrizations of the states $\psi$ and $\phi$ prepared by the circuits `circuit_1` and `circuit_2`, respectively. + +## Methods + +### create\_fidelity\_circuit + + + +`abstract create_fidelity_circuit(circuit_1, circuit_2)` + +Implementation-dependent method to create a fidelity circuit from 2 circuit inputs. + +**Parameters** + +* **circuit\_1** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – (Parametrized) quantum circuit. +* **circuit\_2** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – (Parametrized) quantum circuit. + +**Returns** + +The fidelity quantum circuit corresponding to `circuit_1` and `circuit_2`. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### run + + + +`run(circuits_1, circuits_2, values_1=None, values_2=None, **options)` + +Runs asynchronously the state overlap (fidelity) calculation between two (parametrized) circuits (first and second) for a specific set of parameter values (first and second). This calculation depends on the particular fidelity method implementation. + +**Parameters** + +* **circuits\_1** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – (Parametrized) quantum circuits preparing $|\psi\rangle$. +* **circuits\_2** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – (Parametrized) quantum circuits preparing $|\phi\rangle$. +* **values\_1** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Numerical parameters to be bound to the first set of circuits. +* **values\_2** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Numerical parameters to be bound to the second set of circuits. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > fidelity’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +**Returns** + +Primitive job for the fidelity calculation. The job’s result is an instance of `StateFidelityResult`. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.ComputeUncompute.md b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.ComputeUncompute.md new file mode 100644 index 00000000000..7c8c07acfcf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.ComputeUncompute.md @@ -0,0 +1,117 @@ +--- +title: ComputeUncompute +description: API reference for qiskit.algorithms.state_fidelities.ComputeUncompute +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.state_fidelities.ComputeUncompute +--- + +# ComputeUncompute + + + +`qiskit.algorithms.state_fidelities.ComputeUncompute(sampler, options=None, local=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/state_fidelities/compute_uncompute.py "view source code") + +Bases: [`BaseStateFidelity`](qiskit.algorithms.state_fidelities.BaseStateFidelity "qiskit.algorithms.state_fidelities.base_state_fidelity.BaseStateFidelity") + +This class leverages the sampler primitive to calculate the state fidelity of two quantum circuits following the compute-uncompute method (see \[1] for further reference). The fidelity can be defined as the state overlap. + +$$ +|\langle\psi(x)|\phi(y)\rangle|^2 +$$ + +where $x$ and $y$ are optional parametrizations of the states $\psi$ and $\phi$ prepared by the circuits `circuit_1` and `circuit_2`, respectively. + +**Reference:** \[1] Havlíček, V., Córcoles, A. D., Temme, K., Harrow, A. W., Kandala, A., Chow, J. M., & Gambetta, J. M. (2019). Supervised learning with quantum-enhanced feature spaces. Nature, 567(7747), 209-212. [arXiv:1804.11326v2 \[quant-ph\]](https://arxiv.org/pdf/1804.11326.pdf) + +**Parameters** + +* **sampler** ([*BaseSampler*](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler")) – Sampler primitive instance. + +* **options** ([*Options*](qiskit.providers.Options "qiskit.providers.Options") *| None*) – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > fidelity’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +* **local** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – + + If set to `True`, the fidelity is averaged over single-qubit projectors + + $$ + \hat{O} = \frac{1}{N}\sum_{i=1}^N|0_i\rangle\langle 0_i|, + $$ + + instead of the global projector $|0\rangle\langle 0|^{\otimes n}$. This coincides with the standard (global) fidelity in the limit of the fidelity approaching 1. Might be used to increase the variance to improve trainability in algorithms such as `PVQD`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the sampler is not an instance of `BaseSampler`. + +## Attributes + + + +### options + +Return the union of estimator options setting and fidelity default options, where, if the same field is set in both, the fidelity’s default options override the primitive’s default setting. + +**Returns** + +The fidelity default + estimator options. + +## Methods + +### create\_fidelity\_circuit + + + +`create_fidelity_circuit(circuit_1, circuit_2)` + +Combines `circuit_1` and `circuit_2` to create the fidelity circuit following the compute-uncompute method. + +**Parameters** + +* **circuit\_1** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – (Parametrized) quantum circuit. +* **circuit\_2** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – (Parametrized) quantum circuit. + +**Returns** + +The fidelity quantum circuit corresponding to circuit\_1 and circuit\_2. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### run + + + +`run(circuits_1, circuits_2, values_1=None, values_2=None, **options)` + +Runs asynchronously the state overlap (fidelity) calculation between two (parametrized) circuits (first and second) for a specific set of parameter values (first and second). This calculation depends on the particular fidelity method implementation. + +**Parameters** + +* **circuits\_1** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – (Parametrized) quantum circuits preparing $|\psi\rangle$. +* **circuits\_2** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – (Parametrized) quantum circuits preparing $|\phi\rangle$. +* **values\_1** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Numerical parameters to be bound to the first set of circuits. +* **values\_2** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Numerical parameters to be bound to the second set of circuits. +* **options** – Primitive backend runtime options used for circuit execution. The order of priority is: options in `run` method > fidelity’s default options > primitive’s default setting. Higher priority setting overrides lower priority setting. + +**Returns** + +Primitive job for the fidelity calculation. The job’s result is an instance of `StateFidelityResult`. + +**Return type** + +[AlgorithmJob](qiskit.algorithms.AlgorithmJob "qiskit.algorithms.AlgorithmJob") + +### update\_default\_options + + + +`update_default_options(**options)` + +Update the fidelity’s default options setting. + +**Parameters** + +**\*\*options** – The fields to update the default options. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.StateFidelityResult.md b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.StateFidelityResult.md new file mode 100644 index 00000000000..3450e82de80 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.StateFidelityResult.md @@ -0,0 +1,52 @@ +--- +title: StateFidelityResult +description: API reference for qiskit.algorithms.state_fidelities.StateFidelityResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.state_fidelities.StateFidelityResult +--- + +# StateFidelityResult + + + +`qiskit.algorithms.state_fidelities.StateFidelityResult(fidelities, raw_fidelities, metadata, options)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/state_fidelities/state_fidelity_result.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +This class stores the result of StateFidelity computations. + +## Attributes + + + +### fidelities + +`Sequence[float]` + +List of truncated fidelity values for each pair of input circuits, ensured to be in \[0,1]. + + + +### raw\_fidelities + +`Sequence[float]` + +List of raw fidelity values for each pair of input circuits, which might not be in \[0,1] depending on the error mitigation method used. + + + +### metadata + +`Sequence[Mapping[str, Any]]` + +Additional information about the fidelity calculation. + + + +### options + +`Options` + +Primitive runtime options for the execution of the fidelity job. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.md b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.md new file mode 100644 index 00000000000..5479b77e6f4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.state_fidelities.md @@ -0,0 +1,35 @@ +--- +title: state_fidelities +description: API reference for qiskit.algorithms.state_fidelities +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.state_fidelities +--- + + + + + +# qiskit.algorithms.state\_fidelities + + + +## State Fidelity Interfaces + + + +`qiskit.algorithms.state_fidelities` + +### State Fidelities + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`BaseStateFidelity`](qiskit.algorithms.state_fidelities.BaseStateFidelity "qiskit.algorithms.state_fidelities.BaseStateFidelity")() | An interface to calculate state fidelities (state overlaps) for pairs of (parametrized) quantum circuits. | +| [`ComputeUncompute`](qiskit.algorithms.state_fidelities.ComputeUncompute "qiskit.algorithms.state_fidelities.ComputeUncompute")(sampler\[, options, local]) | This class leverages the sampler primitive to calculate the state fidelity of two quantum circuits following the compute-uncompute method (see \[1] for further reference). | + +### Results + +> | | | +> | --------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------- | +> | [`StateFidelityResult`](qiskit.algorithms.state_fidelities.StateFidelityResult "qiskit.algorithms.state_fidelities.StateFidelityResult")(fidelities, ...) | This class stores the result of StateFidelity computations. | + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE.md new file mode 100644 index 00000000000..a30f0e6fe83 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE.md @@ -0,0 +1,109 @@ +--- +title: TrotterQRTE +description: API reference for qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE +--- + +# TrotterQRTE + + + +`qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE(product_formula=None, estimator=None, num_timesteps=1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/trotterization/trotter_qrte.py "view source code") + +Bases: [`RealTimeEvolver`](qiskit.algorithms.RealTimeEvolver "qiskit.algorithms.time_evolvers.real_time_evolver.RealTimeEvolver") + +Quantum Real Time Evolution using Trotterization. Type of Trotterization is defined by a `ProductFormula` provided. + +**Examples** + +```python +from qiskit.opflow import PauliSumOp +from qiskit.quantum_info import Pauli, SparsePauliOp +from qiskit import QuantumCircuit +from qiskit.algorithms import TimeEvolutionProblem +from qiskit.algorithms.time_evolvers import TrotterQRTE +from qiskit.primitives import Estimator + +operator = PauliSumOp(SparsePauliOp([Pauli("X"), Pauli("Z")])) +initial_state = QuantumCircuit(1) +time = 1 +evolution_problem = TimeEvolutionProblem(operator, time, initial_state) +# LieTrotter with 1 rep +estimator = Estimator() +trotter_qrte = TrotterQRTE(estimator=estimator) +evolved_state = trotter_qrte.evolve(evolution_problem).evolved_state +``` + +**Parameters** + +* **product\_formula** ([*ProductFormula*](qiskit.synthesis.ProductFormula "qiskit.synthesis.ProductFormula") *| None*) – A Lie-Trotter-Suzuki product formula. If `None` provided, the Lie-Trotter first order product formula with a single repetition is used. `reps` should be 1 to obtain a number of time-steps equal to `num_timesteps` and an evaluation of [`TimeEvolutionProblem.aux_operators`](qiskit.algorithms.TimeEvolutionProblem#aux_operators "qiskit.algorithms.TimeEvolutionProblem.aux_operators") at every time-step. If `reps` is larger than 1, the true number of time-steps will be `num_timesteps * reps`. +* **num\_timesteps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of time-steps the full evolution time is devided into (repetitions of `product_formula`) +* **estimator** ([*BaseEstimator*](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") *| None*) – An estimator primitive used for calculating expectation values of `TimeEvolutionProblem.aux_operators`. + +## Attributes + + + +### estimator + +Returns an estimator. + + + +### num\_timesteps + +Returns the number of timesteps. + + + +### product\_formula + +Returns a product formula. + +## Methods + +### evolve + + + +`evolve(evolution_problem)` + +Evolves a quantum state for a given time using the Trotterization method based on a product formula provided. The result is provided in the form of a quantum circuit. If auxiliary operators are included in the `evolution_problem`, they are evaluated on the `init_state` and on the evolved state at every step (`num_timesteps` times) using an estimator primitive provided. + +**Parameters** + +**evolution\_problem** ([*TimeEvolutionProblem*](qiskit.algorithms.TimeEvolutionProblem "qiskit.algorithms.time_evolvers.time_evolution_problem.TimeEvolutionProblem")) – Instance defining evolution problem. For the included Hamiltonian, `Pauli` or `PauliSumOp` are supported by TrotterQRTE. + +**Returns** + +Evolution result that includes an evolved state as a quantum circuit and, optionally, auxiliary operators evaluated for a resulting state on an estimator primitive. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `t_param` is not set to `None` in the `TimeEvolutionProblem` (feature not currently supported). +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `aux_operators` provided in the time evolution problem but no estimator provided to the algorithm. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the `initial_state` is not provided in the `TimeEvolutionProblem`. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If an unsupported Hamiltonian type is provided. + +**Return type** + +[*TimeEvolutionResult*](qiskit.algorithms.TimeEvolutionResult "qiskit.algorithms.time_evolvers.time_evolution_result.TimeEvolutionResult") + +### supports\_aux\_operators + + + +`classmethod supports_aux_operators()` + +Whether computing the expectation value of auxiliary operators is supported. + +**Returns** + +`True` if `aux_operators` expectations in the `TimeEvolutionProblem` can be evaluated, `False` otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.md new file mode 100644 index 00000000000..6546eaa58bc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.trotterization.md @@ -0,0 +1,22 @@ +--- +title: trotterization +description: API reference for qiskit.algorithms.time_evolvers.trotterization +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.time_evolvers.trotterization +--- + + + + + +# qiskit.algorithms.time\_evolvers.trotterization + +This package contains Trotterization-based Quantum Real Time Evolution algorithm. It is compliant with the new Quantum Time Evolution Framework and makes use of `qiskit.synthesis.evolution.ProductFormula` and [`PauliEvolutionGate`](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate") implementations. + +## Trotterization-based Quantum Real Time Evolution + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------- | +| [`TrotterQRTE`](qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE "qiskit.algorithms.time_evolvers.trotterization.TrotterQRTE") | Quantum Real Time Evolution using Trotterization. | + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver.md new file mode 100644 index 00000000000..9d255fb58e7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver.md @@ -0,0 +1,42 @@ +--- +title: ForwardEulerSolver +description: API reference for qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver +--- + +# ForwardEulerSolver + + + +`qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver(function, t0, y0, t_bound, vectorized=False, support_complex=False, num_t_steps=15)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/solvers/ode/forward_euler_solver.py "view source code") + +Bases: `OdeSolver` + +Forward Euler ODE solver. + +Forward Euler ODE solver that implements an interface from SciPy. + +**Parameters** + +* **function** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)")) – Right-hand side of the system. The calling signature is `fun(t, y)`. Here `t` is a scalar, and there are two options for the ndarray `y`: It can either have shape (n,); then `fun` must return array\_like with shape (n,). Alternatively it can have shape (n, k); then `fun` must return an array\_like with shape (n, k), i.e., each column corresponds to a single column in `y`. The choice between the two options is determined by vectorized argument (see below). The vectorized implementation allows a faster approximation of the Jacobian by finite differences (required for this solver). +* **t0** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Initial time. +* **y0** ([*Sequence*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Sequence "(in Python v3.12)")) – Initial state. +* **t\_bound** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Boundary time - the integration won’t continue beyond it. It also determines the direction of the integration. +* **vectorized** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether `fun` is implemented in a vectorized fashion. Default is False. +* **support\_complex** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether integration in a complex domain should be supported. Generally determined by a derived solver class capabilities. Default is False. +* **num\_t\_steps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of time steps for the forward Euler method. + +## Attributes + + + +### TOO\_SMALL\_STEP + +`= 'Required step size is less than spacing between numbers.'` + + + +### step\_size + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple.md new file mode 100644 index 00000000000..f3460cb2fab --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple.md @@ -0,0 +1,56 @@ +--- +title: ImaginaryMcLachlanPrinciple +description: API reference for qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple +--- + +# ImaginaryMcLachlanPrinciple + + + +`qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple(qgt=None, gradient=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/variational_principles/imaginary_mc_lachlan_principle.py "view source code") + +Bases: [`ImaginaryVariationalPrinciple`](qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple "qiskit.algorithms.time_evolvers.variational.variational_principles.imaginary_variational_principle.ImaginaryVariationalPrinciple") + +Class for an Imaginary McLachlan’s Variational Principle. It aims to minimize the distance between both sides of the Wick-rotated Schrödinger equation with a quantum state given as a parametrized trial state. The principle leads to a system of linear equations handled by a linear solver. The imaginary variant means that we consider imaginary time dynamics. + +**Parameters** + +* **qgt** ([*BaseQGT*](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT") *| None*) – Instance of a the GQT class used to compute the QFI. If `None` provided, `LinCombQGT` is used. +* **gradient** ([*BaseEstimatorGradient*](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient") *| None*) – Instance of a class used to compute the state gradient. If `None` provided, `LinCombEstimatorGradient` is used. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If the gradient instance does not contain an estimator. + +## Methods + +### evolution\_gradient + + + +`evolution_gradient(hamiltonian, ansatz, param_values, gradient_params=None)` + +Calculates an evolution gradient according to the rules of this variational principle. + +**Parameters** + +* **hamiltonian** (*BaseOperator*) – Operator used for Variational Quantum Time Evolution. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Quantum state in the form of a parametrized quantum circuit. +* **param\_values** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Values of parameters to be bound. +* **gradient\_params** (*Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None*) – List of parameters with respect to which gradients should be computed. If `None` given, gradients w\.r.t. all parameters will be computed. + +**Returns** + +An evolution gradient. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If a gradient job fails. + +**Return type** + +np.ndarray + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple.md new file mode 100644 index 00000000000..a7c8270ca0a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple.md @@ -0,0 +1,23 @@ +--- +title: ImaginaryVariationalPrinciple +description: API reference for qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple +--- + +# ImaginaryVariationalPrinciple + + + +`qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple(qgt, gradient)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/variational_principles/imaginary_variational_principle.py "view source code") + +Bases: [`VariationalPrinciple`](qiskit.algorithms.time_evolvers.variational.VariationalPrinciple "qiskit.algorithms.time_evolvers.variational.variational_principles.variational_principle.VariationalPrinciple"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Abstract class for an Imaginary Variational Principle. The imaginary variant means that we consider imaginary time dynamics. + +**Parameters** + +* **qgt** ([*BaseQGT*](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT")) – Instance of a class used to compute the GQT. +* **gradient** ([*BaseEstimatorGradient*](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient")) – Instance of a class used to compute the state gradient. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple.md new file mode 100644 index 00000000000..0de5c9639eb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple.md @@ -0,0 +1,56 @@ +--- +title: RealMcLachlanPrinciple +description: API reference for qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple +--- + +# RealMcLachlanPrinciple + + + +`qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple(qgt=None, gradient=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/variational_principles/real_mc_lachlan_principle.py "view source code") + +Bases: [`RealVariationalPrinciple`](qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple "qiskit.algorithms.time_evolvers.variational.variational_principles.real_variational_principle.RealVariationalPrinciple") + +Class for a Real McLachlan’s Variational Principle. It aims to minimize the distance between both sides of the Schrödinger equation with a quantum state given as a parametrized trial state. The principle leads to a system of linear equations handled by a linear solver. The real variant means that we consider real time dynamics. + +**Parameters** + +* **qgt** ([*BaseQGT*](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT") *| None*) – Instance of a the GQT class used to compute the QFI. If `None` provided, `LinCombQGT` is used. +* **gradient** ([*BaseEstimatorGradient*](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient") *| None*) – Instance of a class used to compute the state gradient. If `None` provided, `LinCombEstimatorGradient` is used. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If the gradient instance does not contain an estimator. + +## Methods + +### evolution\_gradient + + + +`evolution_gradient(hamiltonian, ansatz, param_values, gradient_params=None)` + +Calculates an evolution gradient according to the rules of this variational principle. + +**Parameters** + +* **hamiltonian** (*BaseOperator*) – Operator used for Variational Quantum Time Evolution. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Quantum state in the form of a parametrized quantum circuit. +* **param\_values** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Values of parameters to be bound. +* **gradient\_params** (*Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None*) – List of parameters with respect to which gradients should be computed. If `None` given, gradients w\.r.t. all parameters will be computed. + +**Returns** + +An evolution gradient. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If a gradient job fails. + +**Return type** + +np.ndarray + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple.md new file mode 100644 index 00000000000..28e79ff4d8b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple.md @@ -0,0 +1,23 @@ +--- +title: RealVariationalPrinciple +description: API reference for qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple +--- + +# RealVariationalPrinciple + + + +`qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple(qgt, gradient)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/variational_principles/real_variational_principle.py "view source code") + +Bases: [`VariationalPrinciple`](qiskit.algorithms.time_evolvers.variational.VariationalPrinciple "qiskit.algorithms.time_evolvers.variational.variational_principles.variational_principle.VariationalPrinciple"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Class for a Real Variational Principle. The real variant means that we consider real time dynamics. + +**Parameters** + +* **qgt** ([*BaseQGT*](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT")) – Instance of a class used to compute the GQT. +* **gradient** ([*BaseEstimatorGradient*](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient")) – Instance of a class used to compute the state gradient. + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.VariationalPrinciple.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.VariationalPrinciple.md new file mode 100644 index 00000000000..72959fe10f1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.VariationalPrinciple.md @@ -0,0 +1,93 @@ +--- +title: VariationalPrinciple +description: API reference for qiskit.algorithms.time_evolvers.variational.VariationalPrinciple +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.algorithms.time_evolvers.variational.VariationalPrinciple +--- + +# VariationalPrinciple + + + +`qiskit.algorithms.time_evolvers.variational.VariationalPrinciple(qgt, gradient)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/algorithms/time_evolvers/variational/variational_principles/variational_principle.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +A Variational Principle class. It determines the time propagation of parameters in a quantum state provided as a parametrized quantum circuit (ansatz). + + + +### qgt + +Instance of a class used to compute the GQT. + +**Type** + +[BaseQGT](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT") + + + +### gradient + +Instance of a class used to compute the state gradient. + +**Type** + +[BaseEstimatorGradient](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient") + +**Parameters** + +* **qgt** ([*BaseQGT*](qiskit.algorithms.gradients.BaseQGT "qiskit.algorithms.gradients.BaseQGT")) – Instance of a class used to compute the GQT. +* **gradient** ([*BaseEstimatorGradient*](qiskit.algorithms.gradients.BaseEstimatorGradient "qiskit.algorithms.gradients.BaseEstimatorGradient")) – Instance of a class used to compute the state gradient. + +## Methods + +### evolution\_gradient + + + +`abstract evolution_gradient(hamiltonian, ansatz, param_values, gradient_params=None)` + +Calculates an evolution gradient according to the rules of this variational principle. + +**Parameters** + +* **hamiltonian** (*BaseOperator*) – Operator used for Variational Quantum Time Evolution. +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Quantum state in the form of a parametrized quantum circuit. +* **param\_values** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Values of parameters to be bound. +* **gradient\_params** (*Sequence\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*] | None*) – List of parameters with respect to which gradients should be computed. If `None` given, gradients w\.r.t. all parameters will be computed. + +**Returns** + +An evolution gradient. + +**Return type** + +np.ndarray + +### metric\_tensor + + + +`metric_tensor(ansatz, param_values)` + +Calculates a metric tensor according to the rules of this variational principle. + +**Parameters** + +* **ansatz** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – Quantum state in the form of a parametrized quantum circuit. +* **param\_values** ([*Sequence*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Sequence "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Values of parameters to be bound. + +**Returns** + +Metric tensor. + +**Raises** + +[**AlgorithmError**](algorithms#qiskit.algorithms.AlgorithmError "qiskit.algorithms.AlgorithmError") – If a QFI job fails. + +**Return type** + +[*Sequence*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Sequence "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + diff --git a/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.md b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.md new file mode 100644 index 00000000000..4a573fcddb1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.algorithms.time_evolvers.variational.md @@ -0,0 +1,78 @@ +--- +title: variational +description: API reference for qiskit.algorithms.time_evolvers.variational +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.algorithms.time_evolvers.variational +--- + + + + + +# qiskit.algorithms.time\_evolvers.variational + + + +## Variational Quantum Time Evolutions + + + +`qiskit.algorithms.time_evolvers.variational` + +Algorithms for performing Variational Quantum Time Evolution of quantum states, which can be tailored to near-term devices. `VarQTE` base class exposes an interface, compliant with the Quantum Time Evolution Framework in Qiskit Terra, that is implemented by [`VarQRTE`](qiskit.algorithms.VarQRTE "qiskit.algorithms.VarQRTE") and [`VarQITE`](qiskit.algorithms.VarQITE "qiskit.algorithms.VarQITE") classes for real and imaginary time evolution respectively. The variational approach is taken according to a variational principle chosen by a user. + +**Example** + +```python +import numpy as np + +from qiskit.algorithms import TimeEvolutionProblem, VarQITE +from qiskit.algorithms.time_evolvers.variational import ImaginaryMcLachlanPrinciple +from qiskit.circuit.library import EfficientSU2 +from qiskit.quantum_info import SparsePauliOp + +observable = SparsePauliOp.from_list( + [ + ("II", 0.2252), + ("ZZ", 0.5716), + ("IZ", 0.3435), + ("ZI", -0.4347), + ("YY", 0.091), + ("XX", 0.091), + ] +) + +ansatz = EfficientSU2(observable.num_qubits, reps=1) +init_param_values = np.zeros(len(ansatz.parameters)) +for i in range(len(ansatz.parameters)): + init_param_values[i] = np.pi / 2 +var_principle = ImaginaryMcLachlanPrinciple() +time = 1 +evolution_problem = TimeEvolutionProblem(observable, time) +var_qite = VarQITE(ansatz, var_principle, init_param_values) +evolution_result = var_qite.evolve(evolution_problem) +``` + +### Variational Principles + +With variational principles we can project time evolution of a quantum state onto the parameters of a model, in our case a variational quantum circuit. + +They can be divided into two categories: Variational Quantum \_Real\_ Time Evolution, which evolves the variational ansatz under the standard Schroediger equation and Variational Quantum \_Imaginary\_ Time Evolution, which evolves under the normalized Wick-rotated Schroedinger equation. + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------- | +| [`VariationalPrinciple`](qiskit.algorithms.time_evolvers.variational.VariationalPrinciple "qiskit.algorithms.time_evolvers.variational.VariationalPrinciple")(qgt, gradient) | A Variational Principle class. | +| [`RealVariationalPrinciple`](qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple "qiskit.algorithms.time_evolvers.variational.RealVariationalPrinciple")(qgt, gradient) | Class for a Real Variational Principle. | +| [`ImaginaryVariationalPrinciple`](qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple "qiskit.algorithms.time_evolvers.variational.ImaginaryVariationalPrinciple")(qgt, gradient) | Abstract class for an Imaginary Variational Principle. | +| [`RealMcLachlanPrinciple`](qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple "qiskit.algorithms.time_evolvers.variational.RealMcLachlanPrinciple")(\[qgt, gradient]) | Class for a Real McLachlan's Variational Principle. | +| [`ImaginaryMcLachlanPrinciple`](qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple "qiskit.algorithms.time_evolvers.variational.ImaginaryMcLachlanPrinciple")(\[qgt, gradient]) | Class for an Imaginary McLachlan's Variational Principle. | + +### ODE solvers + +ODE solvers that implement the SciPy ODE Solver interface. The Forward Euler Solver is a preferred choice in the presence of noise. One might also use solvers provided by SciPy directly, e.g. RK45. + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------- | +| [`ForwardEulerSolver`](qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver "qiskit.algorithms.time_evolvers.variational.ForwardEulerSolver")(function, t0, y0, t\_bound) | Forward Euler ODE solver. | + diff --git a/docs/api/qiskit/0.46/qiskit.assembler.RunConfig.md b/docs/api/qiskit/0.46/qiskit.assembler.RunConfig.md new file mode 100644 index 00000000000..798708002db --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.assembler.RunConfig.md @@ -0,0 +1,106 @@ +--- +title: RunConfig +description: API reference for qiskit.assembler.RunConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.assembler.RunConfig +--- + +# RunConfig + + + +`qiskit.assembler.RunConfig(shots=None, seed_simulator=None, memory=None, parameter_binds=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/assembler/run_config.py "view source code") + +Bases: [`SimpleNamespace`](https://docs.python.org/3/library/types.html#types.SimpleNamespace "(in Python v3.12)") + +Class for Run Configuration. + + + +### shots + +the number of shots + +**Type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### seed\_simulator + +the seed to use in the simulator + +**Type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### memory + +whether to request memory from backend (per-shot readouts) + +**Type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + +### parameter\_binds + +List of parameter bindings + +**Type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")] + +Initialize a RunConfig object + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of shots +* **seed\_simulator** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the seed to use in the simulator +* **memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to request memory from backend (per-shot readouts) +* **parameter\_binds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*]*) – List of parameter bindings +* **\*\*kwargs** – optional fields + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new RunConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the RunConfig to create. It will be in the same format as output by [`to_dict()`](#qiskit.assembler.RunConfig.to_dict "qiskit.assembler.RunConfig.to_dict"). + +**Returns** + +The RunConfig from the input dictionary. + +**Return type** + +[RunConfig](#qiskit.assembler.RunConfig "qiskit.assembler.RunConfig") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the RunConfig + +**Returns** + +The dictionary form of the RunConfig. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.AncillaQubit.md b/docs/api/qiskit/0.46/qiskit.circuit.AncillaQubit.md new file mode 100644 index 00000000000..7ccf1c31b79 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.AncillaQubit.md @@ -0,0 +1,55 @@ +--- +title: AncillaQubit +description: API reference for qiskit.circuit.AncillaQubit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.AncillaQubit +--- + +# AncillaQubit + + + +`qiskit.circuit.AncillaQubit(register=None, index=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/quantumregister.py "view source code") + +Bases: [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") + +A qubit used as ancillary qubit. + +Creates a qubit. + +**Parameters** + +* **register** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")) – Optional. A quantum register containing the bit. +* **index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The index of the bit in its containing register. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the provided register is not a valid [`QuantumRegister`](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") + +## Attributes + + + +### index + +Get the index of an old-style bit in the register that owns it. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.index` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + + + +### register + +Get the register of an old-style bit. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.register` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.AncillaRegister.md b/docs/api/qiskit/0.46/qiskit.circuit.AncillaRegister.md new file mode 100644 index 00000000000..0fa6e148b76 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.AncillaRegister.md @@ -0,0 +1,90 @@ +--- +title: AncillaRegister +description: API reference for qiskit.circuit.AncillaRegister +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.AncillaRegister +--- + +# AncillaRegister + + + +`qiskit.circuit.AncillaRegister(size=None, name=None, bits=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/quantumregister.py "view source code") + +Bases: [`QuantumRegister`](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") + +Implement an ancilla register. + +Create a new generic register. + +Either the `size` or the `bits` argument must be provided. If `size` is not None, the register will be pre-populated with bits of the correct type. + +**Parameters** + +* **size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The number of bits to include in the register. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional. The name of the register. If not provided, a unique name will be auto-generated from the register type. +* **bits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – Optional. A list of Bit() instances to be used to populate the register. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both the `size` and `bits` arguments are provided, or if neither are. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `size` is not valid. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `name` is not a valid name according to the OpenQASM spec. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained duplicated bits. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained bits of an incorrect type. + +## Attributes + + + +### instances\_counter + +`= count(0)` + + + +### name + +Get the register name. + + + +### name\_format + +`= re.compile('[a-z][a-zA-Z0-9_]*')` + + + +### prefix + +`= 'a'` + + + +### size + +Get the register size. + +## Methods + +### index + + + +`index(bit)` + +Find the index of the provided bit within this register. + +### qasm + + + +`qasm()` + +Return OPENQASM string for this register. + + + The method `qiskit.circuit.quantumregister.QuantumRegister.qasm()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.AnnotatedOperation.md b/docs/api/qiskit/0.46/qiskit.circuit.AnnotatedOperation.md new file mode 100644 index 00000000000..018298ea0b8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.AnnotatedOperation.md @@ -0,0 +1,84 @@ +--- +title: AnnotatedOperation +description: API reference for qiskit.circuit.AnnotatedOperation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.AnnotatedOperation +--- + +# AnnotatedOperation + + + +`qiskit.circuit.AnnotatedOperation(base_op, modifiers)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/annotated_operation.py "view source code") + +Bases: [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") + +Annotated operation. + +Create a new AnnotatedOperation. + +An “annotated operation” allows to add a list of modifiers to the “base” operation. For now, the only supported modifiers are of types [`InverseModifier`](qiskit.circuit.InverseModifier "qiskit.circuit.InverseModifier"), [`ControlModifier`](qiskit.circuit.ControlModifier "qiskit.circuit.ControlModifier") and [`PowerModifier`](qiskit.circuit.PowerModifier "qiskit.circuit.PowerModifier"). + +An annotated operation can be viewed as an extension of [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") (which also allows adding control to the base operation). However, an important difference is that the circuit definition of an annotated operation is not constructed when the operation is declared, and instead happens during transpilation, specifically during the [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transpiler pass. + +An annotated operation can be also viewed as a “higher-level” or “more abstract” object that can be added to a quantum circuit. This enables writing transpiler optimization passes that make use of this higher-level representation, for instance removing a gate that is immediately followed by its inverse. + +**Parameters** + +* **base\_op** ([*Operation*](qiskit.circuit.Operation "qiskit.circuit.operation.Operation")) – base operation being modified +* **modifiers** (*Modifier |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[Modifier]*) – ordered list of modifiers. Supported modifiers include `InverseModifier`, `ControlModifier` and `PowerModifier`. + +Examples: + +```python +op1 = AnnotatedOperation(SGate(), [InverseModifier(), ControlModifier(2)]) + +op2_inner = AnnotatedGate(SGate(), InverseModifier()) +op2 = AnnotatedGate(op2_inner, ControlModifier(2)) +``` + +Both op1 and op2 are semantically equivalent to an `SGate()` which is first inverted and then controlled by 2 qubits. + +## Attributes + + + +### name + +Unique string identifier for operation type. + + + +### num\_clbits + +Number of classical bits. + + + +### num\_qubits + +Number of qubits. + +## Methods + +### copy + + + +`copy()` + +Return a copy of the [`AnnotatedOperation`](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation"). + +**Return type** + +[*AnnotatedOperation*](#qiskit.circuit.AnnotatedOperation "qiskit.circuit.annotated_operation.AnnotatedOperation") + +### to\_matrix + + + +`to_matrix()` + +Return a matrix representation (allowing to construct Operator). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Bit.md b/docs/api/qiskit/0.46/qiskit.circuit.Bit.md new file mode 100644 index 00000000000..41f0b585135 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Bit.md @@ -0,0 +1,50 @@ +--- +title: Bit +description: API reference for qiskit.circuit.Bit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Bit +--- + +# Bit + + + +`qiskit.circuit.Bit(register=None, index=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/bit.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Implement a generic bit. + + + This class should not be instantiated directly. This is just a superclass for [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") and [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit"). + + +Create a new generic bit. + +## Attributes + + + +### index + +Get the index of an old-style bit in the register that owns it. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.index` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + + + +### register + +Get the register of an old-style bit. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.register` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.BreakLoopOp.md b/docs/api/qiskit/0.46/qiskit.circuit.BreakLoopOp.md new file mode 100644 index 00000000000..33dab1d1251 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.BreakLoopOp.md @@ -0,0 +1,345 @@ +--- +title: BreakLoopOp +description: API reference for qiskit.circuit.BreakLoopOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.BreakLoopOp +--- + +# BreakLoopOp + + + +`qiskit.circuit.BreakLoopOp(num_qubits, num_clbits, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlflow/break_loop.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +A circuit operation which, when encountered, jumps to the end of the nearest enclosing loop. + +**Circuit symbol:** + +```python + ┌──────────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 ├ + │ break_loop │ +q_2: ┤2 ├ + │ │ +c_0: ╡0 ╞ + └──────────────┘ +``` + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.BreakLoopOp.base_class "qiskit.circuit.BreakLoopOp.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.CircuitInstruction.md b/docs/api/qiskit/0.46/qiskit.circuit.CircuitInstruction.md new file mode 100644 index 00000000000..e5140ee8a61 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.CircuitInstruction.md @@ -0,0 +1,82 @@ +--- +title: CircuitInstruction +description: API reference for qiskit.circuit.CircuitInstruction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.CircuitInstruction +--- + +# CircuitInstruction + + + +`qiskit.circuit.CircuitInstruction(operation, qubits=(), clbits=())`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/quantumcircuitdata.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A single instruction in a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), comprised of the [`operation`](#qiskit.circuit.CircuitInstruction.operation "qiskit.circuit.CircuitInstruction.operation") and various operands. + + + There is some possible confusion in the names of this class, [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), and [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation"), and this class’s attribute [`operation`](#qiskit.circuit.CircuitInstruction.operation "qiskit.circuit.CircuitInstruction.operation"). Our preferred terminology is by analogy to assembly languages, where an “instruction” is made up of an “operation” and its “operands”. + + Historically, [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") came first, and originally contained the qubits it operated on and any parameters, so it was a true “instruction”. Over time, [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") became responsible for tracking qubits and clbits, and the class became better described as an “operation”. Changing the name of such a core object would be a very unpleasant API break for users, and so we have stuck with it. + + This class was created to provide a formal “instruction” context object in `QuantumCircuit.data`, which had long been made of ad-hoc tuples. With this, and the advent of the [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") interface for adding more complex objects to circuits, we took the opportunity to correct the historical naming. For the time being, this leads to an awkward case where [`CircuitInstruction.operation`](#qiskit.circuit.CircuitInstruction.operation "qiskit.circuit.CircuitInstruction.operation") is often an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instance ([`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") implements the [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") interface), but as the [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") interface gains more use, this confusion will hopefully abate. + + + + This is a lightweight internal class and there is minimal error checking; you must respect the type hints when using it. It is the user’s responsibility to ensure that direct mutations of the object do not invalidate the types, nor the restrictions placed on it by its context. Typically this will mean, for example, that [`qubits`](#qiskit.circuit.CircuitInstruction.qubits "qiskit.circuit.CircuitInstruction.qubits") must be a sequence of distinct items, with no duplicates. + + +## Attributes + + + +### operation + +`Operation` + +The logical operation that this instruction represents an execution of. + + + +### qubits + +`Tuple[Qubit, ...]` + +A sequence of the qubits that the operation is applied to. + + + +### clbits + +`Tuple[Clbit, ...]` + +A sequence of the classical bits that this operation reads from or writes to. + +## Methods + +### copy + + + +`copy()` + +Return a shallow copy of the [`CircuitInstruction`](#qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction"). + +**Return type** + +[*CircuitInstruction*](#qiskit.circuit.CircuitInstruction "qiskit.circuit.quantumcircuitdata.CircuitInstruction") + +### replace + + + +`replace(operation=None, qubits=None, clbits=None)` + +Return a new [`CircuitInstruction`](#qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") with the given fields replaced. + +**Return type** + +[*CircuitInstruction*](#qiskit.circuit.CircuitInstruction "qiskit.circuit.quantumcircuitdata.CircuitInstruction") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ClassicalRegister.md b/docs/api/qiskit/0.46/qiskit.circuit.ClassicalRegister.md new file mode 100644 index 00000000000..b0c1e06d474 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ClassicalRegister.md @@ -0,0 +1,90 @@ +--- +title: ClassicalRegister +description: API reference for qiskit.circuit.ClassicalRegister +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ClassicalRegister +--- + +# ClassicalRegister + + + +`qiskit.circuit.ClassicalRegister(size=None, name=None, bits=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classicalregister.py "view source code") + +Bases: [`Register`](qiskit.circuit.Register "qiskit.circuit.register.Register") + +Implement a classical register. + +Create a new generic register. + +Either the `size` or the `bits` argument must be provided. If `size` is not None, the register will be pre-populated with bits of the correct type. + +**Parameters** + +* **size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The number of bits to include in the register. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional. The name of the register. If not provided, a unique name will be auto-generated from the register type. +* **bits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – Optional. A list of Bit() instances to be used to populate the register. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both the `size` and `bits` arguments are provided, or if neither are. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `size` is not valid. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `name` is not a valid name according to the OpenQASM spec. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained duplicated bits. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained bits of an incorrect type. + +## Attributes + + + +### instances\_counter + +`= count(0)` + + + +### name + +Get the register name. + + + +### name\_format + +`= re.compile('[a-z][a-zA-Z0-9_]*')` + + + +### prefix + +`= 'c'` + + + +### size + +Get the register size. + +## Methods + +### index + + + +`index(bit)` + +Find the index of the provided bit within this register. + +### qasm + + + +`qasm()` + +Return OPENQASM string for this register. + + + The method `qiskit.circuit.classicalregister.ClassicalRegister.qasm()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Clbit.md b/docs/api/qiskit/0.46/qiskit.circuit.Clbit.md new file mode 100644 index 00000000000..ad65b20f0ba --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Clbit.md @@ -0,0 +1,55 @@ +--- +title: Clbit +description: API reference for qiskit.circuit.Clbit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Clbit +--- + +# Clbit + + + +`qiskit.circuit.Clbit(register=None, index=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classicalregister.py "view source code") + +Bases: [`Bit`](qiskit.circuit.Bit "qiskit.circuit.bit.Bit") + +Implement a classical bit. + +Creates a classical bit. + +**Parameters** + +* **register** ([*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")) – Optional. A classical register containing the bit. +* **index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The index of the bit in its containing register. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the provided register is not a valid [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") + +## Attributes + + + +### index + +Get the index of an old-style bit in the register that owns it. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.index` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + + + +### register + +Get the register of an old-style bit. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.register` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.CommutationChecker.md b/docs/api/qiskit/0.46/qiskit.circuit.CommutationChecker.md new file mode 100644 index 00000000000..427805ee99f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.CommutationChecker.md @@ -0,0 +1,46 @@ +--- +title: CommutationChecker +description: API reference for qiskit.circuit.CommutationChecker +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.CommutationChecker +--- + +# CommutationChecker + + + +`qiskit.circuit.CommutationChecker`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/commutation_checker.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +This code is essentially copy-pasted from commutative\_analysis.py. This code cleverly hashes commutativity and non-commutativity results between DAG nodes and seems quite efficient for large Clifford circuits. They may be other possible efficiency improvements: using rule-based commutativity analysis, evicting from the cache less useful entries, etc. + +## Methods + +### commute + + + +`commute(op1, qargs1, cargs1, op2, qargs2, cargs2, max_num_qubits=3)` + +Checks if two Operations commute. The return value of True means that the operations truly commute, and the return value of False means that either the operations do not commute or that the commutation check was skipped (for example, when the operations have conditions or have too many qubits). + +**Parameters** + +* **op1** ([*Operation*](qiskit.circuit.Operation "qiskit.circuit.operation.Operation")) – first operation. +* **qargs1** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")) – first operation’s qubits. +* **cargs1** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")) – first operation’s clbits. +* **op2** ([*Operation*](qiskit.circuit.Operation "qiskit.circuit.operation.Operation")) – second operation. +* **qargs2** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")) – second operation’s qubits. +* **cargs2** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")) – second operation’s clbits. +* **max\_num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the maximum number of qubits to consider, the check may be skipped if the number of qubits for either operation exceeds this amount. + +**Returns** + +whether two operations commute. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ContinueLoopOp.md b/docs/api/qiskit/0.46/qiskit.circuit.ContinueLoopOp.md new file mode 100644 index 00000000000..460051fc9da --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ContinueLoopOp.md @@ -0,0 +1,349 @@ +--- +title: ContinueLoopOp +description: API reference for qiskit.circuit.ContinueLoopOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ContinueLoopOp +--- + +# ContinueLoopOp + + + +`qiskit.circuit.ContinueLoopOp(num_qubits, num_clbits, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlflow/continue_loop.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +A circuit operation which, when encountered, moves to the next iteration of the nearest enclosing loop. + + + Can be inserted only within the body of a loop op, and must span the full width of that block. + + +**Circuit symbol:** + +```python + ┌─────────────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 ├ + │ continue_loop │ +q_2: ┤2 ├ + │ │ +c_0: ╡0 ╞ + └─────────────────┘ +``` + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.ContinueLoopOp.base_class "qiskit.circuit.ContinueLoopOp.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ControlFlowOp.md b/docs/api/qiskit/0.46/qiskit.circuit.ControlFlowOp.md new file mode 100644 index 00000000000..91164e88d20 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ControlFlowOp.md @@ -0,0 +1,353 @@ +--- +title: ControlFlowOp +description: API reference for qiskit.circuit.ControlFlowOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ControlFlowOp +--- + +# ControlFlowOp + + + +`qiskit.circuit.ControlFlowOp(name, num_qubits, num_clbits, params, duration=None, unit='dt', label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlflow/control_flow.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Abstract class to encapsulate all control flow operations. + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.ControlFlowOp.base_class "qiskit.circuit.ControlFlowOp.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### blocks + +Tuple of QuantumCircuits which may be executed as part of the execution of this ControlFlowOp. May be parameterized by a loop parameter to be resolved at run time. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### replace\_blocks + + + +`abstract replace_blocks(blocks)` + +Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + +**Returns** + +New ControlFlowOp with replaced blocks. + +**Return type** + +[*ControlFlowOp*](#qiskit.circuit.ControlFlowOp "qiskit.circuit.controlflow.control_flow.ControlFlowOp") + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ControlModifier.md b/docs/api/qiskit/0.46/qiskit.circuit.ControlModifier.md new file mode 100644 index 00000000000..f63c8349a84 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ControlModifier.md @@ -0,0 +1,36 @@ +--- +title: ControlModifier +description: API reference for qiskit.circuit.ControlModifier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ControlModifier +--- + +# ControlModifier + + + +`qiskit.circuit.ControlModifier(num_ctrl_qubits=0, ctrl_state=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/annotated_operation.py "view source code") + +Bases: `Modifier` + +Control modifier: specifies that the operation is controlled by `num_ctrl_qubits` and has control state `ctrl_state`. + +## Attributes + + + +### ctrl\_state + +`int | str | None` + +`= None` + + + +### num\_ctrl\_qubits + +`int` + +`= 0` + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ControlledGate.md b/docs/api/qiskit/0.46/qiskit.circuit.ControlledGate.md new file mode 100644 index 00000000000..64cc909aad8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ControlledGate.md @@ -0,0 +1,495 @@ +--- +title: ControlledGate +description: API reference for qiskit.circuit.ControlledGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ControlledGate +--- + +# ControlledGate + + + +`qiskit.circuit.ControlledGate(name, num_qubits, params, label=None, num_ctrl_qubits=1, definition=None, ctrl_state=None, base_gate=None, duration=None, unit=None, *, _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlledgate.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Controlled unitary gate. + +Create a new ControlledGate. In the new gate the first `num_ctrl_qubits` of the gate are the controls. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the gate. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits the gate acts on. +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of parameters for the gate. +* **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – An optional label for the gate. +* **num\_ctrl\_qubits** (*Optional\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Number of control qubits. +* **definition** (*Optional\['QuantumCircuit']*) – A list of gate rules for implementing this gate. The elements of the list are tuples of ([`Gate()`](qiskit.circuit.Gate "qiskit.circuit.Gate"), \[qubit\_list], \[clbit\_list]). +* **ctrl\_state** (*Optional\[Union\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]]*) – The control state in decimal or as a bitstring (e.g. ‘111’). If specified as a bitstring the length must equal num\_ctrl\_qubits, MSB on left. If None, use 2\*\*num\_ctrl\_qubits-1. +* **base\_gate** (*Optional\[*[*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")*]*) – Gate object to be controlled. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If `num_ctrl_qubits` >= `num_qubits`. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – ctrl\_state \< 0 or ctrl\_state > 2\*\*num\_ctrl\_qubits. + +Examples: + +Create a controlled standard gate and apply it to a circuit. + +```python +from qiskit import QuantumCircuit, QuantumRegister +from qiskit.circuit.library.standard_gates import HGate + +qr = QuantumRegister(3) +qc = QuantumCircuit(qr) +c3h_gate = HGate().control(2) +qc.append(c3h_gate, qr) +qc.draw('mpl') +``` + +![../\_images/qiskit-circuit-ControlledGate-1.png](/images/api/qiskit/0.46/qiskit-circuit-ControlledGate-1.png) + +Create a controlled custom gate and apply it to a circuit. + +```python +from qiskit import QuantumCircuit, QuantumRegister +from qiskit.circuit.library.standard_gates import HGate + +qc1 = QuantumCircuit(2) +qc1.x(0) +qc1.h(1) +custom = qc1.to_gate().control(2) + +qc2 = QuantumCircuit(4) +qc2.append(custom, [0, 3, 1, 2]) +qc2.draw('mpl') +``` + +![../\_images/qiskit-circuit-ControlledGate-2.png](/images/api/qiskit/0.46/qiskit-circuit-ControlledGate-2.png) + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.ControlledGate.base_class "qiskit.circuit.ControlledGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation and handling of the arguments and its relationship. + +For example, `cx([q[0],q[1]], q[2])` means `cx(q[0], q[2]); cx(q[1], q[2])`. This method yields the arguments in the right grouping. In the given example: + +```python +in: [[q[0],q[1]], q[2]],[] +outs: [q[0], q[2]], [] + [q[1], q[2]], [] +``` + +The general broadcasting rules are: + +> * If len(qargs) == 1: +> +> ```python +> [q[0], q[1]] -> [q[0]],[q[1]] +> ``` +> +> * If len(qargs) == 2: +> +> ```python +> [[q[0], q[1]], [r[0], r[1]]] -> [q[0], r[0]], [q[1], r[1]] +> [[q[0]], [r[0], r[1]]] -> [q[0], r[0]], [q[0], r[1]] +> [[q[0], q[1]], [r[0]]] -> [q[0], r[0]], [q[1], r[0]] +> ``` +> +> * If len(qargs) >= 3: +> +> ```python +> [q[0], q[1]], [r[0], r[1]], ...] -> [q[0], r[0], ...], [q[1], r[1], ...] +> ``` + +**Parameters** + +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of quantum bit arguments. +* **cargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of classical bit arguments. + +**Returns** + +A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +**Return type** + +[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")]] + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return controlled version of gate. See [`ControlledGate`](#qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") for usage. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of controls to add to gate (default: `1`) +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – optional gate label +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The control state in decimal or as a bitstring (e.g. `'111'`). If `None`, use `2**num_ctrl_qubits-1`. + +**Returns** + +Controlled version of gate. This default algorithm uses `num_ctrl_qubits-1` ancilla qubits so returns a gate of size `num_qubits + 2*num_ctrl_qubits - 1`. + +**Return type** + +[qiskit.circuit.ControlledGate](#qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this gate by calling inverse on the base gate. + +**Return type** + +[*ControlledGate*](#qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### power + + + +`power(exponent)` + +Creates a unitary gate as gate^exponent. + +**Parameters** + +**exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + +**Returns** + +To which to\_matrix is self.to\_matrix^exponent. + +**Return type** + +.library.UnitaryGate + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_matrix + + + +`to_matrix()` + +Return a Numpy.array for the gate unitary matrix. + +**Returns** + +if the Gate subclass has a matrix definition. + +**Return type** + +np.ndarray + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If a Gate subclass does not implement this method an exception will be raised when this base class method is called. + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Gate parameters should be int, float, or ParameterExpression + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Delay.md b/docs/api/qiskit/0.46/qiskit.circuit.Delay.md new file mode 100644 index 00000000000..462efb32895 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Delay.md @@ -0,0 +1,350 @@ +--- +title: Delay +description: API reference for qiskit.circuit.Delay +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Delay +--- + +# Delay + + + +`qiskit.circuit.Delay(duration, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/delay.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Do nothing and just delay/wait/idle for a specified duration. + +Create new delay instruction. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.Delay.base_class "qiskit.circuit.Delay.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration of this delay. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation and handling of the arguments and its relationship. + +For example, `cx([q[0],q[1]], q[2])` means `cx(q[0], q[2]); cx(q[1], q[2])`. This method yields the arguments in the right grouping. In the given example: + +```python +in: [[q[0],q[1]], q[2]],[] +outs: [q[0], q[2]], [] + [q[1], q[2]], [] +``` + +The general broadcasting rules are: + +> * If len(qargs) == 1: +> +> ```python +> [q[0], q[1]] -> [q[0]],[q[1]] +> ``` +> +> * If len(qargs) == 2: +> +> ```python +> [[q[0], q[1]], [r[0], r[1]]] -> [q[0], r[0]], [q[1], r[1]] +> [[q[0]], [r[0], r[1]]] -> [q[0], r[0]], [q[0], r[1]] +> [[q[0], q[1]], [r[0]]] -> [q[0], r[0]], [q[1], r[0]] +> ``` +> +> * If len(qargs) >= 3: +> +> ```python +> [q[0], q[1]], [r[0], r[1]], ...] -> [q[0], r[0], ...], [q[1], r[1], ...] +> ``` + +**Parameters** + +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of quantum bit arguments. +* **cargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of classical bit arguments. + +**Returns** + +A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +**Return type** + +[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")]] + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Special case. Return self. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_matrix + + + +`to_matrix()` + +Return a Numpy.array for the unitary matrix. This has been added to enable simulation without making delay a full Gate type. + +**Returns** + +matrix representation. + +**Return type** + +np.ndarray + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Delay parameter (i.e. duration) must be int, float or ParameterExpression. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.EquivalenceLibrary.md b/docs/api/qiskit/0.46/qiskit.circuit.EquivalenceLibrary.md new file mode 100644 index 00000000000..80500c5be3e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.EquivalenceLibrary.md @@ -0,0 +1,184 @@ +--- +title: EquivalenceLibrary +description: API reference for qiskit.circuit.EquivalenceLibrary +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.EquivalenceLibrary +--- + +# EquivalenceLibrary + + + +`qiskit.circuit.EquivalenceLibrary(*, base=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/equivalence.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A library providing a one-way mapping of Gates to their equivalent implementations as QuantumCircuits. + +Create a new equivalence library. + +**Parameters** + +**base** (*Optional\[*[*EquivalenceLibrary*](#qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary")*]*) – Base equivalence library to be referenced if an entry is not found in this library. + +## Attributes + + + +### graph + +Return graph representing the equivalence library data. + +This property should be treated as read-only as it provides a reference to the internal state of the [`EquivalenceLibrary`](#qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary") object. If the graph returned by this property is mutated it could corrupt the the contents of the object. If you need to modify the output `PyDiGraph` be sure to make a copy prior to any modification. + +**Returns** + +A graph object with equivalence data in each node. + +**Return type** + +PyDiGraph + +## Methods + +### add\_equivalence + + + +`add_equivalence(gate, equivalent_circuit)` + +Add a new equivalence to the library. Future queries for the Gate will include the given circuit, in addition to all existing equivalences (including those from base). + +Parameterized Gates (those including qiskit.circuit.Parameters in their Gate.params) can be marked equivalent to parameterized circuits, provided the parameters match. + +**Parameters** + +* **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")) – A Gate instance. +* **equivalent\_circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A circuit equivalently implementing the given Gate. + +### draw + + + +`draw(filename=None)` + +Draws the equivalence relations available in the library. + +**Parameters** + +**filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional path to write the output image to if specified this method will return None. + +**Returns** + +**Drawn equivalence library as an** + +IPython SVG if in a jupyter notebook, or as a PIL.Image otherwise. + +**Return type** + +PIL.Image or IPython.display.SVG + +**Raises** + +[**InvalidFileError**](exceptions#qiskit.exceptions.InvalidFileError "qiskit.exceptions.InvalidFileError") – if filename is not valid. + +### get\_entry + + + +`get_entry(gate)` + +Gets the set of QuantumCircuits circuits from the library which equivalently implement the given Gate. + +Parameterized circuits will have their parameters replaced with the corresponding entries from Gate.params. + +**Parameters** + +**gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")) – A Gate instance. + +**Returns** + +**A list of equivalent QuantumCircuits. If empty,** + +library contains no known decompositions of Gate. + +Returned circuits will be ordered according to their insertion in the library, from earliest to latest, from top to base. The ordering of the StandardEquivalenceLibrary will not generally be consistent across Qiskit versions. + +**Return type** + +List\[[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")] + +### has\_entry + + + +`has_entry(gate)` + +Check if a library contains any decompositions for gate. + +**Parameters** + +**gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")) – A Gate instance. + +**Returns** + +**True if gate has a known decomposition in the library.** + +False otherwise. + +**Return type** + +[Bool](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool") + +### keys + + + +`keys()` + +Return list of keys to key to node index map. + +**Returns** + +Keys to the key to node index map. + +**Return type** + +List + +### node\_index + + + +`node_index(key)` + +Return node index for a given key. + +**Parameters** + +**key** (*Key*) – Key to an equivalence. + +**Returns** + +Index to the node in the graph for the given key. + +**Return type** + +Int + +### set\_entry + + + +`set_entry(gate, entry)` + +Set the equivalence record for a Gate. Future queries for the Gate will return only the circuits provided. + +Parameterized Gates (those including qiskit.circuit.Parameters in their Gate.params) can be marked equivalent to parameterized circuits, provided the parameters match. + +**Parameters** + +* **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")) – A Gate instance. +* **entry** (*List\['QuantumCircuit']*) – A list of QuantumCircuits, each equivalently implementing the given Gate. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ForLoopOp.md b/docs/api/qiskit/0.46/qiskit.circuit.ForLoopOp.md new file mode 100644 index 00000000000..6c2f2b3120e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ForLoopOp.md @@ -0,0 +1,366 @@ +--- +title: ForLoopOp +description: API reference for qiskit.circuit.ForLoopOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ForLoopOp +--- + +# ForLoopOp + + + +`qiskit.circuit.ForLoopOp(indexset, loop_parameter, body, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlflow/for_loop.py "view source code") + +Bases: [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.controlflow.control_flow.ControlFlowOp") + +A circuit operation which repeatedly executes a subcircuit (`body`) parameterized by a parameter `loop_parameter` through the set of integer values provided in `indexset`. + +**Parameters** + +* **indexset** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A collection of integers to loop over. +* **loop\_parameter** ([*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter") *| None*) – The placeholder parameterizing `body` to which the values from `indexset` will be assigned. +* **body** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The loop body to be repeatedly executed. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for identifying the instruction. + +**Circuit symbol:** + +```python + ┌───────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 ├ + │ for_loop │ +q_2: ┤2 ├ + │ │ +c_0: ╡0 ╞ + └───────────┘ +``` + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.ForLoopOp.base_class "qiskit.circuit.ForLoopOp.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### blocks + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### replace\_blocks + + + +`replace_blocks(blocks)` + +Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + +**Returns** + +New ControlFlowOp with replaced blocks. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Gate.md b/docs/api/qiskit/0.46/qiskit.circuit.Gate.md new file mode 100644 index 00000000000..910d4f5d9b0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Gate.md @@ -0,0 +1,427 @@ +--- +title: Gate +description: API reference for qiskit.circuit.Gate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Gate +--- + +# Gate + + + +`qiskit.circuit.Gate(name, num_qubits, params, label=None, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/gate.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Unitary gate. + +Create a new gate. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The Qobj name of the gate. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits the gate acts on. +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of parameters. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for the gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.Gate.base_class "qiskit.circuit.Gate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation and handling of the arguments and its relationship. + +For example, `cx([q[0],q[1]], q[2])` means `cx(q[0], q[2]); cx(q[1], q[2])`. This method yields the arguments in the right grouping. In the given example: + +```python +in: [[q[0],q[1]], q[2]],[] +outs: [q[0], q[2]], [] + [q[1], q[2]], [] +``` + +The general broadcasting rules are: + +> * If len(qargs) == 1: +> +> ```python +> [q[0], q[1]] -> [q[0]],[q[1]] +> ``` +> +> * If len(qargs) == 2: +> +> ```python +> [[q[0], q[1]], [r[0], r[1]]] -> [q[0], r[0]], [q[1], r[1]] +> [[q[0]], [r[0], r[1]]] -> [q[0], r[0]], [q[0], r[1]] +> [[q[0], q[1]], [r[0]]] -> [q[0], r[0]], [q[1], r[0]] +> ``` +> +> * If len(qargs) >= 3: +> +> ```python +> [q[0], q[1]], [r[0], r[1]], ...] -> [q[0], r[0], ...], [q[1], r[1], ...] +> ``` + +**Parameters** + +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of quantum bit arguments. +* **cargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of classical bit arguments. + +**Returns** + +A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +**Return type** + +[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")]] + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return controlled version of gate. See [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") for usage. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of controls to add to gate (default: `1`) +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – optional gate label +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The control state in decimal or as a bitstring (e.g. `'111'`). If `None`, use `2**num_ctrl_qubits-1`. + +**Returns** + +Controlled version of gate. This default algorithm uses `num_ctrl_qubits-1` ancilla qubits so returns a gate of size `num_qubits + 2*num_ctrl_qubits - 1`. + +**Return type** + +[qiskit.circuit.ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### power + + + +`power(exponent)` + +Creates a unitary gate as gate^exponent. + +**Parameters** + +**exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + +**Returns** + +To which to\_matrix is self.to\_matrix^exponent. + +**Return type** + +.library.UnitaryGate + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_matrix + + + +`to_matrix()` + +Return a Numpy.array for the gate unitary matrix. + +**Returns** + +if the Gate subclass has a matrix definition. + +**Return type** + +np.ndarray + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If a Gate subclass does not implement this method an exception will be raised when this base class method is called. + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Gate parameters should be int, float, or ParameterExpression + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.IfElseOp.md b/docs/api/qiskit/0.46/qiskit.circuit.IfElseOp.md new file mode 100644 index 00000000000..3df61193c64 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.IfElseOp.md @@ -0,0 +1,378 @@ +--- +title: IfElseOp +description: API reference for qiskit.circuit.IfElseOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.IfElseOp +--- + +# IfElseOp + + + +`qiskit.circuit.IfElseOp(condition, true_body, false_body=None, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlflow/if_else.py "view source code") + +Bases: [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.controlflow.control_flow.ControlFlowOp") + +A circuit operation which executes a program (`true_body`) if a provided condition (`condition`) evaluates to true, and optionally evaluates another program (`false_body`) otherwise. + +**Parameters** + +* **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – A condition to be evaluated at circuit runtime which, if true, will trigger the evaluation of `true_body`. Can be specified as either a tuple of a `ClassicalRegister` to be tested for equality with a given `int`, or as a tuple of a `Clbit` to be compared to either a `bool` or an `int`. +* **true\_body** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – A program to be executed if `condition` evaluates to true. +* **false\_body** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A optional program to be executed if `condition` evaluates to false. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for identifying the instruction. + +If provided, `false_body` must be of the same `num_qubits` and `num_clbits` as `true_body`. + +The classical bits used in `condition` must be a subset of those attached to the circuit on which this `IfElseOp` will be appended. + +**Circuit symbol:** + +```python + ┌───────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 ├ + │ if_else │ +q_2: ┤2 ├ + │ │ +c_0: ╡0 ╞ + └───────────┘ +``` + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.IfElseOp.base_class "qiskit.circuit.IfElseOp.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### blocks + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### replace\_blocks + + + +`replace_blocks(blocks)` + +Replace blocks and return new instruction. + +**Parameters** + +**blocks** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*]*) – Iterable of circuits for “if” and “else” condition. If there is no “else” circuit it may be set to None or omitted. + +**Returns** + +New IfElseOp with replaced blocks. + +**Return type** + +[*IfElseOp*](#qiskit.circuit.IfElseOp "qiskit.circuit.controlflow.if_else.IfElseOp") + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Instruction.md b/docs/api/qiskit/0.46/qiskit.circuit.Instruction.md new file mode 100644 index 00000000000..84594a70898 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Instruction.md @@ -0,0 +1,331 @@ +--- +title: Instruction +description: API reference for qiskit.circuit.Instruction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Instruction +--- + +# Instruction + + + +`qiskit.circuit.Instruction(name, num_qubits, num_clbits, params, duration=None, unit='dt', label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/instruction.py "view source code") + +Bases: [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") + +Generic quantum instruction. + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.Instruction.base_class "qiskit.circuit.Instruction.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](#qiskit.circuit.Instruction.name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](#qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](#qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](#qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](#qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.InstructionSet.md b/docs/api/qiskit/0.46/qiskit.circuit.InstructionSet.md new file mode 100644 index 00000000000..63441668f32 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.InstructionSet.md @@ -0,0 +1,121 @@ +--- +title: InstructionSet +description: API reference for qiskit.circuit.InstructionSet +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.InstructionSet +--- + +# InstructionSet + + + +`qiskit.circuit.InstructionSet(*, resource_requester=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/instructionset.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Instruction collection, and their contexts. + +New collection of instructions. + +The context (`qargs` and `cargs` that each instruction is attached to) is also stored separately for each instruction. + +**Parameters** + +**resource\_requester** (*Callable\[...,* [*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") *|*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*] | None*) – + +A callable that takes in the classical resource used in the condition, verifies that it is present in the attached circuit, resolves any indices into concrete [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") instances, and returns the concrete resource. If this is not given, specifying a condition with an index is forbidden, and all concrete [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") and [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") resources will be assumed to be valid. + + + The callback `resource_requester` is called once for each call to [`c_if()`](#qiskit.circuit.InstructionSet.c_if "qiskit.circuit.InstructionSet.c_if"), and assumes that a call implies that the resource will now be used. It may throw an error if the resource is not valid for usage. + + +## Attributes + + + +### cargs + +Legacy getter for the cargs components of an instruction set. This does not support mutation. + + + +### instructions + +Legacy getter for the instruction components of an instruction set. This does not support mutation. + + + +### qargs + +Legacy getter for the qargs components of an instruction set. This does not support mutation. + +## Methods + +### add + + + +`add(instruction, qargs=None, cargs=None)` + +Add an instruction and its context (where it is attached). + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on all the instructions in this set between the [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition on any of the contained instructions; it does not stack. + + +**Parameters** + +* **classical** ([*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit") *|*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the classical resource the equality condition should be on. If this is given as an integer, it will be resolved into a [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") using the same conventions as the circuit these instructions are attached to. +* **val** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the value the classical resource should be equal to. + +**Returns** + +This same instance of [`InstructionSet`](#qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet"), but now mutated to have the given equality condition. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the passed classical resource is invalid, or otherwise not resolvable to a concrete resource that these instructions are permitted to access. + +**Return type** + +[InstructionSet](#qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +**Example** + +```python +from qiskit import ClassicalRegister, QuantumRegister, QuantumCircuit + +qr = QuantumRegister(2) +cr = ClassicalRegister(2) +qc = QuantumCircuit(qr, cr) +qc.h(range(2)) +qc.measure(range(2), range(2)) + +# apply x gate if the classical register has the value 2 (10 in binary) +qc.x(0).c_if(cr, 2) + +# apply y gate if bit 0 is set to 1 +qc.y(1).c_if(0, 1) + +qc.draw('mpl') +``` + +![../\_images/qiskit-circuit-InstructionSet-1.png](/images/api/qiskit/0.46/qiskit-circuit-InstructionSet-1.png) + +### inverse + + + +`inverse()` + +Invert all instructions. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.InverseModifier.md b/docs/api/qiskit/0.46/qiskit.circuit.InverseModifier.md new file mode 100644 index 00000000000..49503610b12 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.InverseModifier.md @@ -0,0 +1,18 @@ +--- +title: InverseModifier +description: API reference for qiskit.circuit.InverseModifier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.InverseModifier +--- + +# InverseModifier + + + +`qiskit.circuit.InverseModifier`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/annotated_operation.py "view source code") + +Bases: `Modifier` + +Inverse modifier: specifies that the operation is inverted. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Operation.md b/docs/api/qiskit/0.46/qiskit.circuit.Operation.md new file mode 100644 index 00000000000..5b691c8f996 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Operation.md @@ -0,0 +1,55 @@ +--- +title: Operation +description: API reference for qiskit.circuit.Operation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Operation +--- + +# Operation + + + +`qiskit.circuit.Operation`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/operation.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Quantum Operation Interface Class. For objects that can be added to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). These objects include [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate"), `Reset`, `Barrier`, `Measure`, and operators such as [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford"). The main purpose is to add an [`Operation`](#qiskit.circuit.Operation "qiskit.circuit.Operation") to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") without synthesizing it before the transpilation. + +**Example** + +Add a Clifford and a Toffoli gate to a QuantumCircuit. + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import Clifford, random_clifford + +qc = QuantumCircuit(3) +cliff = random_clifford(2) +qc.append(cliff, [0, 1]) +qc.ccx(0, 1, 2) +qc.draw('mpl') +``` + +![../\_images/qiskit-circuit-Operation-1.png](/images/api/qiskit/0.46/qiskit-circuit-Operation-1.png) + +## Attributes + + + +### name + +Unique string identifier for operation type. + + + +### num\_clbits + +Number of classical bits. + + + +### num\_qubits + +Number of qubits. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Parameter.md b/docs/api/qiskit/0.46/qiskit.circuit.Parameter.md new file mode 100644 index 00000000000..16db09dd992 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Parameter.md @@ -0,0 +1,258 @@ +--- +title: Parameter +description: API reference for qiskit.circuit.Parameter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Parameter +--- + +# Parameter + + + +`qiskit.circuit.Parameter(name, *, uuid=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/parameter.py "view source code") + +Bases: [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + +Parameter Class for variable parameters. + +A parameter is a variable value that is not required to be fixed at circuit definition. + +**Examples** + +Construct a variable-rotation X gate using circuit parameters. + +```python +from qiskit.circuit import QuantumCircuit, Parameter + +# create the parameter +phi = Parameter('phi') +qc = QuantumCircuit(1) + +# parameterize the rotation +qc.rx(phi, 0) +qc.draw('mpl') + +# bind the parameters after circuit to create a bound circuit +bc = qc.assign_parameters({phi: 3.14}) +bc.measure_all() +bc.draw('mpl') +``` + +![../\_images/qiskit-circuit-Parameter-1\_00.png](/images/api/qiskit/0.46/qiskit-circuit-Parameter-1_00.png) + +![../\_images/qiskit-circuit-Parameter-1\_01.png](/images/api/qiskit/0.46/qiskit-circuit-Parameter-1_01.png) + +Create a new named [`Parameter`](#qiskit.circuit.Parameter "qiskit.circuit.Parameter"). + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the `Parameter`, used for visual representation. This can be any unicode string, e.g. “ϕ”. +* **uuid** (*UUID | None*) – For advanced usage only. Override the UUID of this parameter, in order to make it compare equal to some other parameter object. By default, two parameters with the same name do not compare equal to help catch shadowing bugs when two circuits containing the same named parameters are spurious combined. Setting the `uuid` field when creating two parameters to the same thing (along with the same name) allows them to be equal. This is useful during serialization and deserialization. + +## Attributes + + + +### name + +Returns the name of the [`Parameter`](#qiskit.circuit.Parameter "qiskit.circuit.Parameter"). + + + +### parameters + +Returns a set of the unbound Parameters in the expression. + +## Methods + +### abs + + + +`abs()` + +Absolute of a ParameterExpression + +### arccos + + + +`arccos()` + +Arccos of a ParameterExpression + +### arcsin + + + +`arcsin()` + +Arcsin of a ParameterExpression + +### arctan + + + +`arctan()` + +Arctan of a ParameterExpression + +### assign + + + +`assign(parameter, value)` + +Assign one parameter to a value, which can either be numeric or another parameter expression. + +**Parameters** + +* **parameter** ([*Parameter*](#qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – A parameter in this expression whose value will be updated. +* **value** – The new value to bind to. + +**Returns** + +A new expression parameterized by any parameters which were not bound by assignment. + +### bind + + + +`bind(parameter_values, allow_unknown_parameters=False)` + +Binds the provided set of parameters to their corresponding values. + +**Parameters** + +* **parameter\_values** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Mapping of Parameter instances to the numeric value to which they will be bound. +* **allow\_unknown\_parameters** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False`, raises an error if `parameter_values` contains Parameters in the keys outside those present in the expression. If `True`, any such parameters are simply ignored. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – + + * If parameter\_values contains Parameters outside those in self. - If a non-numeric value is passed in parameter\_values. + +* [**ZeroDivisionError**](https://docs.python.org/3/library/exceptions.html#ZeroDivisionError "(in Python v3.12)") – + + * If binding the provided values requires division by zero. + +**Returns** + +A new expression parameterized by any parameters which were not bound by parameter\_values. + +**Return type** + +[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + +### conjugate + + + +`conjugate()` + +Return the conjugate. + +**Return type** + +[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + +### cos + + + +`cos()` + +Cosine of a ParameterExpression + +### exp + + + +`exp()` + +Exponential of a ParameterExpression + +### gradient + + + +`gradient(param)` + +Get the derivative of a parameter expression w\.r.t. a specified parameter expression. + +**Parameters** + +**param** ([*Parameter*](#qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – Parameter w\.r.t. which we want to take the derivative + +**Returns** + +ParameterExpression representing the gradient of param\_expr w\.r.t. param or complex or float number + +**Return type** + +[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### is\_real + + + +`is_real()` + +Return whether the expression is real + +### log + + + +`log()` + +Logarithm of a ParameterExpression + +### sign + + + +`sign()` + +Sign of a ParameterExpression + +### sin + + + +`sin()` + +Sine of a ParameterExpression + +### subs + + + +`subs(parameter_map, allow_unknown_parameters=False)` + +Substitute self with the corresponding parameter in `parameter_map`. + +### sympify + + + +`sympify()` + +Return symbolic expression as a raw Sympy or Symengine object. + +Symengine is used preferentially; if both are available, the result will always be a `symengine` object. Symengine is a separate library but has integration with Sympy. + + + This is for interoperability only. Qiskit will not accept or work with raw Sympy or Symegine expressions in its parameters, because they do not contain the tracking information used in circuit-parameter binding and assignment. + + +### tan + + + +`tan()` + +Tangent of a ParameterExpression + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ParameterExpression.md b/docs/api/qiskit/0.46/qiskit.circuit.ParameterExpression.md new file mode 100644 index 00000000000..b151f6fa9c4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ParameterExpression.md @@ -0,0 +1,250 @@ +--- +title: ParameterExpression +description: API reference for qiskit.circuit.ParameterExpression +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ParameterExpression +--- + +# ParameterExpression + + + +`qiskit.circuit.ParameterExpression(symbol_map, expr)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/parameterexpression.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +ParameterExpression class to enable creating expressions of Parameters. + +Create a new [`ParameterExpression`](#qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression"). + +Not intended to be called directly, but to be instantiated via operations on other [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") or [`ParameterExpression`](#qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") objects. + +**Parameters** + +* **symbol\_map** (*Dict\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*, \[*[*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*, or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Mapping of [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances to the `sympy.Symbol` serving as their placeholder in expr. +* **expr** (*sympy.Expr*) – Expression of `sympy.Symbol` s. + +## Attributes + + + +### parameters + +Returns a set of the unbound Parameters in the expression. + +## Methods + +### abs + + + +`abs()` + +Absolute of a ParameterExpression + +### arccos + + + +`arccos()` + +Arccos of a ParameterExpression + +### arcsin + + + +`arcsin()` + +Arcsin of a ParameterExpression + +### arctan + + + +`arctan()` + +Arctan of a ParameterExpression + +### assign + + + +`assign(parameter, value)` + +Assign one parameter to a value, which can either be numeric or another parameter expression. + +**Parameters** + +* **parameter** ([*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – A parameter in this expression whose value will be updated. +* **value** ([*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The new value to bind to. + +**Returns** + +A new expression parameterized by any parameters which were not bound by assignment. + +**Return type** + +[*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + +### bind + + + +`bind(parameter_values, allow_unknown_parameters=False)` + +Binds the provided set of parameters to their corresponding values. + +**Parameters** + +* **parameter\_values** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Mapping of Parameter instances to the numeric value to which they will be bound. +* **allow\_unknown\_parameters** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False`, raises an error if `parameter_values` contains Parameters in the keys outside those present in the expression. If `True`, any such parameters are simply ignored. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – + + * If parameter\_values contains Parameters outside those in self. - If a non-numeric value is passed in parameter\_values. + +* [**ZeroDivisionError**](https://docs.python.org/3/library/exceptions.html#ZeroDivisionError "(in Python v3.12)") – + + * If binding the provided values requires division by zero. + +**Returns** + +A new expression parameterized by any parameters which were not bound by parameter\_values. + +**Return type** + +[*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + +### conjugate + + + +`conjugate()` + +Return the conjugate. + +**Return type** + +[*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + +### cos + + + +`cos()` + +Cosine of a ParameterExpression + +### exp + + + +`exp()` + +Exponential of a ParameterExpression + +### gradient + + + +`gradient(param)` + +Get the derivative of a parameter expression w\.r.t. a specified parameter expression. + +**Parameters** + +**param** ([*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) – Parameter w\.r.t. which we want to take the derivative + +**Returns** + +ParameterExpression representing the gradient of param\_expr w\.r.t. param or complex or float number + +**Return type** + +[*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### is\_real + + + +`is_real()` + +Return whether the expression is real + +### log + + + +`log()` + +Logarithm of a ParameterExpression + +### sign + + + +`sign()` + +Sign of a ParameterExpression + +### sin + + + +`sin()` + +Sine of a ParameterExpression + +### subs + + + +`subs(parameter_map, allow_unknown_parameters=False)` + +Returns a new Expression with replacement Parameters. + +**Parameters** + +* **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Mapping from Parameters in self to the ParameterExpression instances with which they should be replaced. +* **allow\_unknown\_parameters** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False`, raises an error if `parameter_map` contains Parameters in the keys outside those present in the expression. If `True`, any such parameters are simply ignored. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – + +* If parameter\_map contains Parameters outside those in self. - If the replacement Parameters in parameter\_map would result in a name conflict in the generated expression. + +**Returns** + +A new expression with the specified parameters replaced. + +**Return type** + +[*ParameterExpression*](#qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + +### sympify + + + +`sympify()` + +Return symbolic expression as a raw Sympy or Symengine object. + +Symengine is used preferentially; if both are available, the result will always be a `symengine` object. Symengine is a separate library but has integration with Sympy. + + + This is for interoperability only. Qiskit will not accept or work with raw Sympy or Symegine expressions in its parameters, because they do not contain the tracking information used in circuit-parameter binding and assignment. + + +### tan + + + +`tan()` + +Tangent of a ParameterExpression + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.ParameterVector.md b/docs/api/qiskit/0.46/qiskit.circuit.ParameterVector.md new file mode 100644 index 00000000000..3ba494c36aa --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.ParameterVector.md @@ -0,0 +1,52 @@ +--- +title: ParameterVector +description: API reference for qiskit.circuit.ParameterVector +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.ParameterVector +--- + +# ParameterVector + + + +`qiskit.circuit.ParameterVector(name, length=0)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/parametervector.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +ParameterVector class to quickly generate lists of parameters. + +## Attributes + + + +### name + +Returns the name of the ParameterVector. + + + +### params + +Returns the list of parameters in the ParameterVector. + +## Methods + +### index + + + +`index(value)` + +Returns first index of value. + +### resize + + + +`resize(length)` + +Resize the parameter vector. + +If necessary, new elements are generated. If length is smaller than before, the previous elements are cached and not re-generated if the vector is enlarged again. This is to ensure that the parameter instances do not change. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.PowerModifier.md b/docs/api/qiskit/0.46/qiskit.circuit.PowerModifier.md new file mode 100644 index 00000000000..d05c37059a4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.PowerModifier.md @@ -0,0 +1,26 @@ +--- +title: PowerModifier +description: API reference for qiskit.circuit.PowerModifier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.PowerModifier +--- + +# PowerModifier + + + +`qiskit.circuit.PowerModifier(power)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/annotated_operation.py "view source code") + +Bases: `Modifier` + +Power modifier: specifies that the operation is raised to the power `power`. + +## Attributes + + + +### power + +`float` + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.QuantumCircuit.md b/docs/api/qiskit/0.46/qiskit.circuit.QuantumCircuit.md new file mode 100644 index 00000000000..405af621f63 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.QuantumCircuit.md @@ -0,0 +1,3922 @@ +--- +title: QuantumCircuit +description: API reference for qiskit.circuit.QuantumCircuit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.QuantumCircuit +--- + +# QuantumCircuit + + + +`qiskit.circuit.QuantumCircuit(*regs, name=None, global_phase=0, metadata=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/quantumcircuit.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Create a new circuit. + +A circuit is a list of instructions bound to some registers. + +**Parameters** + +* **regs** (list([`Register`](qiskit.circuit.Register "qiskit.circuit.Register")) or list(`int`) or list(list([`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit")))) – + + The registers to be included in the circuit. + + * If a list of [`Register`](qiskit.circuit.Register "qiskit.circuit.Register") objects, represents the [`QuantumRegister`](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and/or [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") objects to include in the circuit. + + For example: + + > * `QuantumCircuit(QuantumRegister(4))` + > * `QuantumCircuit(QuantumRegister(4), ClassicalRegister(3))` + > * `QuantumCircuit(QuantumRegister(4, 'qr0'), QuantumRegister(2, 'qr1'))` + + * If a list of `int`, the amount of qubits and/or classical bits to include in the circuit. It can either be a single int for just the number of quantum bits, or 2 ints for the number of quantum bits and classical bits, respectively. + + For example: + + > * `QuantumCircuit(4) # A QuantumCircuit with 4 qubits` + > * `QuantumCircuit(4, 3) # A QuantumCircuit with 4 qubits and 3 classical bits` + + * If a list of python lists containing [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit") objects, a collection of [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit") s to be added to the circuit. + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the name of the quantum circuit. If not set, an automatically generated string will be assigned. + +* **global\_phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *or*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")) – The global phase of the circuit in radians. + +* **metadata** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Arbitrary key value metadata to associate with the circuit. This gets stored as free-form data in a dict in the [`metadata`](#qiskit.circuit.QuantumCircuit.metadata "qiskit.circuit.QuantumCircuit.metadata") attribute. It will not be directly used in the circuit. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the circuit name, if given, is not valid. + +**Examples** + +Construct a simple Bell state circuit. + +```python +from qiskit import QuantumCircuit + +qc = QuantumCircuit(2, 2) +qc.h(0) +qc.cx(0, 1) +qc.measure([0, 1], [0, 1]) +qc.draw('mpl') +``` + +![../\_images/qiskit-circuit-QuantumCircuit-1.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-1.png) + +Construct a 5-qubit GHZ circuit. + +```python +from qiskit import QuantumCircuit + +qc = QuantumCircuit(5) +qc.h(0) +qc.cx(0, range(1, 5)) +qc.measure_all() +``` + +Construct a 4-qubit Bernstein-Vazirani circuit using registers. + +```python +from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit + +qr = QuantumRegister(3, 'q') +anc = QuantumRegister(1, 'ancilla') +cr = ClassicalRegister(3, 'c') +qc = QuantumCircuit(qr, anc, cr) + +qc.x(anc[0]) +qc.h(anc[0]) +qc.h(qr[0:3]) +qc.cx(qr[0:3], anc[0]) +qc.h(qr[0:3]) +qc.barrier(qr) +qc.measure(qr, cr) + +qc.draw('mpl') +``` + +![../\_images/qiskit-circuit-QuantumCircuit-2.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-2.png) + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 183` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in [`QuantumCircuit.data`](#qiskit.circuit.QuantumCircuit.data "qiskit.circuit.QuantumCircuit.data"). + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### add\_bits + + + +`add_bits(bits)` + +Add Bits to the circuit. + +### add\_calibration + + + +`add_calibration(gate, qubits, schedule, params=None)` + +Register a low-level, custom pulse definition for the given gate. + +**Parameters** + +* **gate** (*Union\[*[*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")*,* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Gate information. +* **qubits** (*Union\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, Tuple\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – List of qubits to be measured. +* **schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule")) – Schedule information. +* **params** (*Optional\[List\[Union\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]]]*) – A list of parameters. + +**Raises** + +[**Exception**](https://docs.python.org/3/library/exceptions.html#Exception "(in Python v3.12)") – if the gate is of type string and params is None. + +### add\_register + + + +`add_register(*regs)` + +Add registers. + +### append + + + +`append(instruction, qargs=None, cargs=None)` + +Append one or more instructions to the end of the circuit, modifying the circuit in place. + +The `qargs` and `cargs` will be expanded and broadcast according to the rules of the given [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction"), and any non-[`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit") specifiers (such as integer indices) will be resolved into the relevant instances. + +If a [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") is given, it will be unwrapped, verified in the context of this circuit, and a new object will be appended to the circuit. In this case, you may not pass `qargs` or `cargs` separately. + +**Parameters** + +* **instruction** ([*Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation") *|*[*CircuitInstruction*](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")) – [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instance to append, or a [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") with all its context. +* **qargs** (*Sequence\[QubitSpecifier] | None*) – specifiers of the [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit")s to attach instruction to. +* **cargs** (*Sequence\[ClbitSpecifier] | None*) – specifiers of the [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit")s to attach instruction to. + +**Returns** + +a handle to the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s that were actually added to the circuit. + +**Return type** + +[qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the operation passed is not an instance of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") . + +### assign\_parameters + +### assign\_parameters + + + +`assign_parameters(parameters: Mapping[Parameter, ParameterExpression | float] | Sequence[ParameterExpression | float], inplace: Literal[False] = False, *, flat_input: bool = False, strict: bool = True) → QuantumCircuit` + + + +`assign_parameters(parameters: Mapping[Parameter, ParameterExpression | float] | Sequence[ParameterExpression | float], inplace: Literal[True] = False, *, flat_input: bool = False, strict: bool = True) → None` + +Assign parameters to new parameters or values. + +If `parameters` is passed as a dictionary, the keys must be [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") instances in the current circuit. The values of the dictionary can either be numeric values or new parameter objects. + +If `parameters` is passed as a list or array, the elements are assigned to the current parameters in the order of [`parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.parameters") which is sorted alphabetically (while respecting the ordering in [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") objects). + +The values can be assigned to the current circuit object or to a copy of it. + +**Parameters** + +* **parameters** – Either a dictionary or iterable specifying the new parameter values. +* **inplace** – If False, a copy of the circuit with the bound parameters is returned. If True the circuit instance itself is modified. +* **flat\_input** – If `True` and `parameters` is a mapping type, it is assumed to be exactly a mapping of `{parameter: value}`. By default (`False`), the mapping may also contain [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") keys that point to a corresponding sequence of values, and these will be unrolled during the mapping. +* **strict** – If `False`, any parameters given in the mapping that are not used in the circuit will be ignored. If `True` (the default), an error will be raised indicating a logic error. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If parameters is a dict and contains parameters not present in the circuit. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If parameters is a list/array and the length mismatches the number of free parameters in the circuit. + +**Returns** + +A copy of the circuit with bound parameters if `inplace` is False, otherwise None. + +**Examples** + +Create a parameterized circuit and assign the parameters in-place. + +```python +from qiskit.circuit import QuantumCircuit, Parameter + +circuit = QuantumCircuit(2) +params = [Parameter('A'), Parameter('B'), Parameter('C')] +circuit.ry(params[0], 0) +circuit.crx(params[1], 0, 1) +circuit.draw('mpl') +circuit.assign_parameters({params[0]: params[2]}, inplace=True) +circuit.draw('mpl') +``` + +![../\_images/qiskit-circuit-QuantumCircuit-3\_00.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-3_00.png) + +![../\_images/qiskit-circuit-QuantumCircuit-3\_01.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-3_01.png) + +Bind the values out-of-place by list and get a copy of the original circuit. + +```python +from qiskit.circuit import QuantumCircuit, ParameterVector + +circuit = QuantumCircuit(2) +params = ParameterVector('P', 2) +circuit.ry(params[0], 0) +circuit.crx(params[1], 0, 1) + +bound_circuit = circuit.assign_parameters([1, 2]) +bound_circuit.draw('mpl') + +circuit.draw('mpl') +``` + +![../\_images/qiskit-circuit-QuantumCircuit-4\_00.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-4_00.png) + +![../\_images/qiskit-circuit-QuantumCircuit-4\_01.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-4_01.png) + +### barrier + + + +`barrier(*qargs, label=None)` + +Apply [`Barrier`](qiskit.circuit.library.Barrier "qiskit.circuit.library.Barrier"). If `qargs` is empty, applies to all qubits in the circuit. + +**Parameters** + +* **qargs** (*QubitSpecifier*) – Specification for one or more qubit arguments. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The string label of the barrier. + +**Returns** + +handle to the added instructions. + +**Return type** + +[qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### bind\_parameters + + + +`bind_parameters(values)` + +Assign numeric parameters to values yielding a new circuit. + +If the values are given as list or array they are bound to the circuit in the order of [`parameters`](#qiskit.circuit.QuantumCircuit.parameters "qiskit.circuit.QuantumCircuit.parameters") (see the docstring for more details). + +To assign new Parameter objects or bind the values in-place, without yielding a new circuit, use the [`assign_parameters()`](#qiskit.circuit.QuantumCircuit.assign_parameters "qiskit.circuit.QuantumCircuit.assign_parameters") method. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.bind_parameters()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. Use assign\_parameters() instead + + +**Parameters** + +**values** ([*Mapping*](https://docs.python.org/3/library/typing.html#typing.Mapping "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – `{parameter: value, ...}` or `[value1, value2, ...]` + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If values is a dict and contains parameters not present in the circuit. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If values contains a ParameterExpression. + +**Returns** + +Copy of self with assignment substitution. + +**Return type** + +[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### break\_loop + + + +`break_loop()` + +Apply [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp"). + + + If you are using the context-manager “builder” forms of [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test"), [`for_loop()`](#qiskit.circuit.QuantumCircuit.for_loop "qiskit.circuit.QuantumCircuit.for_loop") or [`while_loop()`](#qiskit.circuit.QuantumCircuit.while_loop "qiskit.circuit.QuantumCircuit.while_loop"), you can only call this method if you are within a loop context, because otherwise the “resource width” of the operation cannot be determined. This would quickly lead to invalid circuits, and so if you are trying to construct a reusable loop body (without the context managers), you must also use the non-context-manager form of [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") and [`if_else()`](#qiskit.circuit.QuantumCircuit.if_else "qiskit.circuit.QuantumCircuit.if_else"). Take care that the [`BreakLoopOp`](qiskit.circuit.BreakLoopOp "qiskit.circuit.BreakLoopOp") instruction must span all the resources of its containing loop, not just the immediate scope. + + +**Returns** + +A handle to the instruction created. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if this method was called within a builder context, but not contained within a loop. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### cast + + + +`static cast(value, type_)` + +Best effort to cast value to type. Otherwise, returns the value. + +**Return type** + +*S* | *T* + +### cbit\_argument\_conversion + + + +`cbit_argument_conversion(clbit_representation)` + +Converts several classical bit representations (such as indexes, range, etc.) into a list of classical bits. + +**Parameters** + +**clbit\_representation** (*Object*) – representation to expand + +**Returns** + +Where each tuple is a classical bit. + +**Return type** + +List([tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) + +### ccx + + + +`ccx(control_qubit1, control_qubit2, target_qubit, ctrl_state=None)` + +Apply [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit1** (*QubitSpecifier*) – The qubit(s) used as the first control. +* **control\_qubit2** (*QubitSpecifier*) – The qubit(s) used as the second control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### ccz + + + +`ccz(control_qubit1, control_qubit2, target_qubit, label=None, ctrl_state=None)` + +Apply [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit1** (*QubitSpecifier*) – The qubit(s) used as the first control. +* **control\_qubit2** (*QubitSpecifier*) – The qubit(s) used as the second control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘10’). Defaults to controlling on the ‘11’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### ch + + + +`ch(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CHGate`](qiskit.circuit.library.CHGate "qiskit.circuit.library.CHGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### clear + + + +`clear()` + +Clear all instructions in self. + +Clearing the circuits will keep the metadata and calibrations. + +### cls\_instances + + + +`classmethod cls_instances()` + +Return the current number of instances of this class, useful for auto naming. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### cls\_prefix + + + +`classmethod cls_prefix()` + +Return the prefix to use for auto naming. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### cnot + + + +`cnot(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.cnot()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. Use QuantumCircuit.cx as direct replacement. + + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + + + QuantumCircuit.cx: the same function with a different name. + + +### compose + + + +`compose(other, qubits=None, clbits=None, front=False, inplace=False, wrap=False)` + +Compose circuit with `other` circuit or instruction, optionally permuting wires. + +`other` can be narrower or of equal width to `self`. + +**Parameters** + +* **other** ([*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *or*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – (sub)circuit or instruction to compose onto self. If not a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), this can be anything that [`append`](#qiskit.circuit.QuantumCircuit.append "qiskit.circuit.QuantumCircuit.append") will accept. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – qubits of self to compose onto. +* **clbits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – clbits of self to compose onto. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, front composition will be performed. This is not possible within control-flow builder context managers. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, modify the object. Otherwise return composed circuit. +* **wrap** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, wraps the other circuit into a gate (or instruction, depending on whether it contains only unitary instructions) before composing it onto self. + +**Returns** + +the composed circuit (returns None if inplace==True). + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if no correct wire mapping can be made between the two circuits, such as if `other` is wider than `self`. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if trying to emit a new circuit while `self` has a partially built control-flow context active, such as the context-manager forms of [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test"), [`for_loop()`](#qiskit.circuit.QuantumCircuit.for_loop "qiskit.circuit.QuantumCircuit.for_loop") and [`while_loop()`](#qiskit.circuit.QuantumCircuit.while_loop "qiskit.circuit.QuantumCircuit.while_loop"). +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if trying to compose to the front of a circuit when a control-flow builder block is active; there is no clear meaning to this action. + +**Examples** + +```python +>>> lhs.compose(rhs, qubits=[3, 2], inplace=True) +``` + +```python + ┌───┐ ┌─────┐ ┌───┐ +lqr_1_0: ───┤ H ├─── rqr_0: ──■──┤ Tdg ├ lqr_1_0: ───┤ H ├─────────────── + ├───┤ ┌─┴─┐└─────┘ ├───┤ +lqr_1_1: ───┤ X ├─── rqr_1: ┤ X ├─────── lqr_1_1: ───┤ X ├─────────────── + ┌──┴───┴──┐ └───┘ ┌──┴───┴──┐┌───┐ +lqr_1_2: ┤ U1(0.1) ├ + = lqr_1_2: ┤ U1(0.1) ├┤ X ├─────── + └─────────┘ └─────────┘└─┬─┘┌─────┐ +lqr_2_0: ─────■───── lqr_2_0: ─────■───────■──┤ Tdg ├ + ┌─┴─┐ ┌─┴─┐ └─────┘ +lqr_2_1: ───┤ X ├─── lqr_2_1: ───┤ X ├─────────────── + └───┘ └───┘ +lcr_0: 0 ═══════════ lcr_0: 0 ═══════════════════════ + +lcr_1: 0 ═══════════ lcr_1: 0 ═══════════════════════ +``` + +### continue\_loop + + + +`continue_loop()` + +Apply [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp"). + + + If you are using the context-manager “builder” forms of [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test"), [`for_loop()`](#qiskit.circuit.QuantumCircuit.for_loop "qiskit.circuit.QuantumCircuit.for_loop") or [`while_loop()`](#qiskit.circuit.QuantumCircuit.while_loop "qiskit.circuit.QuantumCircuit.while_loop"), you can only call this method if you are within a loop context, because otherwise the “resource width” of the operation cannot be determined. This would quickly lead to invalid circuits, and so if you are trying to construct a reusable loop body (without the context managers), you must also use the non-context-manager form of [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") and [`if_else()`](#qiskit.circuit.QuantumCircuit.if_else "qiskit.circuit.QuantumCircuit.if_else"). Take care that the [`ContinueLoopOp`](qiskit.circuit.ContinueLoopOp "qiskit.circuit.ContinueLoopOp") instruction must span all the resources of its containing loop, not just the immediate scope. + + +**Returns** + +A handle to the instruction created. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if this method was called within a builder context, but not contained within a loop. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Control this circuit on `num_ctrl_qubits` qubits. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional label to give the controlled operation for visualization. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The control state in decimal or as a bitstring (e.g. ‘111’). If None, use `2**num_ctrl_qubits - 1`. + +**Returns** + +The controlled version of this circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the circuit contains a non-unitary operation and cannot be controlled. + +### copy + + + +`copy(name=None)` + +Copy the circuit. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit. If None, then the name stays the same. + +**Returns** + +a deepcopy of the current circuit, with the specified name + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### copy\_empty\_like + + + +`copy_empty_like(name=None)` + +Return a copy of self with the same structure but empty. + +**That structure includes:** + +* name, calibrations and other metadata +* global phase +* all the qubits and clbits, including the registers + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name for the copied circuit. If None, then the name stays the same. + +**Returns** + +An empty copy of self. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### count\_ops + + + +`count_ops()` + +Count each operation kind in the circuit. + +**Returns** + +a breakdown of how many operations of each kind, sorted by amount. + +**Return type** + +OrderedDict + +### cp + + + +`cp(theta, control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CPhaseGate`](qiskit.circuit.library.CPhaseGate "qiskit.circuit.library.CPhaseGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** (*ParameterValueType*) – The angle of the rotation. +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### crx + + + +`crx(theta, control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CRXGate`](qiskit.circuit.library.CRXGate "qiskit.circuit.library.CRXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** (*ParameterValueType*) – The angle of the rotation. +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### cry + + + +`cry(theta, control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CRYGate`](qiskit.circuit.library.CRYGate "qiskit.circuit.library.CRYGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** (*ParameterValueType*) – The angle of the rotation. +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### crz + + + +`crz(theta, control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CRZGate`](qiskit.circuit.library.CRZGate "qiskit.circuit.library.CRZGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** (*ParameterValueType*) – The angle of the rotation. +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### cs + + + +`cs(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### csdg + + + +`csdg(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### cswap + + + +`cswap(control_qubit, target_qubit1, target_qubit2, label=None, ctrl_state=None)` + +Apply [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit1** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **target\_qubit2** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. `'1'`). Defaults to controlling on the `'1'` state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### csx + + + +`csx(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CSXGate`](qiskit.circuit.library.CSXGate "qiskit.circuit.library.CSXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### cu + + + +`cu(theta, phi, lam, gamma, control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CUGate`](qiskit.circuit.library.CUGate "qiskit.circuit.library.CUGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** (*ParameterValueType*) – The $\theta$ rotation angle of the gate. +* **phi** (*ParameterValueType*) – The $\phi$ rotation angle of the gate. +* **lam** (*ParameterValueType*) – The $\lambda$ rotation angle of the gate. +* **gamma** (*ParameterValueType*) – The global phase applied of the U gate, if applied. +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### cx + + + +`cx(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the control. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### cy + + + +`cy(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the controls. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### cz + + + +`cz(control_qubit, target_qubit, label=None, ctrl_state=None)` + +Apply [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit** (*QubitSpecifier*) – The qubit(s) used as the controls. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. +* **ctrl\_state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The control state in decimal, or as a bitstring (e.g. ‘1’). Defaults to controlling on the ‘1’ state. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### dcx + + + +`dcx(qubit1, qubit2)` + +Apply [`DCXGate`](qiskit.circuit.library.DCXGate "qiskit.circuit.library.DCXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### decompose + + + +`decompose(gates_to_decompose=None, reps=1)` + +Call a decomposition pass on this circuit, to decompose one level (shallow decompose). + +**Parameters** + +* **gates\_to\_decompose** ([*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)")*,* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*)*) – Optional subset of gates to decompose. Can be a gate type, such as `HGate`, or a gate name, such as ‘h’, or a gate label, such as ‘My H Gate’, or a list of any combination of these. If a gate name is entered, it will decompose all gates with that name, whether the gates have labels or not. Defaults to all gates in circuit. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional number of times the circuit should be decomposed. For instance, `reps=2` equals calling `circuit.decompose().decompose()`. can decompose specific gates specific time + +**Returns** + +a circuit one level decomposed + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### delay + + + +`delay(duration, qarg=None, unit='dt')` + +Apply [`Delay`](qiskit.circuit.Delay "qiskit.circuit.Delay"). If qarg is `None`, applies to all qubits. When applying to multiple qubits, delays with the same duration will be created. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *or*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")) – duration of the delay. +* **qarg** (*Object*) – qubit argument to apply this delay. +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – unit of the duration. Supported units: `'s'`, `'ms'`, `'us'`, `'ns'`, `'ps'`, and `'dt'`. Default is `'dt'`, i.e. integer time unit depending on the target backend. + +**Returns** + +handle to the added instructions. + +**Return type** + +[qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if arguments have bad format. + +### depth + + + +`depth(filter_function=>)` + +Return circuit depth (i.e., length of critical path). + +**Parameters** + +**filter\_function** (*callable*) – A function to filter instructions. Should take as input a tuple of (Instruction, list(Qubit), list(Clbit)). Instructions for which the function returns False are ignored in the computation of the circuit depth. By default filters out “directives”, such as barrier or snapshot. + +**Returns** + +Depth of circuit. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +**Notes** + +The circuit depth and the DAG depth need not be the same. + +### diagonal + + + +`diagonal(diag, qubit)` + +Attach a diagonal gate to a circuit. + +The decomposition is based on Theorem 7 given in “Synthesis of Quantum Logic Circuits” by Shende et al. ([https://arxiv.org/pdf/quant-ph/0406176.pdf](https://arxiv.org/pdf/quant-ph/0406176.pdf)). + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.diagonal()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, compose the circuit with a qiskit.circuit.library.Diagonal circuit. + + +**Parameters** + +* **diag** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – list of the 2^k diagonal entries (for a diagonal gate on k qubits). Must contain at least two entries +* **qubit** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – list of k qubits the diagonal is acting on (the order of the qubits specifies the computational basis in which the diagonal gate is provided: the first element in diag acts on the state where all the qubits in q are in the state 0, the second entry acts on the state where all the qubits q\[1],…,q\[k-1] are in the state zero and q\[0] is in the state 1, and so on) + +**Returns** + +the diagonal gate which was attached to the circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the list of the diagonal entries or the qubit list is in bad format; if the number of diagonal entries is not 2^k, where k denotes the number of qubits + +### draw + + + +`draw(output=None, scale=None, filename=None, style=None, interactive=False, plot_barriers=True, reverse_bits=None, justify=None, vertical_compression='medium', idle_wires=True, with_layout=True, fold=None, ax=None, initial_state=False, cregbundle=None, wire_order=None, expr_len=30)` + +Draw the quantum circuit. Use the output parameter to choose the drawing format: + +**text**: ASCII art TextDrawing that can be printed in the console. + +**mpl**: images with color rendered purely in Python using matplotlib. + +**latex**: high-quality images compiled via latex. + +**latex\_source**: raw uncompiled latex output. + + + Support for [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") nodes in conditions and `SwitchCaseOp.target` fields is preliminary and incomplete. The `text` and `mpl` drawers will make a best-effort attempt to show data dependencies, but the LaTeX-based drawers will skip these completely. + + +**Parameters** + +* **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – select the output method to use for drawing the circuit. Valid choices are `text`, `mpl`, `latex`, `latex_source`. By default the text drawer is used unless the user config file (usually `~/.qiskit/settings.conf`) has an alternative backend set as the default. For example, `circuit_drawer = latex`. If the output kwarg is set, that backend will always be used over the default in the user config file. +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – scale of image to draw (shrink if \< 1.0). Only used by the mpl, latex and latex\_source outputs. Defaults to 1.0. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. Defaults to None. +* **style** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – dictionary of style or file name of style json file. This option is only used by the mpl or latex output type. If style is a str, it is used as the path to a json file which contains a style dict. The file will be opened, parsed, and then any style elements in the dict will replace the default values in the input dict. A file to be loaded must end in `.json`, but the name entered here can omit `.json`. For example, `style='iqp.json'` or `style='iqp'`. If style is a dict and the `'name'` key is set, that name will be used to load a json file, followed by loading the other items in the style dict. For example, `style={'name': 'iqp'}`. If style is not a str and name is not a key in the style dict, then the default value from the user config file (usually `~/.qiskit/settings.conf`) will be used, for example, `circuit_mpl_style = iqp`. If none of these are set, the clifford style will be used. The search path for style json files can be specified in the user config, for example, `circuit_mpl_style_path = /home/user/styles:/home/user`. See: [`DefaultStyle`](qiskit.visualization.circuit.qcstyle.DefaultStyle "qiskit.visualization.circuit.qcstyle.DefaultStyle") for more information on the contents. +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to true, show the circuit in a new window (for mpl this depends on the matplotlib backend being used supporting this). Note when used with either the text or the latex\_source output type this has no effect and will be silently ignored. Defaults to False. +* **reverse\_bits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to True, reverse the bit order inside registers for the output visualization. Defaults to False unless the user config file (usually `~/.qiskit/settings.conf`) has an alternative value set. For example, `circuit_reverse_bits = True`. +* **plot\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – enable/disable drawing barriers in the output circuit. Defaults to True. +* **justify** (*string*) – options are `left`, `right` or `none`. If anything else is supplied, it defaults to left justified. It refers to where gates should be placed in the output circuit if there is an option. `none` results in each gate being placed in its own column. +* **vertical\_compression** (*string*) – `high`, `medium` or `low`. It merges the lines generated by the text output so the drawing will take less vertical room. Default is `medium`. Only used by the text output, will be silently ignored otherwise. +* **idle\_wires** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – include idle wires (wires with no circuit elements) in output visualization. Default is True. +* **with\_layout** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – include layout information, with labels on the physical layout. Default is True. +* **fold** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – sets pagination. It can be disabled using -1. In text, sets the length of the lines. This is useful when the drawing does not fit in the console. If None (default), it will try to guess the console width using `shutil.get_terminal_size()`. However, if running in jupyter, the default line length is set to 80 characters. In mpl, it is the number of (visual) layers before folding. Default is 25. +* **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – Only used by the mpl backend. An optional Axes object to be used for the visualization output. If none is specified, a new matplotlib Figure will be created and used. Additionally, if specified there will be no returned Figure since it is redundant. +* **initial\_state** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional. Adds `|0>` in the beginning of the wire. Default is False. +* **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional. If set True, bundle classical registers. Default is True, except for when `output` is set to `"text"`. +* **wire\_order** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Optional. A list of integers used to reorder the display of the bits. The list must have an entry for every bit with the bits in the range 0 to (`num_qubits` + `num_clbits`). +* **expr\_len** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The number of characters to display if an [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") is used for the condition in a [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp"). If this number is exceeded, the string will be truncated at that number and ‘…’ added to the end. + +**Returns** + +`TextDrawing` or `matplotlib.figure` or `PIL.Image` or [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"): + +* **TextDrawing (output=’text’)** + + A drawing that can be printed as ascii art. + +* **matplotlib.figure.Figure (output=’mpl’)** + + A matplotlib figure object for the circuit diagram. + +* **PIL.Image (output=’latex’)** + + An in-memory representation of the image of the circuit diagram. + +* **str (output=’latex\_source’)** + + The LaTeX source code for visualizing the circuit diagram. + +**Raises** + +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – when an invalid output method is selected +* [**ImportError**](https://docs.python.org/3/library/exceptions.html#ImportError "(in Python v3.12)") – when the output methods requires non-installed libraries. + +**Example** + +```python +from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit +q = QuantumRegister(1) +c = ClassicalRegister(1) +qc = QuantumCircuit(q, c) +qc.h(q) +qc.measure(q, c) +qc.draw(output='mpl', style={'backgroundcolor': '#EEEEEE'}) +``` + +![../\_images/qiskit-circuit-QuantumCircuit-5.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-5.png) + +### ecr + + + +`ecr(qubit1, qubit2)` + +Apply [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### find\_bit + + + +`find_bit(bit)` + +Find locations in the circuit which can be used to reference a given [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit"). + +**Parameters** + +**bit** ([*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")) – The bit to locate. + +**Returns** + +**A 2-tuple. The first element (`index`)** + +contains the index at which the `Bit` can be found (in either [`qubits`](#qiskit.circuit.QuantumCircuit.qubits "qiskit.circuit.QuantumCircuit.qubits"), [`clbits`](#qiskit.circuit.QuantumCircuit.clbits "qiskit.circuit.QuantumCircuit.clbits"), depending on its type). The second element (`registers`) is a list of `(register, index)` pairs with an entry for each [`Register`](qiskit.circuit.Register "qiskit.circuit.Register") in the circuit which contains the [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit") (and the index in the [`Register`](qiskit.circuit.Register "qiskit.circuit.Register") at which it can be found). + +**Return type** + +namedtuple([int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), List\[Tuple([Register](qiskit.circuit.Register "qiskit.circuit.Register"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"))]) + +**Notes** + +The circuit index of an [`AncillaQubit`](qiskit.circuit.AncillaQubit "qiskit.circuit.AncillaQubit") will be its index in [`qubits`](#qiskit.circuit.QuantumCircuit.qubits "qiskit.circuit.QuantumCircuit.qubits"), not [`ancillas`](#qiskit.circuit.QuantumCircuit.ancillas "qiskit.circuit.QuantumCircuit.ancillas"). + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit") was of an unknown type. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the supplied [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit") could not be found on the circuit. + +**Return type** + +*BitLocations* + +### for\_loop + +### for\_loop + + + +`for_loop(indexset: Iterable[int], loop_parameter: Parameter | None, body: None, qubits: None, clbits: None, *, label: str | None) → qiskit.circuit.controlflow.for_loop.ForLoopContext` + + + +`for_loop(indexset: Iterable[int], loop_parameter: Parameter | None, body: QuantumCircuit, qubits: Sequence[Qubit | QuantumRegister | int | slice | Sequence[Qubit | int]], clbits: Sequence[Clbit | ClassicalRegister | int | slice | Sequence[Clbit | int]], *, label: str | None) → InstructionSet` + +Create a `for` loop on this circuit. + +There are two forms for calling this function. If called with all its arguments (with the possible exception of `label`), it will create a [`ForLoopOp`](qiskit.circuit.ForLoopOp "qiskit.circuit.ForLoopOp") with the given `body`. If `body` (and `qubits` and `clbits`) are *not* passed, then this acts as a context manager, which, when entered, provides a loop variable (unless one is given, in which case it will be reused) and will automatically build a [`ForLoopOp`](qiskit.circuit.ForLoopOp "qiskit.circuit.ForLoopOp") when the scope finishes. In this form, you do not need to keep track of the qubits or clbits you are using, because the scope will handle it for you. + +For example: + +```python +from qiskit import QuantumCircuit +qc = QuantumCircuit(2, 1) + +with qc.for_loop(range(5)) as i: + qc.h(0) + qc.cx(0, 1) + qc.measure(0, 0) + qc.break_loop().c_if(0, True) +``` + +**Parameters** + +* **indexset** (*Iterable\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A collection of integers to loop over. Always necessary. + +* **loop\_parameter** (*Optional\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]*) – + + The parameter used within `body` to which the values from `indexset` will be assigned. In the context-manager form, if this argument is not supplied, then a loop parameter will be allocated for you and returned as the value of the `with` statement. This will only be bound into the circuit if it is used within the body. + + If this argument is `None` in the manual form of this method, `body` will be repeated once for each of the items in `indexset` but their values will be ignored. + +* **body** (*Optional\[*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The loop body to be repeatedly executed. Omit this to use the context-manager mode. + +* **qubits** (*Optional\[Sequence\[QubitSpecifier]]*) – The circuit qubits over which the loop body should be run. Omit this to use the context-manager mode. + +* **clbits** (*Optional\[Sequence\[ClbitSpecifier]]*) – The circuit clbits over which the loop body should be run. Omit this to use the context-manager mode. + +* **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – The string label of the instruction in the circuit. + +**Returns** + +depending on the call signature, either a context manager for creating the for loop (it will automatically be added to the circuit at the end of the block), or an [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") handle to the appended loop operation. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or ForLoopContext + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + +### fredkin + + + +`fredkin(control_qubit, target_qubit1, target_qubit2)` + +Apply [`CSwapGate`](qiskit.circuit.library.CSwapGate "qiskit.circuit.library.CSwapGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.fredkin()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. Use QuantumCircuit.cswap as direct replacement. + + +**Parameters** + +* **control\_qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the control. +* **target\_qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) targeted by the gate. +* **target\_qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) targeted by the gate. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + + + QuantumCircuit.cswap: the same function with a different name. + + +### from\_instructions + + + +`static from_instructions(instructions, *, qubits=(), clbits=(), name=None, global_phase=0, metadata=None)` + +Construct a circuit from an iterable of CircuitInstructions. + +**Parameters** + +* **instructions** (*Iterable\[*[*CircuitInstruction*](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction") *|*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*] |* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*, Iterable\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]] |* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*, Iterable\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*], Iterable\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]]]*) – The instructions to add to the circuit. +* **qubits** (*Iterable\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – Any qubits to add to the circuit. This argument can be used, for example, to enforce a particular ordering of qubits. +* **clbits** (*Iterable\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – Any classical bits to add to the circuit. This argument can be used, for example, to enforce a particular ordering of classical bits. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The name of the circuit. +* **global\_phase** (*ParameterValueType*) – The global phase of the circuit in radians. +* **metadata** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Arbitrary key value metadata to associate with the circuit. + +**Returns** + +The quantum circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### from\_qasm\_file + + + +`static from_qasm_file(path)` + +Read an OpenQASM 2.0 program from a file and convert to an instance of [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Parameters** + +**path** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Path to the file for an OpenQASM 2 program + +**Returns** + +The QuantumCircuit object for the input OpenQASM 2. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + [`qasm2.load()`](qasm2#qiskit.qasm2.load "qiskit.qasm2.load"): the complete interface to the OpenQASM 2 importer. + + +### from\_qasm\_str + + + +`static from_qasm_str(qasm_str)` + +Convert a string containing an OpenQASM 2.0 program to a [`QuantumCircuit`](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Parameters** + +**qasm\_str** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A string containing an OpenQASM 2.0 program. + +**Returns** + +The QuantumCircuit object for the input OpenQASM 2 + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + + + [`qasm2.loads()`](qasm2#qiskit.qasm2.loads "qiskit.qasm2.loads"): the complete interface to the OpenQASM 2 importer. + + +### get\_instructions + + + +`get_instructions(name)` + +Get instructions matching name. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of instruction to. + +**Returns** + +list of (instruction, qargs, cargs). + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")([tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) + +### h + + + +`h(qubit)` + +Apply [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### hamiltonian + + + +`hamiltonian(operator, time, qubits, label=None)` + +Apply hamiltonian evolution to qubits. + +This gate resolves to a [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate") as $U(t) = exp(-i t H)$, which can be decomposed into basis gates if it is 2 qubits or less, or simulated directly in Aer for more qubits. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.hamiltonian()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, append a qiskit.circuit.library.HamiltonianGate to the circuit. + + +**Parameters** + +* **operator** (*matrix or* [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – a hermitian operator. +* **time** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *or*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")) – time evolution parameter. +* **qubits** (*Union\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, Tuple\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – The circuit qubits to apply the transformation to. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – unitary name for backend \[Default: None]. + +**Returns** + +The quantum circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### has\_calibration\_for + + + +`has_calibration_for(instruction)` + +Return True if the circuit has a calibration defined for the instruction context. In this case, the operation does not need to be translated to the device basis. + +### has\_register + + + +`has_register(register)` + +Test if this circuit has the register r. + +**Parameters** + +**register** ([*Register*](qiskit.circuit.Register "qiskit.circuit.Register")) – a quantum or classical register. + +**Returns** + +True if the register is contained in this circuit. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### i + + + +`i(qubit)` + +Apply [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.i()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. Use QuantumCircuit.id as direct replacement. + + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### id + + + +`id(qubit)` + +Apply [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### if\_else + + + +`if_else(condition, true_body, false_body, qubits, clbits, label=None)` + +Apply [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp"). + + + This method does not have an associated context-manager form, because it is already handled by the [`if_test()`](#qiskit.circuit.QuantumCircuit.if_test "qiskit.circuit.QuantumCircuit.if_test") method. You can use the `else` part of that with something such as: + + ```python + from qiskit.circuit import QuantumCircuit, Qubit, Clbit + bits = [Qubit(), Qubit(), Clbit()] + qc = QuantumCircuit(bits) + qc.h(0) + qc.cx(0, 1) + qc.measure(0, 0) + with qc.if_test((bits[2], 0)) as else_: + qc.h(0) + with else_: + qc.x(0) + ``` + + +**Parameters** + +* **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*,* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*]*) – A condition to be evaluated at circuit runtime which, if true, will trigger the evaluation of `true_body`. Can be specified as either a tuple of a `ClassicalRegister` to be tested for equality with a given `int`, or as a tuple of a `Clbit` to be compared to either a `bool` or an `int`. +* **true\_body** ([*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The circuit body to be run if `condition` is true. +* **false\_body** ([*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The circuit to be run if `condition` is false. +* **qubits** (*Sequence\[QubitSpecifier]*) – The circuit qubits over which the if/else should be run. +* **clbits** (*Sequence\[ClbitSpecifier]*) – The circuit clbits over which the if/else should be run. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the instruction in the circuit. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the provided condition references Clbits outside the enclosing circuit. + +**Returns** + +A handle to the instruction created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### if\_test + +### if\_test + + + +`if_test(condition: tuple[ClassicalRegister | Clbit, int], true_body: None, qubits: None, clbits: None, *, label: str | None) → qiskit.circuit.controlflow.if_else.IfContext` + + + +`if_test(condition: tuple[ClassicalRegister | Clbit, int], true_body: QuantumCircuit, qubits: Sequence[Qubit | QuantumRegister | int | slice | Sequence[Qubit | int]], clbits: Sequence[Clbit | ClassicalRegister | int | slice | Sequence[Clbit | int]], *, label: str | None = None) → InstructionSet` + +Create an `if` statement on this circuit. + +There are two forms for calling this function. If called with all its arguments (with the possible exception of `label`), it will create a [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp") with the given `true_body`, and there will be no branch for the `false` condition (see also the [`if_else()`](#qiskit.circuit.QuantumCircuit.if_else "qiskit.circuit.QuantumCircuit.if_else") method). However, if `true_body` (and `qubits` and `clbits`) are *not* passed, then this acts as a context manager, which can be used to build `if` statements. The return value of the `with` statement is a chainable context manager, which can be used to create subsequent `else` blocks. In this form, you do not need to keep track of the qubits or clbits you are using, because the scope will handle it for you. + +For example: + +```python +from qiskit.circuit import QuantumCircuit, Qubit, Clbit +bits = [Qubit(), Qubit(), Qubit(), Clbit(), Clbit()] +qc = QuantumCircuit(bits) + +qc.h(0) +qc.cx(0, 1) +qc.measure(0, 0) +qc.h(0) +qc.cx(0, 1) +qc.measure(0, 1) + +with qc.if_test((bits[3], 0)) as else_: + qc.x(2) +with else_: + qc.h(2) + qc.z(2) +``` + +**Parameters** + +* **condition** (*Tuple\[Union\[*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*],* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A condition to be evaluated at circuit runtime which, if true, will trigger the evaluation of `true_body`. Can be specified as either a tuple of a `ClassicalRegister` to be tested for equality with a given `int`, or as a tuple of a `Clbit` to be compared to either a `bool` or an `int`. +* **true\_body** (*Optional\[*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The circuit body to be run if `condition` is true. +* **qubits** (*Optional\[Sequence\[QubitSpecifier]]*) – The circuit qubits over which the if/else should be run. +* **clbits** (*Optional\[Sequence\[ClbitSpecifier]]*) – The circuit clbits over which the if/else should be run. +* **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – The string label of the instruction in the circuit. + +**Returns** + +depending on the call signature, either a context manager for creating the `if` block (it will automatically be added to the circuit at the end of the block), or an [`InstructionSet`](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") handle to the appended conditional operation. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or IfContext + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the provided condition references Clbits outside the enclosing circuit. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + +**Returns** + +A handle to the instruction created. + +### initialize + + + +`initialize(params, qubits=None, normalize=False)` + +Initialize qubits in a specific state. + +Qubit initialization is done by first resetting the qubits to $|0\rangle$ followed by calling [`StatePreparation`](qiskit.circuit.library.StatePreparation "qiskit.circuit.library.StatePreparation") class to prepare the qubits in a specified state. Both these steps are included in the [`Initialize`](qiskit.circuit.library.Initialize "qiskit.circuit.library.Initialize") instruction. + +**Parameters** + +* **params** (*Sequence\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – + + The state to initialize to, can be either of the following. + + * Statevector or vector of complex amplitudes to initialize to. + * Labels of basis states of the Pauli eigenstates Z, X, Y. See [`Statevector.from_label()`](qiskit.quantum_info.Statevector#from_label "qiskit.quantum_info.Statevector.from_label"). Notice the order of the labels is reversed with respect to the qubit index to be applied to. Example label ‘01’ initializes the qubit zero to $|1\rangle$ and the qubit one to $|0\rangle$. + * An integer that is used as a bitmap indicating which qubits to initialize to $|1\rangle$. Example: setting params to 5 would initialize qubit 0 and qubit 2 to $|1\rangle$ and qubit 1 to $|0\rangle$. + +* **qubits** (*Sequence\[QubitSpecifier] | None*) – Qubits to initialize. If `None` the initialization is applied to all qubits in the circuit. + +* **normalize** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to normalize an input array to a unit vector. + +**Returns** + +A handle to the instructions created. + +**Examples** + +Prepare a qubit in the state $(|0\rangle - |1\rangle) / \sqrt{2}$. + +```python +import numpy as np +from qiskit import QuantumCircuit + +circuit = QuantumCircuit(1) +circuit.initialize([1/np.sqrt(2), -1/np.sqrt(2)], 0) +circuit.draw() +``` + +output: + +```python + ┌──────────────────────────────┐ +q_0: ┤ Initialize(0.70711,-0.70711) ├ + └──────────────────────────────┘ +``` + +Initialize from a string two qubits in the state $|10\rangle$. The order of the labels is reversed with respect to qubit index. More information about labels for basis states are in [`Statevector.from_label()`](qiskit.quantum_info.Statevector#from_label "qiskit.quantum_info.Statevector.from_label"). + +```python +import numpy as np +from qiskit import QuantumCircuit + +circuit = QuantumCircuit(2) +circuit.initialize('01', circuit.qubits) +circuit.draw() +``` + +output: + +```python + ┌──────────────────┐ +q_0: ┤0 ├ + │ Initialize(0,1) │ +q_1: ┤1 ├ + └──────────────────┘ +``` + +Initialize two qubits from an array of complex amplitudes. + +```python +import numpy as np +from qiskit import QuantumCircuit + +circuit = QuantumCircuit(2) +circuit.initialize([0, 1/np.sqrt(2), -1.j/np.sqrt(2), 0], circuit.qubits) +circuit.draw() +``` + +output: + +```python + ┌────────────────────────────────────┐ +q_0: ┤0 ├ + │ Initialize(0,0.70711,-0.70711j,0) │ +q_1: ┤1 ├ + └────────────────────────────────────┘ +``` + +### inverse + + + +`inverse()` + +Invert (take adjoint of) this circuit. + +This is done by recursively inverting all gates. + +**Returns** + +the inverted circuit + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the circuit cannot be inverted. + +**Examples** + +input: + +```python + ┌───┐ +q_0: ┤ H ├─────■────── + └───┘┌────┴─────┐ +q_1: ─────┤ RX(1.57) ├ + └──────────┘ +``` + +output: + +```python + ┌───┐ +q_0: ──────■──────┤ H ├ + ┌─────┴─────┐└───┘ +q_1: ┤ RX(-1.57) ├───── + └───────────┘ +``` + +### iso + + + +`iso(isometry, q_input, q_ancillas_for_output, q_ancillas_zero=None, q_ancillas_dirty=None, epsilon=1e-10)` + +Attach an arbitrary isometry from m to n qubits to a circuit. In particular, this allows to attach arbitrary unitaries on n qubits (m=n) or to prepare any state on n qubits (m=0). The decomposition used here was introduced by Iten et al. in [https://arxiv.org/abs/1501.06911](https://arxiv.org/abs/1501.06911). + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.iso()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, append a qiskit.circuit.library.Isometry to the circuit. + + +**Parameters** + +* **isometry** (*ndarray*) – an isometry from m to n qubits, i.e., a (complex) ndarray of dimension 2^n×2^m with orthonormal columns (given in the computational basis specified by the order of the ancillas and the input qubits, where the ancillas are considered to be more significant than the input qubits.). +* **q\_input** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of m qubits where the input to the isometry is fed in (empty list for state preparation). +* **q\_ancillas\_for\_output** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of n-m ancilla qubits that are used for the output of the isometry and which are assumed to start in the zero state. The qubits are listed with increasing significance. +* **q\_ancillas\_zero** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of ancilla qubits which are assumed to start in the zero state. Default is q\_ancillas\_zero = None. +* **q\_ancillas\_dirty** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of ancilla qubits which can start in an arbitrary state. Default is q\_ancillas\_dirty = None. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – error tolerance of calculations. Default is epsilon = \_EPS. + +**Returns** + +the isometry is attached to the quantum circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the array is not an isometry of the correct size corresponding to the provided number of qubits. + +### isometry + + + +`isometry(isometry, q_input, q_ancillas_for_output, q_ancillas_zero=None, q_ancillas_dirty=None, epsilon=1e-10)` + +Attach an arbitrary isometry from m to n qubits to a circuit. In particular, this allows to attach arbitrary unitaries on n qubits (m=n) or to prepare any state on n qubits (m=0). The decomposition used here was introduced by Iten et al. in [https://arxiv.org/abs/1501.06911](https://arxiv.org/abs/1501.06911). + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.iso()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, append a qiskit.circuit.library.Isometry to the circuit. + + +**Parameters** + +* **isometry** (*ndarray*) – an isometry from m to n qubits, i.e., a (complex) ndarray of dimension 2^n×2^m with orthonormal columns (given in the computational basis specified by the order of the ancillas and the input qubits, where the ancillas are considered to be more significant than the input qubits.). +* **q\_input** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of m qubits where the input to the isometry is fed in (empty list for state preparation). +* **q\_ancillas\_for\_output** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of n-m ancilla qubits that are used for the output of the isometry and which are assumed to start in the zero state. The qubits are listed with increasing significance. +* **q\_ancillas\_zero** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of ancilla qubits which are assumed to start in the zero state. Default is q\_ancillas\_zero = None. +* **q\_ancillas\_dirty** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of ancilla qubits which can start in an arbitrary state. Default is q\_ancillas\_dirty = None. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – error tolerance of calculations. Default is epsilon = \_EPS. + +**Returns** + +the isometry is attached to the quantum circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the array is not an isometry of the correct size corresponding to the provided number of qubits. + +### iswap + + + +`iswap(qubit1, qubit2)` + +Apply [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### mcp + + + +`mcp(lam, control_qubits, target_qubit)` + +Apply [`MCPhaseGate`](qiskit.circuit.library.MCPhaseGate "qiskit.circuit.library.MCPhaseGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **lam** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The angle of the rotation. +* **control\_qubits** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – The qubits used as the controls. +* **target\_qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) targeted by the gate. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### mcrx + + + +`mcrx(theta, q_controls, q_target, use_basis_gates=False)` + +Apply Multiple-Controlled X rotation gate + +**Parameters** + +* **self** ([*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The QuantumCircuit object to apply the mcrx gate on. +* **theta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – angle theta +* **q\_controls** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits +* **q\_target** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The target qubit +* **use\_basis\_gates** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – use p, u, cx + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors + +### mcry + + + +`mcry(theta, q_controls, q_target, q_ancillae=None, mode=None, use_basis_gates=False)` + +Apply Multiple-Controlled Y rotation gate + +**Parameters** + +* **self** ([*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The QuantumCircuit object to apply the mcry gate on. +* **theta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – angle theta +* **q\_controls** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits +* **q\_target** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The target qubit +* **q\_ancillae** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*(*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*)*) – The list of ancillary qubits. +* **mode** (*string*) – The implementation mode to use +* **use\_basis\_gates** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – use p, u, cx + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors + +### mcrz + + + +`mcrz(lam, q_controls, q_target, use_basis_gates=False)` + +Apply Multiple-Controlled Z rotation gate + +**Parameters** + +* **self** ([*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The QuantumCircuit object to apply the mcrz gate on. +* **lam** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – angle lambda +* **q\_controls** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*)*) – The list of control qubits +* **q\_target** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The target qubit +* **use\_basis\_gates** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – use p, u, cx + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – parameter errors + +### mct + + + +`mct(control_qubits, target_qubit, ancilla_qubits=None, mode='noancilla')` + +Apply [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.MCXGate"). + +The multi-cX gate can be implemented using different techniques, which use different numbers of ancilla qubits and have varying circuit depth. These modes are: + +* `'noancilla'`: Requires 0 ancilla qubits. +* `'recursion'`: Requires 1 ancilla qubit if more than 4 controls are used, otherwise 0. +* `'v-chain'`: Requires 2 less ancillas than the number of control qubits. +* `'v-chain-dirty'`: Same as for the clean ancillas (but the circuit will be longer). + +For the full matrix form of this gate, see the underlying gate documentation. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.mct()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. Use QuantumCircuit.mcx as direct replacement. + + +**Parameters** + +* **control\_qubits** (*Sequence\[QubitSpecifier]*) – The qubits used as the controls. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **ancilla\_qubits** (*QubitSpecifier | Sequence\[QubitSpecifier] | None*) – The qubits used as the ancillae, if the mode requires them. +* **mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The choice of mode, explained further above. + +**Returns** + +A handle to the instructions created. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if the given mode is not known, or if too few ancilla qubits are passed. +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – if no ancilla qubits are passed, but some are needed. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + + + QuantumCircuit.mcx: the same gate with a different name. + + +### mcx + + + +`mcx(control_qubits, target_qubit, ancilla_qubits=None, mode='noancilla')` + +Apply [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.MCXGate"). + +The multi-cX gate can be implemented using different techniques, which use different numbers of ancilla qubits and have varying circuit depth. These modes are: + +* `'noancilla'`: Requires 0 ancilla qubits. +* `'recursion'`: Requires 1 ancilla qubit if more than 4 controls are used, otherwise 0. +* `'v-chain'`: Requires 2 less ancillas than the number of control qubits. +* `'v-chain-dirty'`: Same as for the clean ancillas (but the circuit will be longer). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubits** (*Sequence\[QubitSpecifier]*) – The qubits used as the controls. +* **target\_qubit** (*QubitSpecifier*) – The qubit(s) targeted by the gate. +* **ancilla\_qubits** (*QubitSpecifier | Sequence\[QubitSpecifier] | None*) – The qubits used as the ancillae, if the mode requires them. +* **mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The choice of mode, explained further above. + +**Returns** + +A handle to the instructions created. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if the given mode is not known, or if too few ancilla qubits are passed. +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – if no ancilla qubits are passed, but some are needed. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### measure + + + +`measure(qubit, cbit)` + +Measure a quantum bit (`qubit`) in the Z basis into a classical bit (`cbit`). + +When a quantum state is measured, a qubit is projected in the computational (Pauli Z) basis to either $\lvert 0 \rangle$ or $\lvert 1 \rangle$. The classical bit `cbit` indicates the result of that projection as a `0` or a `1` respectively. This operation is non-reversible. + +**Parameters** + +* **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – qubit(s) to measure. +* **cbit** ([*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.classicalregister.Clbit") *|*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.classicalregister.ClassicalRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.classicalregister.Clbit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – classical bit(s) to place the measurement result(s) in. + +**Returns** + +handle to the added instructions. + +**Return type** + +[qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if arguments have bad format. + +**Examples** + +In this example, a qubit is measured and the result of that measurement is stored in the classical bit (usually expressed in diagrams as a double line): + +```python +from qiskit import QuantumCircuit +circuit = QuantumCircuit(1, 1) +circuit.h(0) +circuit.measure(0, 0) +circuit.draw() +``` + +```python + ┌───┐┌─┐ + q: ┤ H ├┤M├ + └───┘└╥┘ +c: 1/══════╩═ + 0 +``` + +It is possible to call `measure` with lists of `qubits` and `cbits` as a shortcut for one-to-one measurement. These two forms produce identical results: + +```python +circuit = QuantumCircuit(2, 2) +circuit.measure([0,1], [0,1]) +``` + +```python +circuit = QuantumCircuit(2, 2) +circuit.measure(0, 0) +circuit.measure(1, 1) +``` + +Instead of lists, you can use [`QuantumRegister`](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") and [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") under the same logic. + +```python +from qiskit import QuantumCircuit, QuantumRegister, ClassicalRegister +qreg = QuantumRegister(2, "qreg") +creg = ClassicalRegister(2, "creg") +circuit = QuantumCircuit(qreg, creg) +circuit.measure(qreg, creg) +``` + +This is equivalent to: + +```python +circuit = QuantumCircuit(qreg, creg) +circuit.measure(qreg[0], creg[0]) +circuit.measure(qreg[1], creg[1]) +``` + +### measure\_active + + + +`measure_active(inplace=True)` + +Adds measurement to all non-idle qubits. Creates a new ClassicalRegister with a size equal to the number of non-idle qubits being measured. + +Returns a new circuit with measurements if inplace=False. + +**Parameters** + +**inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements inplace or return new circuit. + +**Returns** + +Returns circuit with measurements when inplace = False. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### measure\_all + + + +`measure_all(inplace=True, add_bits=True)` + +Adds measurement to all qubits. + +By default, adds new classical bits in a [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") to store these measurements. If `add_bits=False`, the results of the measurements will instead be stored in the already existing classical bits, with qubit `n` being measured into classical bit `n`. + +Returns a new circuit with measurements if `inplace=False`. + +**Parameters** + +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements inplace or return new circuit. +* **add\_bits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to add new bits to store the results. + +**Returns** + +Returns circuit with measurements when `inplace=False`. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `add_bits=False` but there are not enough classical bits. + +### ms + + + +`ms(theta, qubits)` + +Apply [`MSGate`](qiskit.circuit.library.MSGate "qiskit.circuit.library.MSGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The angle of the rotation. +* **qubits** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – The qubits to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### num\_connected\_components + + + +`num_connected_components(unitary_only=False)` + +How many non-entangled subcircuits can the circuit be factored to. + +**Parameters** + +**unitary\_only** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Compute only unitary part of graph. + +**Returns** + +Number of connected components in circuit. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### num\_nonlocal\_gates + + + +`num_nonlocal_gates()` + +Return number of non-local gates (i.e. involving 2+ qubits). + +Conditional nonlocal gates are also included. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### num\_tensor\_factors + + + +`num_tensor_factors()` + +Computes the number of tensor factors in the unitary (quantum) part of the circuit only. + +**Notes** + +This is here for backwards compatibility, and will be removed in a future release of Qiskit. You should call num\_unitary\_factors instead. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### num\_unitary\_factors + + + +`num_unitary_factors()` + +Computes the number of tensor factors in the unitary (quantum) part of the circuit only. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### p + + + +`p(theta, qubit)` + +Apply [`PhaseGate`](qiskit.circuit.library.PhaseGate "qiskit.circuit.library.PhaseGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – THe angle of the rotation. +* **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### pauli + + + +`pauli(pauli_string, qubits)` + +Apply [`PauliGate`](qiskit.circuit.library.PauliGate "qiskit.circuit.library.PauliGate"). + +**Parameters** + +* **pauli\_string** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A string representing the Pauli operator to apply, e.g. ‘XX’. +* **qubits** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – The qubits to apply this gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### power + + + +`power(power, matrix_power=False)` + +Raise this circuit to the power of `power`. + +If `power` is a positive integer and `matrix_power` is `False`, this implementation defaults to calling `repeat`. Otherwise, if the circuit is unitary, the matrix is computed to calculate the matrix power. + +**Parameters** + +* **power** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The power to raise this circuit to. +* **matrix\_power** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, the circuit is converted to a matrix and then the matrix power is computed. If False, and `power` is a positive integer, the implementation defaults to `repeat`. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the circuit needs to be converted to a gate but it is not unitary. + +**Returns** + +A circuit implementing this circuit raised to the power of `power`. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### prepare\_state + + + +`prepare_state(state, qubits=None, label=None, normalize=False)` + +Prepare qubits in a specific state. + +This class implements a state preparing unitary. Unlike [`Initialize`](qiskit.circuit.library.Initialize "qiskit.circuit.library.Initialize") it does not reset the qubits first. + +**Parameters** + +* **state** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")) – + + * Statevector: Statevector to initialize to. + * str: labels of basis states of the Pauli eigenstates Z, X, Y. See [`Statevector.from_label()`](qiskit.quantum_info.Statevector#from_label "qiskit.quantum_info.Statevector.from_label"). Notice the order of the labels is reversed with respect to the qubit index to be applied to. Example label ‘01’ initializes the qubit zero to $|1\rangle$ and the qubit one to $|0\rangle$. + * list: vector of complex amplitudes to initialize to. + * int: an integer that is used as a bitmap indicating which qubits to initialize to $|1\rangle$. Example: setting params to 5 would initialize qubit 0 and qubit 2 to $|1\rangle$ and qubit 1 to $|0\rangle$. + +* **qubits** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – + + * QuantumRegister: A list of qubits to be initialized \[Default: None]. + * Qubit: Single qubit to be initialized \[Default: None]. + * int: Index of qubit to be initialized \[Default: None]. + * list: Indexes of qubits to be initialized \[Default: None]. + +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional label for the gate + +* **normalize** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to normalize an input array to a unit vector. + +**Returns** + +a handle to the instruction that was just initialized + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Examples** + +Prepare a qubit in the state $(|0\rangle - |1\rangle) / \sqrt{2}$. + +```python +import numpy as np +from qiskit import QuantumCircuit + +circuit = QuantumCircuit(1) +circuit.prepare_state([1/np.sqrt(2), -1/np.sqrt(2)], 0) +circuit.draw() +``` + +output: + +```python + ┌─────────────────────────────────────┐ +q_0: ┤ State Preparation(0.70711,-0.70711) ├ + └─────────────────────────────────────┘ +``` + +Prepare from a string two qubits in the state $|10\rangle$. The order of the labels is reversed with respect to qubit index. More information about labels for basis states are in [`Statevector.from_label()`](qiskit.quantum_info.Statevector#from_label "qiskit.quantum_info.Statevector.from_label"). + +```python +import numpy as np +from qiskit import QuantumCircuit + +circuit = QuantumCircuit(2) +circuit.prepare_state('01', circuit.qubits) +circuit.draw() +``` + +output: + +```python + ┌─────────────────────────┐ +q_0: ┤0 ├ + │ State Preparation(0,1) │ +q_1: ┤1 ├ + └─────────────────────────┘ +``` + +Initialize two qubits from an array of complex amplitudes .. code-block: + +```python +import numpy as np +from qiskit import QuantumCircuit + +circuit = QuantumCircuit(2) +circuit.prepare_state([0, 1/np.sqrt(2), -1.j/np.sqrt(2), 0], circuit.qubits) +circuit.draw() +``` + +output: + +```python + ┌───────────────────────────────────────────┐ +q_0: ┤0 ├ + │ State Preparation(0,0.70711,-0.70711j,0) │ +q_1: ┤1 ├ + └───────────────────────────────────────────┘ +``` + +### qasm + + + +`qasm(formatted=False, filename=None, encoding=None)` + +Return OpenQASM 2.0 string. + + + **[`qasm2.dump()`](qasm2#qiskit.qasm2.dump "qiskit.qasm2.dump") and [`qasm2.dumps()`](qasm2#qiskit.qasm2.dumps "qiskit.qasm2.dumps")** + + The preferred entry points to the OpenQASM 2 export capabilities. These match the interface for other serialisers in Qiskit. + + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.qasm()` is deprecated as of qiskit 0.46. It will be removed in the 1.0.0 release. Instead use the qiskit.qasm2.dump() or qiskit.qasm2.dumps() function + + +**Parameters** + +* **formatted** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Return formatted OpenQASM 2.0 string. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Save OpenQASM 2.0 to file with name ‘filename’. +* **encoding** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optionally specify the encoding to use for the output file if `filename` is specified. By default this is set to the system’s default encoding (ie whatever `locale.getpreferredencoding()` returns) and can be set to any valid codec or alias from stdlib’s [codec module](https://docs.python.org/3/library/codecs.html#standard-encodings) + +**Returns** + +If formatted=False. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – If pygments is not installed and `formatted` is `True`. +* [**QASM2ExportError**](qasm2#qiskit.qasm2.QASM2ExportError "qiskit.qasm2.QASM2ExportError") – If circuit has free parameters. +* [**QASM2ExportError**](qasm2#qiskit.qasm2.QASM2ExportError "qiskit.qasm2.QASM2ExportError") – If an operation that has no OpenQASM 2 representation is encountered. + +### qbit\_argument\_conversion + + + +`qbit_argument_conversion(qubit_representation)` + +Converts several qubit representations (such as indexes, range, etc.) into a list of qubits. + +**Parameters** + +**qubit\_representation** (*Object*) – representation to expand + +**Returns** + +the resolved instances of the qubits. + +**Return type** + +List([Qubit](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) + +### qubit\_duration + + + +`qubit_duration(*qubits)` + +Return the duration between the start and stop time of the first and last instructions, excluding delays, over the supplied qubits. Its time unit is `self.unit`. + +**Parameters** + +**\*qubits** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubits within `self` to include. + +**Returns** + +Return the duration between the first start and last stop time of non-delay instructions + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### qubit\_start\_time + + + +`qubit_start_time(*qubits)` + +Return the start time of the first instruction, excluding delays, over the supplied qubits. Its time unit is `self.unit`. + +Return 0 if there are no instructions over qubits + +**Parameters** + +* **\*qubits** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubits within `self` to include. Integers are allowed for qubits, indicating +* **self.qubits.** (*indices of*) – + +**Returns** + +Return the start time of the first instruction, excluding delays, over the qubits + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `self` is a not-yet scheduled circuit. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### qubit\_stop\_time + + + +`qubit_stop_time(*qubits)` + +Return the stop time of the last instruction, excluding delays, over the supplied qubits. Its time unit is `self.unit`. + +Return 0 if there are no instructions over qubits + +**Parameters** + +* **\*qubits** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubits within `self` to include. Integers are allowed for qubits, indicating +* **self.qubits.** (*indices of*) – + +**Returns** + +Return the stop time of the last instruction, excluding delays, over the qubits + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `self` is a not-yet scheduled circuit. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### r + + + +`r(theta, phi, qubit)` + +Apply [`RGate`](qiskit.circuit.library.RGate "qiskit.circuit.library.RGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The angle of the rotation. +* **phi** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The angle of the axis of rotation in the x-y plane. +* **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### rcccx + + + +`rcccx(control_qubit1, control_qubit2, control_qubit3, target_qubit)` + +Apply [`RC3XGate`](qiskit.circuit.library.RC3XGate "qiskit.circuit.library.RC3XGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the first control. +* **control\_qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the second control. +* **control\_qubit3** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the third control. +* **target\_qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) targeted by the gate. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### rccx + + + +`rccx(control_qubit1, control_qubit2, target_qubit)` + +Apply [`RCCXGate`](qiskit.circuit.library.RCCXGate "qiskit.circuit.library.RCCXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **control\_qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the first control. +* **control\_qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the second control. +* **target\_qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) targeted by the gate. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### remove\_final\_measurements + + + +`remove_final_measurements(inplace=True)` + +Removes final measurements and barriers on all qubits if they are present. Deletes the classical registers that were used to store the values from these measurements that become idle as a result of this operation, and deletes classical bits that are referenced only by removed registers, or that aren’t referenced at all but have become idle as a result of this operation. + +Measurements and barriers are considered final if they are followed by no other operations (aside from other measurements or barriers.) + +**Parameters** + +**inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – All measurements removed inplace or return new circuit. + +**Returns** + +Returns the resulting circuit when `inplace=False`, else None. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### repeat + + + +`repeat(reps)` + +Repeat this circuit `reps` times. + +**Parameters** + +**reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – How often this circuit should be repeated. + +**Returns** + +A circuit containing `reps` repetitions of this circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### reset + + + +`reset(qubit)` + +Reset the quantum bit(s) to their default state. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – qubit(s) to reset. + +**Returns** + +handle to the added instruction. + +**Return type** + +[qiskit.circuit.InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### reverse\_bits + + + +`reverse_bits()` + +Return a circuit with the opposite order of wires. + +The circuit is “vertically” flipped. If a circuit is defined over multiple registers, the resulting circuit will have the same registers but with their order flipped. + +This method is useful for converting a circuit written in little-endian convention to the big-endian equivalent, and vice versa. + +**Returns** + +the circuit with reversed bit order. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Examples** + +input: + +```python + ┌───┐ +a_0: ┤ H ├──■───────────────── + └───┘┌─┴─┐ +a_1: ─────┤ X ├──■──────────── + └───┘┌─┴─┐ +a_2: ──────────┤ X ├──■─────── + └───┘┌─┴─┐ +b_0: ───────────────┤ X ├──■── + └───┘┌─┴─┐ +b_1: ────────────────────┤ X ├ + └───┘ +``` + +output: + +```python + ┌───┐ +b_0: ────────────────────┤ X ├ + ┌───┐└─┬─┘ +b_1: ───────────────┤ X ├──■── + ┌───┐└─┬─┘ +a_0: ──────────┤ X ├──■─────── + ┌───┐└─┬─┘ +a_1: ─────┤ X ├──■──────────── + ┌───┐└─┬─┘ +a_2: ┤ H ├──■───────────────── + └───┘ +``` + +### reverse\_ops + + + +`reverse_ops()` + +Reverse the circuit by reversing the order of instructions. + +This is done by recursively reversing all instructions. It does not invert (adjoint) any gate. + +**Returns** + +the reversed circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Examples** + +input: + +```python + ┌───┐ +q_0: ┤ H ├─────■────── + └───┘┌────┴─────┐ +q_1: ─────┤ RX(1.57) ├ + └──────────┘ +``` + +output: + +```python + ┌───┐ +q_0: ─────■──────┤ H ├ + ┌────┴─────┐└───┘ +q_1: ┤ RX(1.57) ├───── + └──────────┘ +``` + +### rv + + + +`rv(vx, vy, vz, qubit)` + +Apply [`RVGate`](qiskit.circuit.library.RVGate "qiskit.circuit.library.RVGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +Rotation around an arbitrary rotation axis $v$, where $|v|$ is the angle of rotation in radians. + +**Parameters** + +* **vx** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – x-component of the rotation axis. +* **vy** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – y-component of the rotation axis. +* **vz** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – z-component of the rotation axis. +* **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### rx + + + +`rx(theta, qubit, label=None)` + +Apply [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** (*ParameterValueType*) – The rotation angle of the gate. +* **qubit** (*QubitSpecifier*) – The qubit(s) to apply the gate to. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### rxx + + + +`rxx(theta, qubit1, qubit2)` + +Apply [`RXXGate`](qiskit.circuit.library.RXXGate "qiskit.circuit.library.RXXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The angle of the rotation. +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### ry + + + +`ry(theta, qubit, label=None)` + +Apply [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** (*ParameterValueType*) – The rotation angle of the gate. +* **qubit** (*QubitSpecifier*) – The qubit(s) to apply the gate to. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### ryy + + + +`ryy(theta, qubit1, qubit2)` + +Apply [`RYYGate`](qiskit.circuit.library.RYYGate "qiskit.circuit.library.RYYGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The rotation angle of the gate. +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### rz + + + +`rz(phi, qubit)` + +Apply [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **phi** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The rotation angle of the gate. +* **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### rzx + + + +`rzx(theta, qubit1, qubit2)` + +Apply [`RZXGate`](qiskit.circuit.library.RZXGate "qiskit.circuit.library.RZXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The rotation angle of the gate. +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### rzz + + + +`rzz(theta, qubit1, qubit2)` + +Apply [`RZZGate`](qiskit.circuit.library.RZZGate "qiskit.circuit.library.RZZGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The rotation angle of the gate. +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### s + + + +`s(qubit)` + +Apply [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### sdg + + + +`sdg(qubit)` + +Apply [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### size + + + +`size(filter_function=>)` + +Returns total number of instructions in circuit. + +**Parameters** + +**filter\_function** (*callable*) – a function to filter out some instructions. Should take as input a tuple of (Instruction, list(Qubit), list(Clbit)). By default filters out “directives”, such as barrier or snapshot. + +**Returns** + +Total number of gate operations. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### snapshot + + + +`snapshot(label, snapshot_type='statevector', qubits=None, params=None)` + +Take a statevector snapshot of the internal simulator representation. Works on all qubits, and prevents reordering (like barrier). + +For other types of snapshots use the Snapshot extension directly. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.snapshot()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. The Snapshot instruction has been superseded by Qiskit Aer’s save instructions, see [https://qiskit.org/ecosystem/aer/apidocs/aer\_library.html#saving-simulator-data](https://qiskit.org/ecosystem/aer/apidocs/aer_library.html#saving-simulator-data). + + +**Parameters** + +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a snapshot label to report the result. +* **snapshot\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the type of the snapshot. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – the qubits to apply snapshot to \[Default: None]. +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – the parameters for snapshot\_type \[Default: None]. + +**Returns** + +with attached command + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**ExtensionError**](extensions#qiskit.extensions.ExtensionError "qiskit.extensions.ExtensionError") – malformed command + +### squ + + + +`squ(unitary_matrix, qubit, mode='ZYZ', up_to_diagonal=False)` + +Decompose an arbitrary 2\*2 unitary into three rotation gates. + +Note that the decomposition is up to a global phase shift. (This is a well known decomposition which can be found for example in Nielsen and Chuang’s book “Quantum computation and quantum information”.) + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.squ()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. Instead, use the QuantumCircuit.unitary method. + + +**Parameters** + +* **unitary\_matrix** (*ndarray*) – 2\*2 unitary (given as a (complex) ndarray). +* **qubit** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *or*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The qubit which the gate is acting on. +* **mode** (*string*) – determines the used decomposition by providing the rotation axes. The allowed modes are: “ZYZ” (default) +* **up\_to\_diagonal** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if set to True, the single-qubit unitary is decomposed up to a diagonal matrix, i.e. a unitary u’ is implemented such that there exists a 2\*2 diagonal gate d with u = d.dot(u’) + +**Returns** + +The single-qubit unitary instruction attached to the circuit. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the format is wrong; if the array u is not unitary + +### swap + + + +`swap(qubit1, qubit2)` + +Apply [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits to apply the gate to. +* **qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### switch + +### switch + + + +`switch(target: Clbit | ClassicalRegister | int | slice | Sequence[Clbit | int], cases: None, qubits: None, clbits: None, *, label: str | None) → qiskit.circuit.controlflow.switch_case.SwitchContext` + + + +`switch(target: Clbit | ClassicalRegister | int | slice | Sequence[Clbit | int], cases: Iterable[Tuple[Any, QuantumCircuit]], qubits: Sequence[Qubit | QuantumRegister | int | slice | Sequence[Qubit | int]], clbits: Sequence[Clbit | ClassicalRegister | int | slice | Sequence[Clbit | int]], *, label: str | None) → InstructionSet` + +Create a `switch`/`case` structure on this circuit. + +There are two forms for calling this function. If called with all its arguments (with the possible exception of `label`), it will create a [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") with the given case structure. If `cases` (and `qubits` and `clbits`) are *not* passed, then this acts as a context manager, which will automatically build a [`SwitchCaseOp`](qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") when the scope finishes. In this form, you do not need to keep track of the qubits or clbits you are using, because the scope will handle it for you. + +Example usage: + +```python +from qiskit.circuit import QuantumCircuit, ClassicalRegister, QuantumRegister +qreg = QuantumRegister(3) +creg = ClassicalRegister(3) +qc = QuantumCircuit(qreg, creg) +qc.h([0, 1, 2]) +qc.measure([0, 1, 2], [0, 1, 2]) + +with qc.switch(creg) as case: + with case(0): + qc.x(0) + with case(1, 2): + qc.z(1) + with case(case.DEFAULT): + qc.cx(0, 1) +``` + +**Parameters** + +* **target** (*Union\[*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – The classical value to switch one. This must be integer-like. +* **cases** (*Iterable\[Tuple\[*[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*,* [*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]]*) – A sequence of case specifiers. Each tuple defines one case body (the second item). The first item of the tuple can be either a single integer value, the special value [`CASE_DEFAULT`](circuit#qiskit.circuit.CASE_DEFAULT "qiskit.circuit.CASE_DEFAULT"), or a tuple of several integer values. Each of the integer values will be tried in turn; control will then pass to the body corresponding to the first match. [`CASE_DEFAULT`](circuit#qiskit.circuit.CASE_DEFAULT "qiskit.circuit.CASE_DEFAULT") matches all possible values. Omit in context-manager form. +* **qubits** (*Sequence\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – The circuit qubits over which all case bodies execute. Omit in context-manager form. +* **clbits** (*Sequence\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – The circuit clbits over which all case bodies execute. Omit in context-manager form. +* **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – The string label of the instruction in the circuit. + +**Returns** + +If used in context-manager mode, then this should be used as a `with` resource, which will return an object that can be repeatedly entered to produce cases for the switch statement. If the full form is used, then this returns a handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or SwitchCaseContext + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + +### sx + + + +`sx(qubit)` + +Apply [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### sxdg + + + +`sxdg(qubit)` + +Apply [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### t + + + +`t(qubit)` + +Apply [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### tdg + + + +`tdg(qubit)` + +Apply [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### tensor + + + +`tensor(other, inplace=False)` + +Tensor `self` with `other`. + +Remember that in the little-endian convention the leftmost operation will be at the bottom of the circuit. See also [the docs](https://docs.quantum-computing.ibm.com/build/circuit-construction) for more information. + +```python + ┌────────┐ ┌─────┐ ┌─────┐ +q_0: ┤ bottom ├ ⊗ q_0: ┤ top ├ = q_0: ─┤ top ├── + └────────┘ └─────┘ ┌┴─────┴─┐ + q_1: ┤ bottom ├ + └────────┘ +``` + +**Parameters** + +* **other** ([*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The other circuit to tensor this circuit with. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, modify the object. Otherwise return composed circuit. + +**Return type** + +[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") | None + +**Examples** + +```python +from qiskit import QuantumCircuit +top = QuantumCircuit(1) +top.x(0); +bottom = QuantumCircuit(2) +bottom.cry(0.2, 0, 1); +tensored = bottom.tensor(top) +tensored.draw('mpl') +``` + +![../\_images/qiskit-circuit-QuantumCircuit-6.png](/images/api/qiskit/0.46/qiskit-circuit-QuantumCircuit-6.png) + +**Returns** + +The tensored circuit (returns None if inplace==True). + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### to\_gate + + + +`to_gate(parameter_map=None, label=None)` + +Create a Gate out of this circuit. + +**Parameters** + +* **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – For parameterized circuits, a mapping from parameters in the circuit to parameters to be used in the gate. If None, existing circuit parameters will also parameterize the gate. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional gate label. + +**Returns** + +a composite gate encapsulating this circuit (can be decomposed back) + +**Return type** + +[Gate](qiskit.circuit.Gate "qiskit.circuit.Gate") + +### to\_instruction + + + +`to_instruction(parameter_map=None, label=None)` + +Create an Instruction out of this circuit. + +**Parameters** + +* **parameter\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – For parameterized circuits, a mapping from parameters in the circuit to parameters to be used in the instruction. If None, existing circuit parameters will also parameterize the instruction. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional gate label. + +**Returns** + +a composite instruction encapsulating this circuit (can be decomposed back) + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### toffoli + + + +`toffoli(control_qubit1, control_qubit2, target_qubit)` + +Apply [`CCXGate`](qiskit.circuit.library.CCXGate "qiskit.circuit.library.CCXGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.toffoli()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0.0 release. Use QuantumCircuit.ccx as direct replacement. + + +**Parameters** + +* **control\_qubit1** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the first control. +* **control\_qubit2** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) used as the second control. +* **target\_qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) targeted by the gate. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + + + QuantumCircuit.ccx: the same gate with a different name. + + +### u + + + +`u(theta, phi, lam, qubit)` + +Apply [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The $\theta$ rotation angle of the gate. +* **phi** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The $\phi$ rotation angle of the gate. +* **lam** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The $\lambda$ rotation angle of the gate. +* **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### uc + + + +`uc(gate_list, q_controls, q_target, up_to_diagonal=False)` + +Attach a uniformly controlled gates (also called multiplexed gates) to a circuit. + +The decomposition was introduced by Bergholm et al. in [https://arxiv.org/pdf/quant-ph/0410066.pdf](https://arxiv.org/pdf/quant-ph/0410066.pdf). + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.uc()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, append a qiskit.circuit.library.UCGate to the circuit. + + +**Parameters** + +* **gate\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[ndarray]*) – list of two qubit unitaries \[U\_0,…,U\_\{2^k-1}], where each single-qubit unitary U\_i is a given as a 2\*2 array +* **q\_controls** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[(*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")*,*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*)]*) – list of k control qubits. The qubits are ordered according to their significance in the computational basis. For example if q\_controls=\[q\[1],q\[2]] (with q = QuantumRegister(2)), the unitary U\_0 is performed if q\[1] and q\[2] are in the state zero, U\_1 is performed if q\[2] is in the state zero and q\[1] is in the state one, and so on +* **q\_target** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") *|*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*(*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*)*) – target qubit, where we act on with the single-qubit gates. +* **up\_to\_diagonal** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to True, the uniformly controlled gate is decomposed up to a diagonal gate, i.e. a unitary u’ is implemented such that there exists a diagonal gate d with u = d.dot(u’), where the unitary u describes the uniformly controlled gate + +**Returns** + +the uniformly controlled gate is attached to the circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the list number of control qubits does not correspond to the provided number of single-qubit unitaries; if an input is of the wrong type + +### ucrx + + + +`ucrx(angle_list, q_controls, q_target)` + +Attach a uniformly controlled (also called multiplexed) Rx rotation gate to a circuit. + +The decomposition is base on [https://arxiv.org/pdf/quant-ph/0406176.pdf](https://arxiv.org/pdf/quant-ph/0406176.pdf) by Shende et al. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.ucrx()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, append a qiskit.circuit.library.UCRXGate to the circuit. + + +**Parameters** + +* **angle\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – list of (real) rotation angles $[a_0,...,a_{2^k-1}]$ +* **q\_controls** (*Sequence\[QubitSpecifier]*) – list of k control qubits (or empty list if no controls). The control qubits are ordered according to their significance in increasing order: For example if `q_controls=[q[0],q[1]]` (with `q = QuantumRegister(2)`), the rotation `Rx(a_0)` is performed if `q[0]` and `q[1]` are in the state zero, the rotation `Rx(a_1)` is performed if `q[0]` is in the state one and `q[1]` is in the state zero, and so on +* **q\_target** (*QubitSpecifier*) – target qubit, where we act on with the single-qubit rotation gates + +**Returns** + +the uniformly controlled rotation gate is attached to the circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the list number of control qubits does not correspond to the provided number of single-qubit unitaries; if an input is of the wrong type + +### ucry + + + +`ucry(angle_list, q_controls, q_target)` + +Attach a uniformly controlled (also called multiplexed) Ry rotation gate to a circuit. + +The decomposition is base on [https://arxiv.org/pdf/quant-ph/0406176.pdf](https://arxiv.org/pdf/quant-ph/0406176.pdf) by Shende et al. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.ucry()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, append a qiskit.circuit.library.UCRYGate to the circuit. + + +**Parameters** + +* **angle\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – list of (real) rotation angles $[a_0,...,a_{2^k-1}]$ +* **q\_controls** (*Sequence\[QubitSpecifier]*) – list of k control qubits (or empty list if no controls). The control qubits are ordered according to their significance in increasing order: For example if `q_controls=[q[0],q[1]]` (with `q = QuantumRegister(2)`), the rotation `Ry(a_0)` is performed if `q[0]` and `q[1]` are in the state zero, the rotation `Ry(a_1)` is performed if `q[0]` is in the state one and `q[1]` is in the state zero, and so on +* **q\_target** (*QubitSpecifier*) – target qubit, where we act on with the single-qubit rotation gates + +**Returns** + +the uniformly controlled rotation gate is attached to the circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the list number of control qubits does not correspond to the provided number of single-qubit unitaries; if an input is of the wrong type + +### ucrz + + + +`ucrz(angle_list, q_controls, q_target)` + +Attach a uniformly controlled (also called multiplexed) Rz rotation gate to a circuit. + +The decomposition is base on [https://arxiv.org/pdf/quant-ph/0406176.pdf](https://arxiv.org/pdf/quant-ph/0406176.pdf) by Shende et al. + + + The method `qiskit.circuit.quantumcircuit.QuantumCircuit.ucrz()` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0.0 release. Instead, append a qiskit.circuit.library.UCRZGate to the circuit. + + +**Parameters** + +* **angle\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – list of (real) rotation angles $[a_0,...,a_{2^k-1}]$ +* **q\_controls** (*Sequence\[QubitSpecifier]*) – list of k control qubits (or empty list if no controls). The control qubits are ordered according to their significance in increasing order: For example if `q_controls=[q[0],q[1]]` (with `q = QuantumRegister(2)`), the rotation `Rz(a_0)` is performed if `q[0]` and `q[1]` are in the state zero, the rotation `Rz(a_1)` is performed if `q[0]` is in the state one and `q[1]` is in the state zero, and so on +* **q\_target** (*QubitSpecifier*) – target qubit, where we act on with the single-qubit rotation gates + +**Returns** + +the uniformly controlled rotation gate is attached to the circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the list number of control qubits does not correspond to the provided number of single-qubit unitaries; if an input is of the wrong type + +### unitary + + + +`unitary(obj, qubits, label=None)` + +Apply unitary gate specified by `obj` to `qubits`. + +**Parameters** + +* **obj** (*np.ndarray |* [*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| BaseOperator*) – Unitary operator. +* **qubits** (*Sequence\[QubitSpecifier]*) – The circuit qubits to apply the transformation to. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Unitary name for backend \[Default: None]. + +**Returns** + +The quantum circuit. + +**Return type** + +[QuantumCircuit](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Example** + +Apply a gate specified by a unitary matrix to a quantum circuit + +```python +from qiskit import QuantumCircuit +matrix = [[0, 0, 0, 1], + [0, 0, 1, 0], + [1, 0, 0, 0], + [0, 1, 0, 0]] +circuit = QuantumCircuit(2) +circuit.unitary(matrix, [0, 1]) +``` + +### while\_loop + +### while\_loop + + + +`while_loop(condition: tuple[ClassicalRegister | Clbit, int] | expr.Expr, body: None, qubits: None, clbits: None, *, label: str | None) → qiskit.circuit.controlflow.while_loop.WhileLoopContext` + + + +`while_loop(condition: tuple[ClassicalRegister | Clbit, int] | expr.Expr, body: QuantumCircuit, qubits: Sequence[Qubit | QuantumRegister | int | slice | Sequence[Qubit | int]], clbits: Sequence[Clbit | ClassicalRegister | int | slice | Sequence[Clbit | int]], *, label: str | None) → InstructionSet` + +Create a `while` loop on this circuit. + +There are two forms for calling this function. If called with all its arguments (with the possible exception of `label`), it will create a `WhileLoopOp` with the given `body`. If `body` (and `qubits` and `clbits`) are *not* passed, then this acts as a context manager, which will automatically build a `WhileLoopOp` when the scope finishes. In this form, you do not need to keep track of the qubits or clbits you are using, because the scope will handle it for you. + +Example usage: + +```python +from qiskit.circuit import QuantumCircuit, Clbit, Qubit +bits = [Qubit(), Qubit(), Clbit()] +qc = QuantumCircuit(bits) + +with qc.while_loop((bits[2], 0)): + qc.h(0) + qc.cx(0, 1) + qc.measure(0, 0) +``` + +**Parameters** + +* **condition** (*Tuple\[Union\[*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*],* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – An equality condition to be checked prior to executing `body`. The left-hand side of the condition must be a [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or a [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit"), and the right-hand side must be an integer or boolean. +* **body** (*Optional\[*[*QuantumCircuit*](#qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The loop body to be repeatedly executed. Omit this to use the context-manager mode. +* **qubits** (*Optional\[Sequence\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]]*) – The circuit qubits over which the loop body should be run. Omit this to use the context-manager mode. +* **clbits** (*Optional\[Sequence\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]]*) – The circuit clbits over which the loop body should be run. Omit this to use the context-manager mode. +* **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – The string label of the instruction in the circuit. + +**Returns** + +If used in context-manager mode, then this should be used as a `with` resource, which will infer the block content and operands on exit. If the full form is used, then this returns a handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") or WhileLoopContext + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if an incorrect calling convention is used. + +### width + + + +`width()` + +Return number of qubits plus clbits in circuit. + +**Returns** + +Width of circuit. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### x + + + +`x(qubit, label=None)` + +Apply [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +* **qubit** (*QubitSpecifier*) – The qubit(s) to apply the gate to. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The string label of the gate in the circuit. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[InstructionSet](qiskit.circuit.InstructionSet "qiskit.circuit.InstructionSet") + +### y + + + +`y(qubit)` + +Apply [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + +### z + + + +`z(qubit)` + +Apply [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate"). + +For the full matrix form of this gate, see the underlying gate documentation. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.quantumregister.QuantumRegister") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*slice*](https://docs.python.org/3/library/functions.html#slice "(in Python v3.12)") *|*[*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.quantumregister.Qubit") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit(s) to apply the gate to. + +**Returns** + +A handle to the instructions created. + +**Return type** + +[*InstructionSet*](qiskit.circuit.InstructionSet "qiskit.circuit.instructionset.InstructionSet") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.QuantumRegister.md b/docs/api/qiskit/0.46/qiskit.circuit.QuantumRegister.md new file mode 100644 index 00000000000..009b411b508 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.QuantumRegister.md @@ -0,0 +1,90 @@ +--- +title: QuantumRegister +description: API reference for qiskit.circuit.QuantumRegister +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.QuantumRegister +--- + +# QuantumRegister + + + +`qiskit.circuit.QuantumRegister(size=None, name=None, bits=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/quantumregister.py "view source code") + +Bases: [`Register`](qiskit.circuit.Register "qiskit.circuit.register.Register") + +Implement a quantum register. + +Create a new generic register. + +Either the `size` or the `bits` argument must be provided. If `size` is not None, the register will be pre-populated with bits of the correct type. + +**Parameters** + +* **size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The number of bits to include in the register. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional. The name of the register. If not provided, a unique name will be auto-generated from the register type. +* **bits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – Optional. A list of Bit() instances to be used to populate the register. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both the `size` and `bits` arguments are provided, or if neither are. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `size` is not valid. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `name` is not a valid name according to the OpenQASM spec. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained duplicated bits. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained bits of an incorrect type. + +## Attributes + + + +### instances\_counter + +`= count(6)` + + + +### name + +Get the register name. + + + +### name\_format + +`= re.compile('[a-z][a-zA-Z0-9_]*')` + + + +### prefix + +`= 'q'` + + + +### size + +Get the register size. + +## Methods + +### index + + + +`index(bit)` + +Find the index of the provided bit within this register. + +### qasm + + + +`qasm()` + +Return OPENQASM string for this register. + + + The method `qiskit.circuit.quantumregister.QuantumRegister.qasm()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Qubit.md b/docs/api/qiskit/0.46/qiskit.circuit.Qubit.md new file mode 100644 index 00000000000..4eec17a136b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Qubit.md @@ -0,0 +1,55 @@ +--- +title: Qubit +description: API reference for qiskit.circuit.Qubit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Qubit +--- + +# Qubit + + + +`qiskit.circuit.Qubit(register=None, index=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/quantumregister.py "view source code") + +Bases: [`Bit`](qiskit.circuit.Bit "qiskit.circuit.bit.Bit") + +Implement a quantum bit. + +Creates a qubit. + +**Parameters** + +* **register** ([*QuantumRegister*](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister")) – Optional. A quantum register containing the bit. +* **index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The index of the bit in its containing register. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the provided register is not a valid [`QuantumRegister`](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister") + +## Attributes + + + +### index + +Get the index of an old-style bit in the register that owns it. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.index` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + + + +### register + +Get the register of an old-style bit. + +In modern Qiskit Terra (version 0.17+), bits are the fundamental object and registers are aliases to collections of bits. A bit can be in many registers depending on the circuit, so a single containing register is no longer a property of a bit. It is an error to access this attribute on bits that were not constructed as “owned” by a register. + + + The property `qiskit.circuit.bit.Bit.register` is deprecated as of qiskit-terra 0.17. It will be removed in the Qiskit 1.0 release. Instead, use `find_bit()` to find all the containing registers within a circuit and the index of the bit within the circuit. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.Register.md b/docs/api/qiskit/0.46/qiskit.circuit.Register.md new file mode 100644 index 00000000000..6b95a843580 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.Register.md @@ -0,0 +1,88 @@ +--- +title: Register +description: API reference for qiskit.circuit.Register +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.Register +--- + +# Register + + + +`qiskit.circuit.Register(size=None, name=None, bits=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/register.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Implement a generic register. + + + This class should not be instantiated directly. This is just a superclass for [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") and [`QuantumRegister`](qiskit.circuit.QuantumRegister "qiskit.circuit.QuantumRegister"). + + +Create a new generic register. + +Either the `size` or the `bits` argument must be provided. If `size` is not None, the register will be pre-populated with bits of the correct type. + +**Parameters** + +* **size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The number of bits to include in the register. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional. The name of the register. If not provided, a unique name will be auto-generated from the register type. +* **bits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – Optional. A list of Bit() instances to be used to populate the register. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if both the `size` and `bits` arguments are provided, or if neither are. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `size` is not valid. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `name` is not a valid name according to the OpenQASM spec. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained duplicated bits. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if `bits` contained bits of an incorrect type. + +## Attributes + + + +### bit\_type + +`= None` + + + +### instances\_counter + +`= count(0)` + + + +### name + +Get the register name. + + + +### name\_format + +`= re.compile('[a-z][a-zA-Z0-9_]*')` + + + +### prefix + +`= 'reg'` + + + +### size + +Get the register size. + +## Methods + +### index + + + +`index(bit)` + +Find the index of the provided bit within this register. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.SwitchCaseOp.md b/docs/api/qiskit/0.46/qiskit.circuit.SwitchCaseOp.md new file mode 100644 index 00000000000..3d24cb66b1a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.SwitchCaseOp.md @@ -0,0 +1,392 @@ +--- +title: SwitchCaseOp +description: API reference for qiskit.circuit.SwitchCaseOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.SwitchCaseOp +--- + +# SwitchCaseOp + + + +`qiskit.circuit.SwitchCaseOp(target, cases, *, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlflow/switch_case.py "view source code") + +Bases: [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.controlflow.control_flow.ControlFlowOp") + +A circuit operation that executes one particular circuit block based on matching a given `target` against an ordered list of `values`. The special value [`CASE_DEFAULT`](circuit#qiskit.circuit.CASE_DEFAULT "qiskit.circuit.CASE_DEFAULT") can be used to represent a default condition. + +This is the low-level interface for creating a switch-case statement; in general, the circuit method [`QuantumCircuit.switch()`](qiskit.circuit.QuantumCircuit#switch "qiskit.circuit.QuantumCircuit.switch") should be used as a context manager to access the builder interface. At the low level, you must ensure that all the circuit blocks contain equal numbers of qubits and clbits, and that the order the virtual bits of the containing circuit should be bound is the same for all blocks. This will likely mean that each circuit block is wider than its natural width, as each block must span the union of all the spaces covered by *any* of the blocks. + +**Parameters** + +* **target** ([*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit") *|*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") *|*[*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – the runtime value to switch on. +* **cases** (*Iterable\[Tuple\[Any,* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]]*) – an ordered iterable of the corresponding value of the `target` and the circuit block that should be executed if this is matched. There is no fall-through between blocks, and the order matters. + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.SwitchCaseOp.base_class "qiskit.circuit.SwitchCaseOp.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### blocks + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### cases + + + +`cases()` + +Return a lookup table from case labels to the circuit that would be executed in that case. This object is not generally suitable for creating a new [`SwitchCaseOp`](#qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") because any keys that point to the same object will not be grouped. + + + **[`SwitchCaseOp.cases_specifier()`](#qiskit.circuit.SwitchCaseOp.cases_specifier "qiskit.circuit.SwitchCaseOp.cases_specifier")** + + An alternate method that produces its output in a suitable format for creating new [`SwitchCaseOp`](#qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") instances. + + +### cases\_specifier + + + +`cases_specifier()` + +Return an iterable where each element is a 2-tuple whose first element is a tuple of jump values, and whose second is the single circuit block that is associated with those values. + +This is an abstract specification of the jump table suitable for creating new [`SwitchCaseOp`](#qiskit.circuit.SwitchCaseOp "qiskit.circuit.SwitchCaseOp") instances. + + + **[`SwitchCaseOp.cases()`](#qiskit.circuit.SwitchCaseOp.cases "qiskit.circuit.SwitchCaseOp.cases")** + + Create a lookup table that you can use for your own purposes to jump from values to the circuit that would be executed. + + +**Return type** + +[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)"), [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")]] + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### replace\_blocks + + + +`replace_blocks(blocks)` + +Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + +**Returns** + +New ControlFlowOp with replaced blocks. + +**Return type** + +[*SwitchCaseOp*](#qiskit.circuit.SwitchCaseOp "qiskit.circuit.controlflow.switch_case.SwitchCaseOp") + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.WhileLoopOp.md b/docs/api/qiskit/0.46/qiskit.circuit.WhileLoopOp.md new file mode 100644 index 00000000000..f850b0a6671 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.WhileLoopOp.md @@ -0,0 +1,367 @@ +--- +title: WhileLoopOp +description: API reference for qiskit.circuit.WhileLoopOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.WhileLoopOp +--- + +# WhileLoopOp + + + +`qiskit.circuit.WhileLoopOp(condition, body, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/controlflow/while_loop.py "view source code") + +Bases: [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.controlflow.control_flow.ControlFlowOp") + +A circuit operation which repeatedly executes a subcircuit (`body`) until a condition (`condition`) evaluates as False. + +**Parameters** + +* **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*ClassicalRegister*](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*expr.Expr*](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr")) – A condition to be checked prior to executing `body`. Can be specified as either a tuple of a `ClassicalRegister` to be tested for equality with a given `int`, or as a tuple of a `Clbit` to be compared to either a `bool` or an `int`. +* **body** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The loop body to be repeatedly executed. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for identifying the instruction. + +The classical bits used in `condition` must be a subset of those attached to `body`. + +**Circuit symbol:** + +```python + ┌─────────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 ├ + │ while_loop │ +q_2: ┤2 ├ + │ │ +c_0: ╡0 ╞ + └─────────────┘ +``` + +Create a new instruction. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – instruction name +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s qubit width +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – instruction’s clbit width +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*|ndarray|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – list of parameters +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – instruction’s duration. it must be integer if `unit` is ‘dt’ +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – time unit of duration +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for identifying the instruction. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – when the register is not in the correct format. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – when the optional label is provided, but it is not a string. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.WhileLoopOp.base_class "qiskit.circuit.WhileLoopOp.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that [`Instruction.name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") should be a more suitable discriminator in most situations. + + + +### blocks + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### replace\_blocks + + + +`replace_blocks(blocks)` + +Replace blocks and return new instruction. :param blocks: Tuple of QuantumCircuits to replace in instruction. + +**Returns** + +New ControlFlowOp with replaced blocks. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.BooleanExpression.md b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.BooleanExpression.md new file mode 100644 index 00000000000..7cc37760ed2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.BooleanExpression.md @@ -0,0 +1,487 @@ +--- +title: BooleanExpression +description: API reference for qiskit.circuit.classicalfunction.BooleanExpression +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.classicalfunction.BooleanExpression +--- + +# BooleanExpression + + + +`qiskit.circuit.classicalfunction.BooleanExpression(expression, name=None, var_order=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classicalfunction/boolean_expression.py "view source code") + +Bases: `ClassicalElement` + +The Boolean Expression gate. + +**Parameters** + +* **expression** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The logical expression string. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional. Instruction gate name. Otherwise part of the expression is going to be used. +* **var\_order** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list with the order in which variables will be created. (default: by appearance) + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.classicalfunction.BooleanExpression.base_class "qiskit.circuit.classicalfunction.BooleanExpression.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation and handling of the arguments and its relationship. + +For example, `cx([q[0],q[1]], q[2])` means `cx(q[0], q[2]); cx(q[1], q[2])`. This method yields the arguments in the right grouping. In the given example: + +```python +in: [[q[0],q[1]], q[2]],[] +outs: [q[0], q[2]], [] + [q[1], q[2]], [] +``` + +The general broadcasting rules are: + +> * If len(qargs) == 1: +> +> ```python +> [q[0], q[1]] -> [q[0]],[q[1]] +> ``` +> +> * If len(qargs) == 2: +> +> ```python +> [[q[0], q[1]], [r[0], r[1]]] -> [q[0], r[0]], [q[1], r[1]] +> [[q[0]], [r[0], r[1]]] -> [q[0], r[0]], [q[0], r[1]] +> [[q[0], q[1]], [r[0]]] -> [q[0], r[0]], [q[1], r[0]] +> ``` +> +> * If len(qargs) >= 3: +> +> ```python +> [q[0], q[1]], [r[0], r[1]], ...] -> [q[0], r[0], ...], [q[1], r[1], ...] +> ``` + +**Parameters** + +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of quantum bit arguments. +* **cargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of classical bit arguments. + +**Returns** + +A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +**Return type** + +[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")]] + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return controlled version of gate. See [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") for usage. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of controls to add to gate (default: `1`) +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – optional gate label +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The control state in decimal or as a bitstring (e.g. `'111'`). If `None`, use `2**num_ctrl_qubits-1`. + +**Returns** + +Controlled version of gate. This default algorithm uses `num_ctrl_qubits-1` ancilla qubits so returns a gate of size `num_qubits + 2*num_ctrl_qubits - 1`. + +**Return type** + +[qiskit.circuit.ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### from\_dimacs\_file + + + +`classmethod from_dimacs_file(filename)` + +Create a BooleanExpression from the string in the DIMACS format. :param filename: A file in DIMACS format. + +**Returns** + +A gate for the input string + +**Return type** + +[BooleanExpression](#qiskit.circuit.classicalfunction.BooleanExpression "qiskit.circuit.classicalfunction.BooleanExpression") + +**Raises** + +[**FileNotFoundError**](https://docs.python.org/3/library/exceptions.html#FileNotFoundError "(in Python v3.12)") – If filename is not found. + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### power + + + +`power(exponent)` + +Creates a unitary gate as gate^exponent. + +**Parameters** + +**exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + +**Returns** + +To which to\_matrix is self.to\_matrix^exponent. + +**Return type** + +.library.UnitaryGate + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### simulate + + + +`simulate(bitstring)` + +Evaluate the expression on a bitstring. + +This evaluation is done classically. + +**Parameters** + +**bitstring** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The bitstring for which to evaluate. + +**Returns** + +result of the evaluation. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### synth + + + +`synth(registerless=True, synthesizer=None)` + +Synthesis the logic network into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Parameters** + +* **registerless** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Default `True`. If `False` uses the parameter names to create registers with those names. Otherwise, creates a circuit with a flat quantum register. +* **synthesizer** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*BooleanExpression*](#qiskit.circuit.classicalfunction.BooleanExpression "qiskit.circuit.classicalfunction.boolean_expression.BooleanExpression")*],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*] | None*) – A callable that takes self and returns a Tweedledum circuit. + +**Returns** + +A circuit implementing the logic network. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### to\_matrix + + + +`to_matrix()` + +Return a Numpy.array for the gate unitary matrix. + +**Returns** + +if the Gate subclass has a matrix definition. + +**Return type** + +np.ndarray + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If a Gate subclass does not implement this method an exception will be raised when this base class method is called. + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Gate parameters should be int, float, or ParameterExpression + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunction.md b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunction.md new file mode 100644 index 00000000000..44a8ab5b1a7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunction.md @@ -0,0 +1,544 @@ +--- +title: ClassicalFunction +description: API reference for qiskit.circuit.classicalfunction.ClassicalFunction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.classicalfunction.ClassicalFunction +--- + +# ClassicalFunction + + + +`qiskit.circuit.classicalfunction.ClassicalFunction(source, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classicalfunction/classicalfunction.py "view source code") + +Bases: `ClassicalElement` + +Represent a classical function and its logic network. + +Creates a `ClassicalFunction` from Python source code in `source`. + +The code should be a single function with types. + +**Parameters** + +* **source** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Python code with type hints. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional. Default: “*classicalfunction*”. ClassicalFunction name. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If source is not a string. + +## Attributes + + + +### args + +Returns the classicalfunction arguments + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.classicalfunction.ClassicalFunction.base_class "qiskit.circuit.classicalfunction.ClassicalFunction.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### network + +Returns the logical network + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### qregs + +The list of qregs used by the classicalfunction + + + +### scopes + +Returns the scope dict + + + +### truth\_table + +Returns (and computes) the truth table + + + +### types + +Dumps a list of scopes with their variables and types. + +**Returns** + +A list of scopes as dicts, where key is the variable name and value is its type. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")([dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation and handling of the arguments and its relationship. + +For example, `cx([q[0],q[1]], q[2])` means `cx(q[0], q[2]); cx(q[1], q[2])`. This method yields the arguments in the right grouping. In the given example: + +```python +in: [[q[0],q[1]], q[2]],[] +outs: [q[0], q[2]], [] + [q[1], q[2]], [] +``` + +The general broadcasting rules are: + +> * If len(qargs) == 1: +> +> ```python +> [q[0], q[1]] -> [q[0]],[q[1]] +> ``` +> +> * If len(qargs) == 2: +> +> ```python +> [[q[0], q[1]], [r[0], r[1]]] -> [q[0], r[0]], [q[1], r[1]] +> [[q[0]], [r[0], r[1]]] -> [q[0], r[0]], [q[0], r[1]] +> [[q[0], q[1]], [r[0]]] -> [q[0], r[0]], [q[1], r[0]] +> ``` +> +> * If len(qargs) >= 3: +> +> ```python +> [q[0], q[1]], [r[0], r[1]], ...] -> [q[0], r[0], ...], [q[1], r[1], ...] +> ``` + +**Parameters** + +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of quantum bit arguments. +* **cargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of classical bit arguments. + +**Returns** + +A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +**Return type** + +[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")]] + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### compile + + + +`compile()` + +Parses and creates the logical circuit + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return controlled version of gate. See [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") for usage. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of controls to add to gate (default: `1`) +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – optional gate label +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The control state in decimal or as a bitstring (e.g. `'111'`). If `None`, use `2**num_ctrl_qubits-1`. + +**Returns** + +Controlled version of gate. This default algorithm uses `num_ctrl_qubits-1` ancilla qubits so returns a gate of size `num_qubits + 2*num_ctrl_qubits - 1`. + +**Return type** + +[qiskit.circuit.ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### power + + + +`power(exponent)` + +Creates a unitary gate as gate^exponent. + +**Parameters** + +**exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + +**Returns** + +To which to\_matrix is self.to\_matrix^exponent. + +**Return type** + +.library.UnitaryGate + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### simulate + + + +`simulate(bitstring)` + +Evaluate the expression on a bitstring. + +This evaluation is done classically. + +**Parameters** + +**bitstring** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The bitstring for which to evaluate. + +**Returns** + +result of the evaluation. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### simulate\_all + + + +`simulate_all()` + +Returns a truth table. + +**Returns** + +a bitstring with a truth table + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### synth + + + +`synth(registerless=True, synthesizer=None)` + +Synthesis the logic network into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Parameters** + +* **registerless** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Default `True`. If `False` uses the parameter names to create +* **Otherwise** (*registers with those names.*) – +* **register.** (*creates a circuit with a flat quantum*) – +* **synthesizer** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[ClassicalElement],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*] | None*) – Optional. If None tweedledum’s pkrm\_synth is used. + +**Returns** + +A circuit implementing the logic network. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### to\_matrix + + + +`to_matrix()` + +Return a Numpy.array for the gate unitary matrix. + +**Returns** + +if the Gate subclass has a matrix definition. + +**Return type** + +np.ndarray + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If a Gate subclass does not implement this method an exception will be raised when this base class method is called. + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Gate parameters should be int, float, or ParameterExpression + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.md b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.md new file mode 100644 index 00000000000..94b9c516a35 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError.md @@ -0,0 +1,20 @@ +--- +title: ClassicalFunctionCompilerTypeError +description: API reference for qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError +in_page_toc_min_heading_level: 1 +python_api_type: exception +python_api_name: qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError +--- + + + +# qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError + + + +`qiskit.circuit.classicalfunction.ClassicalFunctionCompilerTypeError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classicalfunction/exceptions.py "view source code") + +ClassicalFunction compiler type error. The classicalfunction function fails at type checking time. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.md b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.md new file mode 100644 index 00000000000..e9d783380b1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.classicalfunction.ClassicalFunctionParseError.md @@ -0,0 +1,20 @@ +--- +title: ClassicalFunctionParseError +description: API reference for qiskit.circuit.classicalfunction.ClassicalFunctionParseError +in_page_toc_min_heading_level: 1 +python_api_type: exception +python_api_name: qiskit.circuit.classicalfunction.ClassicalFunctionParseError +--- + + + +# qiskit.circuit.classicalfunction.ClassicalFunctionParseError + + + +`qiskit.circuit.classicalfunction.ClassicalFunctionParseError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/classicalfunction/exceptions.py "view source code") + +ClassicalFunction compiler parse error. The classicalfunction function fails at parsing time. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.AND.md b/docs/api/qiskit/0.46/qiskit.circuit.library.AND.md new file mode 100644 index 00000000000..612e6a9994f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.AND.md @@ -0,0 +1,227 @@ +--- +title: AND +description: API reference for qiskit.circuit.library.AND +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.AND +--- + +# AND + + + +`qiskit.circuit.library.AND(num_variable_qubits, flags=None, mcx_mode='noancilla')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/boolean_logic/quantum_and.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +A circuit implementing the logical AND operation on a number of qubits. + +For the AND operation the state $|1\rangle$ is interpreted as `True`. The result qubit is flipped, if the state of all variable qubits is `True`. In this format, the AND operation equals a multi-controlled X gate, which is controlled on all variable qubits. Using a list of flags however, qubits can be skipped or negated. Practically, the flags allow to skip controls or to apply pre- and post-X gates to the negated qubits. + +The AND gate without special flags equals the multi-controlled-X gate: + +![../\_images/qiskit-circuit-library-AND-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-AND-1.png) + +Using flags we can negate qubits or skip them. For instance, if we have 5 qubits and want to return `True` if the first qubit is `False` and the last two are `True` we use the flags `[-1, 0, 0, 1, 1]`. + +![../\_images/qiskit-circuit-library-AND-2.png](/images/api/qiskit/0.46/qiskit-circuit-library-AND-2.png) + +Create a new logical AND circuit. + +**Parameters** + +* **num\_variable\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The qubits of which the OR is computed. The result will be written into an additional result qubit. +* **flags** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – A list of +1/0/-1 marking negations or omissions of qubits. +* **mcx\_mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The mode to be used to implement the multi-controlled X gate. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 193` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.Barrier.md b/docs/api/qiskit/0.46/qiskit.circuit.library.Barrier.md new file mode 100644 index 00000000000..dcc73097c35 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.Barrier.md @@ -0,0 +1,311 @@ +--- +title: Barrier +description: API reference for qiskit.circuit.library.Barrier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.Barrier +--- + +# Barrier + + + +`qiskit.circuit.library.Barrier(num_qubits, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/barrier.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Barrier instruction. + +A barrier is a visual indicator of the grouping of a circuit section. It also acts as a directive for circuit compilation to separate pieces of a circuit so that any optimizations or re-writes are constrained to only act between barriers. + +Create new barrier instruction. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits for the barrier type \[Default: 0]. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the barrier label + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – if barrier label is invalid. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.Barrier.base_class "qiskit.circuit.library.Barrier.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Special case. Return self. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.C3SXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.C3SXGate.md new file mode 100644 index 00000000000..4afb068188b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.C3SXGate.md @@ -0,0 +1,176 @@ +--- +title: C3SXGate +description: API reference for qiskit.circuit.library.C3SXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.C3SXGate +--- + +# C3SXGate + + + +`qiskit.circuit.library.C3SXGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +The 3-qubit controlled sqrt-X gate. + +This implementation is based on Page 17 of \[1]. + +**References** + +\[1] Barenco et al., 1995. [https://arxiv.org/pdf/quant-ph/9503016.pdf](https://arxiv.org/pdf/quant-ph/9503016.pdf) + +Create a new 3-qubit controlled sqrt-X gate. + +**Parameters** + +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.C3SXGate.base_class "qiskit.circuit.library.C3SXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### qasm + + + +`qasm()` + + + The method `qiskit.circuit.library.standard_gates.x.C3SXGate.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. + + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.C3XGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.C3XGate.md new file mode 100644 index 00000000000..b36568887b0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.C3XGate.md @@ -0,0 +1,187 @@ +--- +title: C3XGate +description: API reference for qiskit.circuit.library.C3XGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.C3XGate +--- + +# C3XGate + + + +`qiskit.circuit.library.C3XGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +The X gate controlled on 3 qubits. + +This implementation uses $\sqrt{T}$ and 14 CNOT gates. + +Create a new 3-qubit controlled X gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.C3XGate.base_class "qiskit.circuit.library.C3XGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Controlled version of this gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Invert this gate. The C4X is its own inverse. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.C4XGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.C4XGate.md new file mode 100644 index 00000000000..6df286171a5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.C4XGate.md @@ -0,0 +1,191 @@ +--- +title: C4XGate +description: API reference for qiskit.circuit.library.C4XGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.C4XGate +--- + +# C4XGate + + + +`qiskit.circuit.library.C4XGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +The 4-qubit controlled X gate. + +This implementation is based on Page 21, Lemma 7.5, of \[1], with the use of the relative phase version of c3x, the rc3x \[2]. + +**References** + +\[1] Barenco et al., 1995. [https://arxiv.org/pdf/quant-ph/9503016.pdf](https://arxiv.org/pdf/quant-ph/9503016.pdf) \[2] Maslov, 2015. [https://arxiv.org/abs/1508.03273](https://arxiv.org/abs/1508.03273) + +Create a new 4-qubit controlled X gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.C4XGate.base_class "qiskit.circuit.library.C4XGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Controlled version of this gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Invert this gate. The C4X is its own inverse. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CCXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CCXGate.md new file mode 100644 index 00000000000..0c6169baeae --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CCXGate.md @@ -0,0 +1,243 @@ +--- +title: CCXGate +description: API reference for qiskit.circuit.library.CCXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CCXGate +--- + +# CCXGate + + + +`qiskit.circuit.library.CCXGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +CCX gate, also known as Toffoli gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`ccx()`](qiskit.circuit.QuantumCircuit#ccx "qiskit.circuit.QuantumCircuit.ccx") and [`toffoli()`](qiskit.circuit.QuantumCircuit#toffoli "qiskit.circuit.QuantumCircuit.toffoli") methods. + +**Circuit symbol:** + +```python +q_0: ──■── + │ +q_1: ──■── + ┌─┴─┐ +q_2: ┤ X ├ + └───┘ +``` + +**Matrix representation:** + +$$ +CCX q_0, q_1, q_2 = + I \otimes I \otimes |0 \rangle \langle 0| + CX \otimes |1 \rangle \langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0\\ + 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0\\ + 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0\\ + 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1\\ + 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0\\ + 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0\\ + 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0\\ + 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_2 and q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───┐ + q_0: ┤ X ├ + └─┬─┘ + q_1: ──■── + │ + q_2: ──■── + ``` + + $$ + CCX\ q_2, q_1, q_0 = + |0 \rangle \langle 0| \otimes I \otimes I + |1 \rangle \langle 1| \otimes CX = + \begin{pmatrix} + 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0\\ + 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0\\ + 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0\\ + 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0\\ + 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0\\ + 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0\\ + 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1\\ + 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 + \end{pmatrix} + $$ + + +Create new CCX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CCXGate.base_class "qiskit.circuit.library.CCXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Controlled version of this gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return an inverted CCX gate (also a CCX). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CCZGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CCZGate.md new file mode 100644 index 00000000000..53fd3661a21 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CCZGate.md @@ -0,0 +1,196 @@ +--- +title: CCZGate +description: API reference for qiskit.circuit.library.CCZGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CCZGate +--- + +# CCZGate + + + +`qiskit.circuit.library.CCZGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/z.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +CCZ gate. + +This is a symmetric gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`ccz()`](qiskit.circuit.QuantumCircuit#ccz "qiskit.circuit.QuantumCircuit.ccz") method. + +**Circuit symbol:** + +```python +q_0: ─■─ + │ +q_1: ─■─ + │ +q_2: ─■─ +``` + +**Matrix representation:** + +$$ +CCZ\ q_0, q_1, q_2 = + I \otimes I \otimes |0\rangle\langle 0| + CZ \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 0 & -1 + \end{pmatrix} +$$ + +In the computational basis, this gate flips the phase of the target qubit if the control qubits are in the $|11\rangle$ state. + +Create new CCZ gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CCZGate.base_class "qiskit.circuit.library.CCZGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted CCZ gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CDKMRippleCarryAdder.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CDKMRippleCarryAdder.md new file mode 100644 index 00000000000..d21cd10c0f7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CDKMRippleCarryAdder.md @@ -0,0 +1,283 @@ +--- +title: CDKMRippleCarryAdder +description: API reference for qiskit.circuit.library.CDKMRippleCarryAdder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CDKMRippleCarryAdder +--- + +# CDKMRippleCarryAdder + + + +`qiskit.circuit.library.CDKMRippleCarryAdder(num_state_qubits, kind='full', name='CDKMRippleCarryAdder')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/adders/cdkm_ripple_carry_adder.py "view source code") + +Bases: `Adder` + +A ripple-carry circuit to perform in-place addition on two qubit registers. + +As an example, a ripple-carry adder circuit that performs addition on two 3-qubit sized registers with a carry-in bit (`kind="full"`) is as follows: + +```python + ┌──────┐ ┌──────┐ + cin_0: ┤2 ├─────────────────────────────────────┤2 ├ + │ │┌──────┐ ┌──────┐│ │ + a_0: ┤0 ├┤2 ├─────────────────────┤2 ├┤0 ├ + │ ││ │┌──────┐ ┌──────┐│ ││ │ + a_1: ┤ MAJ ├┤0 ├┤2 ├─────┤2 ├┤0 ├┤ UMA ├ + │ ││ ││ │ │ ││ ││ │ + a_2: ┤ ├┤ MAJ ├┤0 ├──■──┤0 ├┤ UMA ├┤ ├ + │ ││ ││ │ │ │ ││ ││ │ + b_0: ┤1 ├┤ ├┤ MAJ ├──┼──┤ UMA ├┤ ├┤1 ├ + └──────┘│ ││ │ │ │ ││ │└──────┘ + b_1: ────────┤1 ├┤ ├──┼──┤ ├┤1 ├──────── + └──────┘│ │ │ │ │└──────┘ + b_2: ────────────────┤1 ├──┼──┤1 ├──────────────── + └──────┘┌─┴─┐└──────┘ +cout_0: ────────────────────────┤ X ├──────────────────────── + └───┘ +``` + +Here *MAJ* and *UMA* gates correspond to the gates introduced in \[1]. Note that in this implementation the input register qubits are ordered as all qubits from the first input register, followed by all qubits from the second input register. + +Two different kinds of adders are supported. By setting the `kind` argument, you can also choose a half-adder, which doesn’t have a carry-in, and a fixed-sized-adder, which has neither carry-in nor carry-out, and thus acts on fixed register sizes. Unlike the full-adder, these circuits need one additional helper qubit. + +The circuit diagram for the fixed-point adder (`kind="fixed"`) on 3-qubit sized inputs is + +```python + ┌──────┐┌──────┐ ┌──────┐┌──────┐ + a_0: ┤0 ├┤2 ├────────────────┤2 ├┤0 ├ + │ ││ │┌──────┐┌──────┐│ ││ │ + a_1: ┤ ├┤0 ├┤2 ├┤2 ├┤0 ├┤ ├ + │ ││ ││ ││ ││ ││ │ + a_2: ┤ ├┤ MAJ ├┤0 ├┤0 ├┤ UMA ├┤ ├ + │ ││ ││ ││ ││ ││ │ + b_0: ┤1 MAJ ├┤ ├┤ MAJ ├┤ UMA ├┤ ├┤1 UMA ├ + │ ││ ││ ││ ││ ││ │ + b_1: ┤ ├┤1 ├┤ ├┤ ├┤1 ├┤ ├ + │ │└──────┘│ ││ │└──────┘│ │ + b_2: ┤ ├────────┤1 ├┤1 ├────────┤ ├ + │ │ └──────┘└──────┘ │ │ +help_0: ┤2 ├────────────────────────────────┤2 ├ + └──────┘ └──────┘ +``` + +It has one less qubit than the full-adder since it doesn’t have the carry-out, but uses a helper qubit instead of the carry-in, so it only has one less qubit, not two. + +**References:** + +\[1] Cuccaro et al., A new quantum ripple-carry addition circuit, 2004. [arXiv:quant-ph/0410184](https://arxiv.org/pdf/quant-ph/0410184.pdf) + +\[2] Vedral et al., Quantum Networks for Elementary Arithmetic Operations, 1995. [arXiv:quant-ph/9511018](https://arxiv.org/pdf/quant-ph/9511018.pdf) + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits in either input register for state $|a\rangle$ or $|b\rangle$. The two input registers must have the same number of qubits. +* **kind** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The kind of adder, can be `'full'` for a full adder, `'half'` for a half adder, or `'fixed'` for a fixed-sized adder. A full adder includes both carry-in and carry-out, a half only carry-out, and a fixed-sized adder neither carry-in nor carry-out. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit object. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `num_state_qubits` is lower than 1. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits, i.e. the number of bits in each input register. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CHGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CHGate.md new file mode 100644 index 00000000000..8093f61659f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CHGate.md @@ -0,0 +1,211 @@ +--- +title: CHGate +description: API reference for qiskit.circuit.library.CHGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CHGate +--- + +# CHGate + + + +`qiskit.circuit.library.CHGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/h.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-Hadamard gate. + +Applies a Hadamard on the target qubit if the control is in the $|1\rangle$ state. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`ch()`](qiskit.circuit.QuantumCircuit#ch "qiskit.circuit.QuantumCircuit.ch") method. + +**Circuit symbol:** + +```python +q_0: ──■── + ┌─┴─┐ +q_1: ┤ H ├ + └───┘ +``` + +**Matrix Representation:** + +$$ +CH\ q_0, q_1 = + I \otimes |0\rangle\langle 0| + H \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & \frac{1}{\sqrt{2}} & 0 & \frac{1}{\sqrt{2}} \\ + 0 & 0 & 1 & 0 \\ + 0 & \frac{1}{\sqrt{2}} & 0 & -\frac{1}{\sqrt{2}} + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───┐ + q_0: ┤ H ├ + └─┬─┘ + q_1: ──■── + ``` + + $$ + CH\ q_1, q_0 = + |0\rangle\langle 0| \otimes I + |1\rangle\langle 1| \otimes H = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & \frac{1}{\sqrt{2}} & \frac{1}{\sqrt{2}} \\ + 0 & 0 & \frac{1}{\sqrt{2}} & -\frac{1}{\sqrt{2}} + \end{pmatrix} + $$ + + +Create new CH gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CHGate.base_class "qiskit.circuit.library.CHGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted CH gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CPhaseGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CPhaseGate.md new file mode 100644 index 00000000000..caa15cce20f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CPhaseGate.md @@ -0,0 +1,222 @@ +--- +title: CPhaseGate +description: API reference for qiskit.circuit.library.CPhaseGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CPhaseGate +--- + +# CPhaseGate + + + +`qiskit.circuit.library.CPhaseGate(theta, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/p.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Controlled-Phase gate. + +This is a diagonal and symmetric gate that induces a phase on the state of the target qubit, depending on the control state. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cp()`](qiskit.circuit.QuantumCircuit#cp "qiskit.circuit.QuantumCircuit.cp") method. + +**Circuit symbol:** + +```python +q_0: ─■── + │λ +q_1: ─■── +``` + +**Matrix representation:** + +$$ +CPhase = + I \otimes |0\rangle\langle 0| + P \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & e^{i\lambda} + \end{pmatrix} +$$ + + + `CRZGate`: Due to the global phase difference in the matrix definitions of Phase and RZ, CPhase and CRZ are different gates with a relative phase difference. + + +Create new CPhase gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CPhaseGate.base_class "qiskit.circuit.library.CPhaseGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Controlled version of this gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted CPhase gate ($CPhase(\lambda)^{\dagger} = CPhase(-\lambda)$) + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CRXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CRXGate.md new file mode 100644 index 00000000000..b9ebc221b24 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CRXGate.md @@ -0,0 +1,213 @@ +--- +title: CRXGate +description: API reference for qiskit.circuit.library.CRXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CRXGate +--- + +# CRXGate + + + +`qiskit.circuit.library.CRXGate(theta, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/rx.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Controlled-RX gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`crx()`](qiskit.circuit.QuantumCircuit#crx "qiskit.circuit.QuantumCircuit.crx") method. + +**Circuit symbol:** + +```python +q_0: ────■──── + ┌───┴───┐ +q_1: ┤ Rx(ϴ) ├ + └───────┘ +``` + +**Matrix representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +CRX(\theta)\ q_0, q_1 = + I \otimes |0\rangle\langle 0| + RX(\theta) \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & \cos\left(\rotationangle\right) & 0 & -i\sin\left(\rotationangle\right) \\ + 0 & 0 & 1 & 0 \\ + 0 & -i\sin\left(\rotationangle\right) & 0 & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───────┐ + q_0: ┤ Rx(ϴ) ├ + └───┬───┘ + q_1: ────■──── + ``` + + $$ + \newcommand{\rotationangle}{\frac{\theta}{2}} + + CRX(\theta)\ q_1, q_0 = + |0\rangle\langle0| \otimes I + |1\rangle\langle1| \otimes RX(\theta) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & \cos\left(\rotationangle\right) & -i\sin\left(\rotationangle\right) \\ + 0 & 0 & -i\sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) + \end{pmatrix} + $$ + + +Create new CRX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CRXGate.base_class "qiskit.circuit.library.CRXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse CRX gate (i.e. with the negative rotation angle). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CRYGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CRYGate.md new file mode 100644 index 00000000000..5e5413f5c56 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CRYGate.md @@ -0,0 +1,213 @@ +--- +title: CRYGate +description: API reference for qiskit.circuit.library.CRYGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CRYGate +--- + +# CRYGate + + + +`qiskit.circuit.library.CRYGate(theta, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/ry.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Controlled-RY gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cry()`](qiskit.circuit.QuantumCircuit#cry "qiskit.circuit.QuantumCircuit.cry") method. + +**Circuit symbol:** + +```python +q_0: ────■──── + ┌───┴───┐ +q_1: ┤ Ry(ϴ) ├ + └───────┘ +``` + +**Matrix representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +CRY(\theta)\ q_0, q_1 = + I \otimes |0\rangle\langle 0| + RY(\theta) \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & \cos\left(\rotationangle\right) & 0 & -\sin\left(\rotationangle\right) \\ + 0 & 0 & 1 & 0 \\ + 0 & \sin\left(\rotationangle\right) & 0 & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───────┐ + q_0: ┤ Ry(ϴ) ├ + └───┬───┘ + q_1: ────■──── + ``` + + $$ + \newcommand{\rotationangle}{\frac{\theta}{2}} + + CRY(\theta)\ q_1, q_0 = + |0\rangle\langle 0| \otimes I + |1\rangle\langle 1| \otimes RY(\theta) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & \cos\left(\rotationangle\right) & -\sin\left(\rotationangle\right) \\ + 0 & 0 & \sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) + \end{pmatrix} + $$ + + +Create new CRY gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CRYGate.base_class "qiskit.circuit.library.CRYGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse CRY gate (i.e. with the negative rotation angle). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CRZGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CRZGate.md new file mode 100644 index 00000000000..3ecf0b95ed1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CRZGate.md @@ -0,0 +1,215 @@ +--- +title: CRZGate +description: API reference for qiskit.circuit.library.CRZGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CRZGate +--- + +# CRZGate + + + +`qiskit.circuit.library.CRZGate(theta, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/rz.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Controlled-RZ gate. + +This is a diagonal but non-symmetric gate that induces a phase on the state of the target qubit, depending on the control state. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`crz()`](qiskit.circuit.QuantumCircuit#crz "qiskit.circuit.QuantumCircuit.crz") method. + +**Circuit symbol:** + +```python +q_0: ────■──── + ┌───┴───┐ +q_1: ┤ Rz(λ) ├ + └───────┘ +``` + +**Matrix representation:** + +$$ +CRZ(\lambda)\ q_0, q_1 = + I \otimes |0\rangle\langle 0| + RZ(\lambda) \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & e^{-i\frac{\lambda}{2}} & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & e^{i\frac{\lambda}{2}} + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───────┐ + q_0: ┤ Rz(λ) ├ + └───┬───┘ + q_1: ────■──── + ``` + + $$ + CRZ(\lambda)\ q_1, q_0 = + |0\rangle\langle 0| \otimes I + |1\rangle\langle 1| \otimes RZ(\lambda) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & e^{-i\frac{\lambda}{2}} & 0 \\ + 0 & 0 & 0 & e^{i\frac{\lambda}{2}} + \end{pmatrix} + $$ + + + + `CU1Gate`: Due to the global phase difference in the matrix definitions of U1 and RZ, CU1 and CRZ are different gates with a relative phase difference. + + +Create new CRZ gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CRZGate.base_class "qiskit.circuit.library.CRZGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse CRZ gate (i.e. with the negative rotation angle). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CSGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CSGate.md new file mode 100644 index 00000000000..0d73e333043 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CSGate.md @@ -0,0 +1,195 @@ +--- +title: CSGate +description: API reference for qiskit.circuit.library.CSGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CSGate +--- + +# CSGate + + + +`qiskit.circuit.library.CSGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/s.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-S gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cs()`](qiskit.circuit.QuantumCircuit#cs "qiskit.circuit.QuantumCircuit.cs") method. + +**Circuit symbol:** + +```python +q_0: ──■── + ┌─┴─┐ +q_1: ┤ S ├ + └───┘ +``` + +**Matrix representation:** + +$$ +CS \ q_0, q_1 = +I \otimes |0 \rangle\langle 0| + S \otimes |1 \rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & i + \end{pmatrix} +$$ + +Create new CS gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CSGate.base_class "qiskit.circuit.library.CSGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse of CSGate (CSdgGate). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CSXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CSXGate.md new file mode 100644 index 00000000000..19647b1c8f3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CSXGate.md @@ -0,0 +1,199 @@ +--- +title: CSXGate +description: API reference for qiskit.circuit.library.CSXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CSXGate +--- + +# CSXGate + + + +`qiskit.circuit.library.CSXGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/sx.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-√X gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`csx()`](qiskit.circuit.QuantumCircuit#csx "qiskit.circuit.QuantumCircuit.csx") method. + +**Circuit symbol:** + +```python +q_0: ──■── + ┌─┴──┐ +q_1: ┤ √X ├ + └────┘ +``` + +**Matrix representation:** + +$$ +C\sqrt{X} \ q_0, q_1 = +I \otimes |0 \rangle\langle 0| + \sqrt{X} \otimes |1 \rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & (1 + i) / 2 & 0 & (1 - i) / 2 \\ + 0 & 0 & 1 & 0 \\ + 0 & (1 - i) / 2 & 0 & (1 + i) / 2 + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌────┐ + q_0: ┤ √X ├ + └─┬──┘ + q_1: ──■── + ``` + + $$ + C\sqrt{X}\ q_1, q_0 = + |0 \rangle\langle 0| \otimes I + |1 \rangle\langle 1| \otimes \sqrt{X} = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & (1 + i) / 2 & (1 - i) / 2 \\ + 0 & 0 & (1 - i) / 2 & (1 + i) / 2 + \end{pmatrix} + $$ + + +Create new CSX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CSXGate.base_class "qiskit.circuit.library.CSXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CSdgGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CSdgGate.md new file mode 100644 index 00000000000..839c7f3565e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CSdgGate.md @@ -0,0 +1,195 @@ +--- +title: CSdgGate +description: API reference for qiskit.circuit.library.CSdgGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CSdgGate +--- + +# CSdgGate + + + +`qiskit.circuit.library.CSdgGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/s.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-S^dagger gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`csdg()`](qiskit.circuit.QuantumCircuit#csdg "qiskit.circuit.QuantumCircuit.csdg") method. + +**Circuit symbol:** + +```python +q_0: ───■─── + ┌──┴──┐ +q_1: ┤ Sdg ├ + └─────┘ +``` + +**Matrix representation:** + +$$ +CS^\dagger \ q_0, q_1 = +I \otimes |0 \rangle\langle 0| + S^\dagger \otimes |1 \rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & -i + \end{pmatrix} +$$ + +Create new CSdg gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CSdgGate.base_class "qiskit.circuit.library.CSdgGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse of CSdgGate (CSGate). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CSwapGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CSwapGate.md new file mode 100644 index 00000000000..344ad69c3f1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CSwapGate.md @@ -0,0 +1,230 @@ +--- +title: CSwapGate +description: API reference for qiskit.circuit.library.CSwapGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CSwapGate +--- + +# CSwapGate + + + +`qiskit.circuit.library.CSwapGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/swap.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-SWAP gate, also known as the Fredkin gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cswap()`](qiskit.circuit.QuantumCircuit#cswap "qiskit.circuit.QuantumCircuit.cswap") and [`fredkin()`](qiskit.circuit.QuantumCircuit#fredkin "qiskit.circuit.QuantumCircuit.fredkin") methods. + +**Circuit symbol:** + +```python +q_0: ─■─ + │ +q_1: ─X─ + │ +q_2: ─X─ +``` + +**Matrix representation:** + +$$ +CSWAP\ q_0, q_1, q_2 = + I \otimes I \otimes |0 \rangle \langle 0| + + SWAP \otimes |1 \rangle \langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 \\ + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_2. Thus a textbook matrix for this gate will be: + + ```python + q_0: ─X─ + │ + q_1: ─X─ + │ + q_2: ─■─ + ``` + + $$ + CSWAP\ q_2, q_1, q_0 = + |0 \rangle \langle 0| \otimes I \otimes I + + |1 \rangle \langle 1| \otimes SWAP = + \begin{pmatrix} + 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ + 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 \\ + \end{pmatrix} + $$ + + +In the computational basis, this gate swaps the states of the two target qubits if the control qubit is in the $|1\rangle$ state. + +$$ +|0, b, c\rangle \rightarrow |0, b, c\rangle +|1, b, c\rangle \rightarrow |1, c, b\rangle + + +$$ + +Create new CSWAP gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CSwapGate.base_class "qiskit.circuit.library.CSwapGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse CSwap gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CU1Gate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CU1Gate.md new file mode 100644 index 00000000000..589b7e5fe13 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CU1Gate.md @@ -0,0 +1,212 @@ +--- +title: CU1Gate +description: API reference for qiskit.circuit.library.CU1Gate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CU1Gate +--- + +# CU1Gate + + + +`qiskit.circuit.library.CU1Gate(theta, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/u1.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Controlled-U1 gate. + +This is a diagonal and symmetric gate that induces a phase on the state of the target qubit, depending on the control state. + +**Circuit symbol:** + +```python +q_0: ─■── + │λ +q_1: ─■── +``` + +**Matrix representation:** + +$$ +CU1(\lambda) = + I \otimes |0\rangle\langle 0| + U1 \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & e^{i\lambda} + \end{pmatrix} +$$ + + + `CRZGate`: Due to the global phase difference in the matrix definitions of U1 and RZ, CU1 and CRZ are different gates with a relative phase difference. + + +Create new CU1 gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CU1Gate.base_class "qiskit.circuit.library.CU1Gate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Controlled version of this gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted CU1 gate ($CU1(\lambda)^{\dagger} = CU1(-\lambda)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CU3Gate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CU3Gate.md new file mode 100644 index 00000000000..1e97d6be50e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CU3Gate.md @@ -0,0 +1,217 @@ +--- +title: CU3Gate +description: API reference for qiskit.circuit.library.CU3Gate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CU3Gate +--- + +# CU3Gate + + + +`qiskit.circuit.library.CU3Gate(theta, phi, lam, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/u3.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Controlled-U3 gate (3-parameter two-qubit gate). + +This is a controlled version of the U3 gate (generic single qubit rotation). It is restricted to 3 parameters, and so cannot cover generic two-qubit controlled gates). + +**Circuit symbol:** + +```python +q_0: ──────■────── + ┌─────┴─────┐ +q_1: ┤ U3(ϴ,φ,λ) ├ + └───────────┘ +``` + +**Matrix representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +CU3(\theta, \phi, \lambda)\ q_0, q_1 = + I \otimes |0\rangle\langle 0| + + U3(\theta,\phi,\lambda) \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & \cos(\rotationangle) & 0 & -e^{i\lambda}\sin(\rotationangle) \\ + 0 & 0 & 1 & 0 \\ + 0 & e^{i\phi}\sin(\rotationangle) & 0 & e^{i(\phi+\lambda)}\cos(\rotationangle) + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───────────┐ + q_0: ┤ U3(ϴ,φ,λ) ├ + └─────┬─────┘ + q_1: ──────■────── + ``` + + $$ + \newcommand{\rotationangle}{\frac{\theta}{2}} + + CU3(\theta, \phi, \lambda)\ q_1, q_0 = + |0\rangle\langle 0| \otimes I + + |1\rangle\langle 1| \otimes U3(\theta,\phi,\lambda) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & \cos(\rotationangle) & -e^{i\lambda}\sin(\rotationangle) \\ + 0 & 0 & e^{i\phi}\sin(\rotationangle) & e^{i(\phi+\lambda)}\cos(\rotationangle) + \end{pmatrix} + $$ + + +Create new CU3 gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CU3Gate.base_class "qiskit.circuit.library.CU3Gate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted CU3 gate. + +$CU3(\theta,\phi,\lambda)^{\dagger} =CU3(-\theta,-\phi,-\lambda)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CUGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CUGate.md new file mode 100644 index 00000000000..dc2e6b48a14 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CUGate.md @@ -0,0 +1,207 @@ +--- +title: CUGate +description: API reference for qiskit.circuit.library.CUGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CUGate +--- + +# CUGate + + + +`qiskit.circuit.library.CUGate(theta, phi, lam, gamma, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/u.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Controlled-U gate (4-parameter two-qubit gate). + +This is a controlled version of the U gate (generic single qubit rotation), including a possible global phase $e^{i\gamma}$ of the U gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cu()`](qiskit.circuit.QuantumCircuit#cu "qiskit.circuit.QuantumCircuit.cu") method. + +**Circuit symbol:** + +```python +q_0: ──────■────── + ┌─────┴──────┐ +q_1: ┤ U(ϴ,φ,λ,γ) ├ + └────────────┘ +``` + +**Matrix representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +CU(\theta, \phi, \lambda, \gamma)\ q_0, q_1 = + I \otimes |0\rangle\langle 0| + + e^{i\gamma} U(\theta,\phi,\lambda) \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & e^{i\gamma}\cos(\rotationangle) & + 0 & -e^{i(\gamma + \lambda)}\sin(\rotationangle) \\ + 0 & 0 & 1 & 0 \\ + 0 & e^{i(\gamma+\phi)}\sin(\rotationangle) & + 0 & e^{i(\gamma+\phi+\lambda)}\cos(\rotationangle) + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌────────────┐ + q_0: ┤ U(ϴ,φ,λ,γ) ├ + └─────┬──────┘ + q_1: ──────■─────── + ``` + + $$ + \newcommand{\rotationangle}{\frac{\theta}{2}} + CU(\theta, \phi, \lambda, \gamma)\ q_1, q_0 = + |0\rangle\langle 0| \otimes I + + e^{i\gamma}|1\rangle\langle 1| \otimes U(\theta,\phi,\lambda) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & e^{i\gamma} \cos(\rotationangle) & -e^{i(\gamma + \lambda)}\sin(\rotationangle) \\ + 0 & 0 & + e^{i(\gamma + \phi)}\sin(\rotationangle) & e^{i(\gamma + \phi+\lambda)}\cos(\rotationangle) + \end{pmatrix} + $$ + + +Create new CU gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CUGate.base_class "qiskit.circuit.library.CUGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted CU gate. + +$CU(\theta,\phi,\lambda,\gamma)^{\dagger} = CU(-\theta,-\phi,-\lambda,-\gamma)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CXGate.md new file mode 100644 index 00000000000..9aac3159491 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CXGate.md @@ -0,0 +1,239 @@ +--- +title: CXGate +description: API reference for qiskit.circuit.library.CXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CXGate +--- + +# CXGate + + + +`qiskit.circuit.library.CXGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-X gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cx()`](qiskit.circuit.QuantumCircuit#cx "qiskit.circuit.QuantumCircuit.cx") and [`cnot()`](qiskit.circuit.QuantumCircuit#cnot "qiskit.circuit.QuantumCircuit.cnot") methods. + +**Circuit symbol:** + +```python +q_0: ──■── + ┌─┴─┐ +q_1: ┤ X ├ + └───┘ +``` + +**Matrix representation:** + +$$ +CX\ q_0, q_1 = + I \otimes |0\rangle\langle0| + X \otimes |1\rangle\langle1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 1 \\ + 0 & 0 & 1 & 0 \\ + 0 & 1 & 0 & 0 + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───┐ + q_0: ┤ X ├ + └─┬─┘ + q_1: ──■── + ``` + + $$ + CX\ q_1, q_0 = + |0 \rangle\langle 0| \otimes I + |1 \rangle\langle 1| \otimes X = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 0 & 1 \\ + 0 & 0 & 1 & 0 + \end{pmatrix} + $$ + + +In the computational basis, this gate flips the target qubit if the control qubit is in the $|1\rangle$ state. In this sense it is similar to a classical XOR gate. + +$$ +`|a, b\rangle \rightarrow |a, a \oplus b\rangle` + + +$$ + +Create new CX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CXGate.base_class "qiskit.circuit.library.CXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a controlled-X gate with more control lines. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted CX gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CYGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CYGate.md new file mode 100644 index 00000000000..99228a9d25c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CYGate.md @@ -0,0 +1,209 @@ +--- +title: CYGate +description: API reference for qiskit.circuit.library.CYGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CYGate +--- + +# CYGate + + + +`qiskit.circuit.library.CYGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/y.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-Y gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cy()`](qiskit.circuit.QuantumCircuit#cy "qiskit.circuit.QuantumCircuit.cy") method. + +**Circuit symbol:** + +```python +q_0: ──■── + ┌─┴─┐ +q_1: ┤ Y ├ + └───┘ +``` + +**Matrix representation:** + +$$ +CY\ q_0, q_1 = +I \otimes |0 \rangle\langle 0| + Y \otimes |1 \rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 0 & 0 & -i \\ + 0 & 0 & 1 & 0 \\ + 0 & i & 0 & 0 + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In many textbooks, controlled gates are presented with the assumption of more significant qubits as control, which in our case would be q\_1. Thus a textbook matrix for this gate will be: + + ```python + ┌───┐ + q_0: ┤ Y ├ + └─┬─┘ + q_1: ──■── + ``` + + $$ + CY\ q_1, q_0 = + |0 \rangle\langle 0| \otimes I + |1 \rangle\langle 1| \otimes Y = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 0 & -i \\ + 0 & 0 & i & 0 + \end{pmatrix} + $$ + + +Create new CY gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CYGate.base_class "qiskit.circuit.library.CYGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted CY gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.CZGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.CZGate.md new file mode 100644 index 00000000000..01d2b7e0f3e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.CZGate.md @@ -0,0 +1,190 @@ +--- +title: CZGate +description: API reference for qiskit.circuit.library.CZGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.CZGate +--- + +# CZGate + + + +`qiskit.circuit.library.CZGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/z.py "view source code") + +Bases: [`SingletonControlledGate`](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +Controlled-Z gate. + +This is a Clifford and symmetric gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`cz()`](qiskit.circuit.QuantumCircuit#cz "qiskit.circuit.QuantumCircuit.cz") method. + +**Circuit symbol:** + +```python +q_0: ─■─ + │ +q_1: ─■─ +``` + +**Matrix representation:** + +$$ +CZ\ q_0, q_1 = + I \otimes |0\rangle\langle 0| + Z \otimes |1\rangle\langle 1| = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 0 & 0 & -1 + \end{pmatrix} +$$ + +In the computational basis, this gate flips the phase of the target qubit if the control qubit is in the $|1\rangle$ state. + +Create new CZ gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.CZGate.base_class "qiskit.circuit.library.CZGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted CZ gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.DCXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.DCXGate.md new file mode 100644 index 00000000000..c2e34acbfd6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.DCXGate.md @@ -0,0 +1,141 @@ +--- +title: DCXGate +description: API reference for qiskit.circuit.library.DCXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.DCXGate +--- + +# DCXGate + + + +`qiskit.circuit.library.DCXGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/dcx.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +Double-CNOT gate. + +A 2-qubit Clifford gate consisting of two back-to-back CNOTs with alternate controls. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`dcx()`](qiskit.circuit.QuantumCircuit#dcx "qiskit.circuit.QuantumCircuit.dcx") method. + +```python + ┌───┐ +q_0: ──■──┤ X ├ + ┌─┴─┐└─┬─┘ +q_1: ┤ X ├──■── + └───┘ +``` + +This is a classical logic gate, equivalent to a CNOT-SWAP (CNS) sequence, and locally equivalent to an iSWAP. + +$$ +DCX\ q_0, q_1 = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 0 & 0 & 1 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 + \end{pmatrix} +$$ + +Create new DCX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.DCXGate.base_class "qiskit.circuit.library.DCXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.Diagonal.md b/docs/api/qiskit/0.46/qiskit.circuit.library.Diagonal.md new file mode 100644 index 00000000000..2d0660b1c8b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.Diagonal.md @@ -0,0 +1,255 @@ +--- +title: Diagonal +description: API reference for qiskit.circuit.library.Diagonal +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.Diagonal +--- + +# Diagonal + + + +`qiskit.circuit.library.Diagonal(diag)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/diagonal.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Diagonal circuit. + +Circuit symbol: + +```python + ┌───────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 Diagonal ├ + │ │ +q_2: ┤2 ├ + └───────────┘ +``` + +Matrix form: + +$$ +\text{DiagonalGate}\ q_0, q_1, .., q_{n-1} = + \begin{pmatrix} + D[0] & 0 & \dots & 0 \\ + 0 & D[1] & \dots & 0 \\ + \vdots & \vdots & \ddots & 0 \\ + 0 & 0 & \dots & D[n-1] + \end{pmatrix} + + +$$ + +Diagonal gates are useful as representations of Boolean functions, as they can map from $\{0,1\}^{2^n}$ to $\{0,1\}^{2^n}$ space. For example a phase oracle can be seen as a diagonal gate with $\{1, -1\}$ on the diagonals. Such an oracle will induce a $+1$ or :math\`-1\` phase on the amplitude of any corresponding basis state. + +Diagonal gates appear in many classically hard oracular problems such as Forrelation or Hidden Shift circuits. + +Diagonal gates are represented and simulated more efficiently than a dense $2^n \times 2^n$ unitary matrix. + +The reference implementation is via the method described in Theorem 7 of \[1]. The code is based on Emanuel Malvetti’s semester thesis at ETH in 2018, supervised by Raban Iten and Prof. Renato Renner. + +**Reference:** + +\[1] Shende et al., Synthesis of Quantum Logic Circuits, 2009 [arXiv:0406176](https://arxiv.org/pdf/quant-ph/0406176.pdf) + +**Parameters** + +**diag** (*Sequence\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]*) – List of the $2^k$ diagonal entries (for a diagonal gate on $k$ qubits). + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the list of the diagonal entries or the qubit list is in bad format; if the number of diagonal entries is not $2^k$, where $k$ denotes the number of qubits. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.DiagonalGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.DiagonalGate.md new file mode 100644 index 00000000000..33fd6d7b987 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.DiagonalGate.md @@ -0,0 +1,137 @@ +--- +title: DiagonalGate +description: API reference for qiskit.circuit.library.DiagonalGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.DiagonalGate +--- + +# DiagonalGate + + + +`qiskit.circuit.library.DiagonalGate(diag)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/diagonal.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Gate implementing a diagonal transformation. + +**Parameters** + +**diag** (*Sequence\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]*) – list of the $2^k$ diagonal entries (for a diagonal gate on $k$ qubits). + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.DiagonalGate.base_class "qiskit.circuit.library.DiagonalGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return the inverse of the diagonal gate. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Diagonal Gate parameter should accept complex (in addition to the Gate parameter types) and always return build-in complex. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.DraperQFTAdder.md b/docs/api/qiskit/0.46/qiskit.circuit.library.DraperQFTAdder.md new file mode 100644 index 00000000000..1075c4a53a2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.DraperQFTAdder.md @@ -0,0 +1,254 @@ +--- +title: DraperQFTAdder +description: API reference for qiskit.circuit.library.DraperQFTAdder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.DraperQFTAdder +--- + +# DraperQFTAdder + + + +`qiskit.circuit.library.DraperQFTAdder(num_state_qubits, kind='fixed', name='DraperQFTAdder')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/adders/draper_qft_adder.py "view source code") + +Bases: `Adder` + +A circuit that uses QFT to perform in-place addition on two qubit registers. + +For registers with $n$ qubits, the QFT adder can perform addition modulo $2^n$ (with `kind="fixed"`) or ordinary addition by adding a carry qubits (with `kind="half"`). + +As an example, a non-fixed\_point QFT adder circuit that performs addition on two 2-qubit sized registers is as follows: + +```python + a_0: ─────────■──────■────────────────────────■──────────────── + │ │ │ + a_1: ─────────┼──────┼────────■──────■────────┼──────────────── + ┌──────┐ │P(π) │ │ │ │ ┌───────┐ + b_0: ┤0 ├─■──────┼────────┼──────┼────────┼───────┤0 ├ + │ │ │P(π/2) │P(π) │ │ │ │ + b_1: ┤1 qft ├────────■────────■──────┼────────┼───────┤1 iqft ├ + │ │ │P(π/2) │P(π/4) │ │ +cout_0: ┤2 ├────────────────────────■────────■───────┤2 ├ + └──────┘ └───────┘ +``` + +**References:** + +\[1] T. G. Draper, Addition on a Quantum Computer, 2000. [arXiv:quant-ph/0008033](https://arxiv.org/pdf/quant-ph/0008033.pdf) + +\[2] Ruiz-Perez et al., Quantum arithmetic with the Quantum Fourier Transform, 2017. [arXiv:1411.5949](https://arxiv.org/pdf/1411.5949.pdf) + +\[3] Vedral et al., Quantum Networks for Elementary Arithmetic Operations, 1995. [arXiv:quant-ph/9511018](https://arxiv.org/pdf/quant-ph/9511018.pdf) + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits in either input register for state $|a\rangle$ or $|b\rangle$. The two input registers must have the same number of qubits. +* **kind** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The kind of adder, can be `'half'` for a half adder or `'fixed'` for a fixed-sized adder. A half adder contains a carry-out to represent the most-significant bit, but the fixed-sized adder doesn’t and hence performs addition modulo `2 ** num_state_qubits`. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit object. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `num_state_qubits` is lower than 1. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits, i.e. the number of bits in each input register. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.ECRGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.ECRGate.md new file mode 100644 index 00000000000..6338fdb1fe9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.ECRGate.md @@ -0,0 +1,175 @@ +--- +title: ECRGate +description: API reference for qiskit.circuit.library.ECRGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.ECRGate +--- + +# ECRGate + + + +`qiskit.circuit.library.ECRGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/ecr.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +An echoed cross-resonance gate. + +This gate is maximally entangling and is equivalent to a CNOT up to single-qubit pre-rotations. The echoing procedure mitigates some unwanted terms (terms other than ZX) to cancel in an experiment. More specifically, this gate implements $\frac{1}{\sqrt{2}}(IX-XY)$. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`ecr()`](qiskit.circuit.QuantumCircuit#ecr "qiskit.circuit.QuantumCircuit.ecr") method. + +**Circuit Symbol:** + +```python + ┌─────────┐ ┌────────────┐┌────────┐┌─────────────┐ +q_0: ┤0 ├ q_0: ┤0 ├┤ RX(pi) ├┤0 ├ + │ ECR │ = │ RZX(pi/4) │└────────┘│ RZX(-pi/4) │ +q_1: ┤1 ├ q_1: ┤1 ├──────────┤1 ├ + └─────────┘ └────────────┘ └─────────────┘ +``` + +**Matrix Representation:** + +$$ +ECR\ q_0, q_1 = \frac{1}{\sqrt{2}} + \begin{pmatrix} + 0 & 1 & 0 & i \\ + 1 & 0 & -i & 0 \\ + 0 & i & 0 & 1 \\ + -i & 0 & 1 & 0 + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In the above example we apply the gate on (q\_0, q\_1) which results in the $X \otimes Z$ tensor order. Instead, if we apply it on (q\_1, q\_0), the matrix will be $Z \otimes X$: + + ```python + ┌─────────┐ + q_0: ┤1 ├ + │ ECR │ + q_1: ┤0 ├ + └─────────┘ + ``` + + $$ + ECR\ q_0, q_1 = \frac{1}{\sqrt{2}} + \begin{pmatrix} + 0 & 0 & 1 & i \\ + 0 & 0 & i & 1 \\ + 1 & -i & 0 & 0 \\ + -i & 1 & 0 & 0 + \end{pmatrix} + $$ + + +Create new ECR gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.ECRGate.base_class "qiskit.circuit.library.ECRGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse ECR gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.EfficientSU2.md b/docs/api/qiskit/0.46/qiskit.circuit.library.EfficientSU2.md new file mode 100644 index 00000000000..a510dad5833 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.EfficientSU2.md @@ -0,0 +1,351 @@ +--- +title: EfficientSU2 +description: API reference for qiskit.circuit.library.EfficientSU2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.EfficientSU2 +--- + +# EfficientSU2 + + + +`qiskit.circuit.library.EfficientSU2(num_qubits=None, su2_gates=None, entanglement='reverse_linear', reps=3, skip_unentangled_qubits=False, skip_final_rotation_layer=False, parameter_prefix='θ', insert_barriers=False, initial_state=None, name='EfficientSU2', flatten=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/n_local/efficient_su2.py "view source code") + +Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") + +The hardware efficient SU(2) 2-local circuit. + +The `EfficientSU2` circuit consists of layers of single qubit operations spanned by SU(2) and $CX$ entanglements. This is a heuristic pattern that can be used to prepare trial wave functions for variational quantum algorithms or classification circuit for machine learning. + +SU(2) stands for special unitary group of degree 2, its elements are $2 \times 2$ unitary matrices with determinant 1, such as the Pauli rotation gates. + +On 3 qubits and using the Pauli $Y$ and $Z$ su2\_gates as single qubit gates, the hardware efficient SU(2) circuit is represented by: + +```python +┌──────────┐┌──────────┐ ░ ░ ░ ┌───────────┐┌───────────┐ +┤ RY(θ[0]) ├┤ RZ(θ[3]) ├─░────────■───░─ ... ─░─┤ RY(θ[12]) ├┤ RZ(θ[15]) ├ +├──────────┤├──────────┤ ░ ┌─┴─┐ ░ ░ ├───────────┤├───────────┤ +┤ RY(θ[1]) ├┤ RZ(θ[4]) ├─░───■──┤ X ├─░─ ... ─░─┤ RY(θ[13]) ├┤ RZ(θ[16]) ├ +├──────────┤├──────────┤ ░ ┌─┴─┐└───┘ ░ ░ ├───────────┤├───────────┤ +┤ RY(θ[2]) ├┤ RZ(θ[5]) ├─░─┤ X ├──────░─ ... ─░─┤ RY(θ[14]) ├┤ RZ(θ[17]) ├ +└──────────┘└──────────┘ ░ └───┘ ░ ░ └───────────┘└───────────┘ +``` + +See [`RealAmplitudes`](qiskit.circuit.library.RealAmplitudes "qiskit.circuit.library.RealAmplitudes") for more detail on the possible arguments and options such as skipping unentanglement qubits, which apply here too. + +**Examples** + +```python +>>> circuit = EfficientSU2(3, reps=1) +>>> print(circuit) + ┌──────────┐┌──────────┐ ┌──────────┐┌──────────┐ +q_0: ┤ RY(θ[0]) ├┤ RZ(θ[3]) ├──■────■──┤ RY(θ[6]) ├┤ RZ(θ[9]) ├───────────── + ├──────────┤├──────────┤┌─┴─┐ │ └──────────┘├──────────┤┌───────────┐ +q_1: ┤ RY(θ[1]) ├┤ RZ(θ[4]) ├┤ X ├──┼───────■──────┤ RY(θ[7]) ├┤ RZ(θ[10]) ├ + ├──────────┤├──────────┤└───┘┌─┴─┐ ┌─┴─┐ ├──────────┤├───────────┤ +q_2: ┤ RY(θ[2]) ├┤ RZ(θ[5]) ├─────┤ X ├───┤ X ├────┤ RY(θ[8]) ├┤ RZ(θ[11]) ├ + └──────────┘└──────────┘ └───┘ └───┘ └──────────┘└───────────┘ +``` + +```python +>>> ansatz = EfficientSU2(4, su2_gates=['rx', 'y'], entanglement='circular', reps=1) +>>> qc = QuantumCircuit(4) # create a circuit and append the RY variational form +>>> qc.compose(ansatz, inplace=True) +>>> qc.draw() + ┌──────────┐┌───┐┌───┐ ┌──────────┐ ┌───┐ +q_0: ┤ RX(θ[0]) ├┤ Y ├┤ X ├──■──┤ RX(θ[4]) ├───┤ Y ├───────────────────── + ├──────────┤├───┤└─┬─┘┌─┴─┐└──────────┘┌──┴───┴───┐ ┌───┐ +q_1: ┤ RX(θ[1]) ├┤ Y ├──┼──┤ X ├─────■──────┤ RX(θ[5]) ├───┤ Y ├───────── + ├──────────┤├───┤ │ └───┘ ┌─┴─┐ └──────────┘┌──┴───┴───┐┌───┐ +q_2: ┤ RX(θ[2]) ├┤ Y ├──┼──────────┤ X ├─────────■──────┤ RX(θ[6]) ├┤ Y ├ + ├──────────┤├───┤ │ └───┘ ┌─┴─┐ ├──────────┤├───┤ +q_3: ┤ RX(θ[3]) ├┤ Y ├──■──────────────────────┤ X ├────┤ RX(θ[7]) ├┤ Y ├ + └──────────┘└───┘ └───┘ └──────────┘└───┘ +``` + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits of the EfficientSU2 circuit. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Specifies how often the structure of a rotation layer followed by an entanglement layer is repeated. +* **su2\_gates** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – The SU(2) single qubit gates to apply in single qubit gate layers. If only one gate is provided, the same gate is applied to each qubit. If a list of gates is provided, all gates are applied to each qubit in the provided order. +* **entanglement** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Specifies the entanglement structure. Can be a string (‘full’, ‘linear’ , ‘reverse\_linear’, ‘circular’ or ‘sca’), a list of integer-pairs specifying the indices of qubits entangled with one another, or a callable returning such a list provided with the index of the entanglement layer. Default to ‘reverse\_linear’ entanglement. Note that ‘reverse\_linear’ entanglement provides the same unitary as ‘full’ with fewer entangling gates. See the Examples section of [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.TwoLocal") for more detail. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A QuantumCircuit object to prepend to the circuit. +* **skip\_unentangled\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, the single qubit gates are only applied to qubits that are entangled with another qubit. If False, the single qubit gates are applied to each qubit in the Ansatz. Defaults to False. +* **skip\_final\_rotation\_layer** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If False, a rotation layer is added at the end of the ansatz. If True, no rotation layer is added. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The parameterized gates require a parameter to be defined, for which we use [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector"). +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, barriers are inserted in between each layer. If False, no barriers are inserted. +* **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Set this to `True` to output a flat circuit instead of nesting it inside multiple layers of gate objects. By default currently the contents of the output circuit will be wrapped in nested objects for cleaner visualization. However, if you’re using this circuit for anything besides visualization its **strongly** recommended to set this flag to `True` to avoid a large performance overhead for parameter binding. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of total parameters that can be set to distinct values. + +This does not change when the parameters are bound or exchanged for same parameters, and therefore is different from `num_parameters` which counts the number of unique [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects currently in the circuit. + +**Returns** + +The number of parameters originally available in the circuit. + + + This quantity does not require the circuit to be built yet. + + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +Return the parameter bounds. + +**Returns** + +The parameter bounds. + + + +### parameters + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.EvolvedOperatorAnsatz.md b/docs/api/qiskit/0.46/qiskit.circuit.library.EvolvedOperatorAnsatz.md new file mode 100644 index 00000000000..a689c6d8fe3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.EvolvedOperatorAnsatz.md @@ -0,0 +1,319 @@ +--- +title: EvolvedOperatorAnsatz +description: API reference for qiskit.circuit.library.EvolvedOperatorAnsatz +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.EvolvedOperatorAnsatz +--- + +# EvolvedOperatorAnsatz + + + +`qiskit.circuit.library.EvolvedOperatorAnsatz(operators=None, reps=1, evolution=None, insert_barriers=False, name='EvolvedOps', parameter_prefix='t', initial_state=None, flatten=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/evolved_operator_ansatz.py "view source code") + +Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") + +The evolved operator ansatz. + +**Parameters** + +* **operators** (*BaseOperator |* [*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *| None*) – The operators to evolve. If a circuit is passed, we assume it implements an already evolved operator and thus the circuit is not evolved again. Can be a single operator (circuit) or a list of operators (and circuits). +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of times to repeat the evolved operators. +* **evolution** ([*EvolutionBase*](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.EvolutionBase") *|*[*EvolutionSynthesis*](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") *| None*) – A specification of which evolution synthesis to use for the [`PauliEvolutionGate`](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate"), if the operator is from [`qiskit.quantum_info`](quantum_info#module-qiskit.quantum_info "qiskit.quantum_info") or an opflow converter object if the operator is from [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow"). Defaults to first order Trotterization. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to insert barriers in between each evolution. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| Sequence\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Set the names of the circuit parameters. If a string, the same prefix will be used for each parameters. Can also be a list to specify a prefix per operator. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object to prepend to the circuit. +* **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Set this to `True` to output a flat circuit instead of nesting it inside multiple layers of gate objects. By default currently the contents of the output circuit will be wrapped in nested objects for cleaner visualization. However, if you’re using this circuit for anything besides visualization its **strongly** recommended to set this flag to `True` to avoid a large performance overhead for parameter binding. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### evolution + +The evolution converter used to compute the evolution. + +**Returns** + +The evolution converter used to compute the evolution. + +**Return type** + +[EvolutionBase](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.EvolutionBase") or [EvolutionSynthesis](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of total parameters that can be set to distinct values. + +This does not change when the parameters are bound or exchanged for same parameters, and therefore is different from `num_parameters` which counts the number of unique [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects currently in the circuit. + +**Returns** + +The number of parameters originally available in the circuit. + + + This quantity does not require the circuit to be built yet. + + + + +### num\_qubits + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### operators + +The operators that are evolved in this circuit. + +**Returns** + +The operators to be evolved (and circuits) contained in this ansatz. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If `None` is returned, problem is fully unbounded. + + + +### parameters + + + +### preferred\_init\_points + +Getter of preferred initial points based on the given initial state. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.ExactReciprocal.md b/docs/api/qiskit/0.46/qiskit.circuit.library.ExactReciprocal.md new file mode 100644 index 00000000000..f21867e703e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.ExactReciprocal.md @@ -0,0 +1,224 @@ +--- +title: ExactReciprocal +description: API reference for qiskit.circuit.library.ExactReciprocal +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.ExactReciprocal +--- + +# ExactReciprocal + + + +`qiskit.circuit.library.ExactReciprocal(num_state_qubits, scaling, neg_vals=False, name='1/x')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/exact_reciprocal.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Exact reciprocal + +$$ +|x\rangle |0\rangle \mapsto \cos(1/x)|x\rangle|0\rangle + \sin(1/x)|x\rangle |1\rangle +$$ + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits representing the value to invert. +* **scaling** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Scaling factor $s$ of the reciprocal function, i.e. to compute $s / x$. +* **neg\_vals** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether $x$ might represent negative values. In this case the first qubit is the sign, with $|1\rangle$ for negative and $|0\rangle$ for positive. For the negative case it is assumed that the remaining string represents $1 - x$. This is because $e^{-2 \pi i x} = e^{2 \pi i (1 - x)}$ for $x \in [0,1)$. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the object. + + + It is assumed that the binary string $x$ represents a number \< 1. + + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.ExcitationPreserving.md b/docs/api/qiskit/0.46/qiskit.circuit.library.ExcitationPreserving.md new file mode 100644 index 00000000000..c753ee5bd58 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.ExcitationPreserving.md @@ -0,0 +1,370 @@ +--- +title: ExcitationPreserving +description: API reference for qiskit.circuit.library.ExcitationPreserving +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.ExcitationPreserving +--- + +# ExcitationPreserving + + + +`qiskit.circuit.library.ExcitationPreserving(num_qubits=None, mode='iswap', entanglement='full', reps=3, skip_unentangled_qubits=False, skip_final_rotation_layer=False, parameter_prefix='θ', insert_barriers=False, initial_state=None, name='ExcitationPreserving', flatten=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/n_local/excitation_preserving.py "view source code") + +Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") + +The heuristic excitation-preserving wave function ansatz. + +The `ExcitationPreserving` circuit preserves the ratio of $|00\rangle$, $|01\rangle + |10\rangle$ and $|11\rangle$ states. To this end, this circuit uses two-qubit interactions of the form + +$$ +\newcommand{\rotationangle}{\theta/2} + +\begin{pmatrix} +1 & 0 & 0 & 0 \\ +0 & \cos\left(\rotationangle\right) & -i\sin\left(\rotationangle\right) & 0 \\ +0 & -i\sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) & 0 \\ +0 & 0 & 0 & e^{-i\phi} +\end{pmatrix} +$$ + +for the mode `'fsim'` or with $e^{-i\phi} = 1$ for the mode `'iswap'`. + +Note that other wave functions, such as UCC-ansatzes, are also excitation preserving. However these can become complex quickly, while this heuristically motivated circuit follows a simpler pattern. + +This trial wave function consists of layers of $Z$ rotations with 2-qubit entanglements. The entangling is creating using $XX+YY$ rotations and optionally a controlled-phase gate for the mode `'fsim'`. + +See [`RealAmplitudes`](qiskit.circuit.library.RealAmplitudes "qiskit.circuit.library.RealAmplitudes") for more detail on the possible arguments and options such as skipping unentanglement qubits, which apply here too. + +The rotations of the ExcitationPreserving ansatz can be written as + +**Examples** + +```python +>>> ansatz = ExcitationPreserving(3, reps=1, insert_barriers=True, entanglement='linear') +>>> print(ansatz) # show the circuit + ┌──────────┐ ░ ┌────────────┐┌────────────┐ ░ ┌──────────┐ +q_0: ┤ RZ(θ[0]) ├─░─┤0 ├┤0 ├─────────────────────────────░─┤ RZ(θ[5]) ├ + ├──────────┤ ░ │ RXX(θ[3]) ││ RYY(θ[3]) │┌────────────┐┌────────────┐ ░ ├──────────┤ +q_1: ┤ RZ(θ[1]) ├─░─┤1 ├┤1 ├┤0 ├┤0 ├─░─┤ RZ(θ[6]) ├ + ├──────────┤ ░ └────────────┘└────────────┘│ RXX(θ[4]) ││ RYY(θ[4]) │ ░ ├──────────┤ +q_2: ┤ RZ(θ[2]) ├─░─────────────────────────────┤1 ├┤1 ├─░─┤ RZ(θ[7]) ├ + └──────────┘ ░ └────────────┘└────────────┘ ░ └──────────┘ +``` + +```python +>>> ansatz = ExcitationPreserving(2, reps=1) +>>> qc = QuantumCircuit(2) # create a circuit and append the RY variational form +>>> qc.cry(0.2, 0, 1) # do some previous operation +>>> qc.compose(ansatz, inplace=True) # add the swaprz +>>> qc.draw() + ┌──────────┐┌────────────┐┌────────────┐┌──────────┐ +q_0: ─────■─────┤ RZ(θ[0]) ├┤0 ├┤0 ├┤ RZ(θ[3]) ├ + ┌────┴────┐├──────────┤│ RXX(θ[2]) ││ RYY(θ[2]) │├──────────┤ +q_1: ┤ RY(0.2) ├┤ RZ(θ[1]) ├┤1 ├┤1 ├┤ RZ(θ[4]) ├ + └─────────┘└──────────┘└────────────┘└────────────┘└──────────┘ +``` + +```python +>>> ansatz = ExcitationPreserving(3, reps=1, mode='fsim', entanglement=[[0,2]], +... insert_barriers=True) +>>> print(ansatz) + ┌──────────┐ ░ ┌────────────┐┌────────────┐ ░ ┌──────────┐ +q_0: ┤ RZ(θ[0]) ├─░─┤0 ├┤0 ├─■──────░─┤ RZ(θ[5]) ├ + ├──────────┤ ░ │ ││ │ │ ░ ├──────────┤ +q_1: ┤ RZ(θ[1]) ├─░─┤ RXX(θ[3]) ├┤ RYY(θ[3]) ├─┼──────░─┤ RZ(θ[6]) ├ + ├──────────┤ ░ │ ││ │ │θ[4] ░ ├──────────┤ +q_2: ┤ RZ(θ[2]) ├─░─┤1 ├┤1 ├─■──────░─┤ RZ(θ[7]) ├ + └──────────┘ ░ └────────────┘└────────────┘ ░ └──────────┘ +``` + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits of the ExcitationPreserving circuit. +* **mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Choose the entangler mode, can be ‘iswap’ or ‘fsim’. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Specifies how often the structure of a rotation layer followed by an entanglement layer is repeated. +* **entanglement** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Specifies the entanglement structure. Can be a string (‘full’, ‘linear’ or ‘sca’), a list of integer-pairs specifying the indices of qubits entangled with one another, or a callable returning such a list provided with the index of the entanglement layer. See the Examples section of [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.TwoLocal") for more detail. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A QuantumCircuit object to prepend to the circuit. +* **skip\_unentangled\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, the single qubit gates are only applied to qubits that are entangled with another qubit. If False, the single qubit gates are applied to each qubit in the Ansatz. Defaults to False. +* **skip\_final\_rotation\_layer** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, a rotation layer is added at the end of the ansatz. If False, no rotation layer is added. Defaults to True. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The parameterized gates require a parameter to be defined, for which we use [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector"). +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, barriers are inserted in between each layer. If False, no barriers are inserted. +* **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Set this to `True` to output a flat circuit instead of nesting it inside multiple layers of gate objects. By default currently the contents of the output circuit will be wrapped in nested objects for cleaner visualization. However, if you’re using this circuit for anything besides visualization its **strongly** recommended to set this flag to `True` to avoid a large performance overhead for parameter binding. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the selected mode is not supported. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of total parameters that can be set to distinct values. + +This does not change when the parameters are bound or exchanged for same parameters, and therefore is different from `num_parameters` which counts the number of unique [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects currently in the circuit. + +**Returns** + +The number of parameters originally available in the circuit. + + + This quantity does not require the circuit to be built yet. + + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +Return the parameter bounds. + +**Returns** + +The parameter bounds. + + + +### parameters + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.FourierChecking.md b/docs/api/qiskit/0.46/qiskit.circuit.library.FourierChecking.md new file mode 100644 index 00000000000..934e100e187 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.FourierChecking.md @@ -0,0 +1,238 @@ +--- +title: FourierChecking +description: API reference for qiskit.circuit.library.FourierChecking +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.FourierChecking +--- + +# FourierChecking + + + +`qiskit.circuit.library.FourierChecking(f, g)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/fourier_checking.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Fourier checking circuit. + +The circuit for the Fourier checking algorithm, introduced in \[1], involves a layer of Hadamards, the function $f$, another layer of Hadamards, the function $g$, followed by a final layer of Hadamards. The functions $f$ and $g$ are classical functions realized as phase oracles (diagonal operators with \{-1, 1} on the diagonal). + +The probability of observing the all-zeros string is $p(f,g)$. The algorithm solves the promise Fourier checking problem, which decides if f is correlated with the Fourier transform of g, by testing if $p(f,g) <= 0.01$ or $p(f,g) >= 0.05$, promised that one or the other of these is true. + +The functions $f$ and $g$ are currently implemented from their truth tables but could be represented concisely and implemented efficiently for special classes of functions. + +Fourier checking is a special case of $k$-fold forrelation \[2]. + +**Reference:** + +\[1] S. Aaronson, BQP and the Polynomial Hierarchy, 2009 (Section 3.2). [arXiv:0910.4698](https://arxiv.org/abs/0910.4698) + +\[2] S. Aaronson, A. Ambainis, Forrelation: a problem that optimally separates quantum from classical computing, 2014. [arXiv:1411.5729](https://arxiv.org/abs/1411.5729) + +Create Fourier checking circuit. + +**Parameters** + +* **f** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – truth table for f, length 2\*\*n list of \{1,-1}. +* **g** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – truth table for g, length 2\*\*n list of \{1,-1}. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the inputs f and g are not valid. + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-FourierChecking-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-FourierChecking-1.png) + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 167` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.FunctionalPauliRotations.md b/docs/api/qiskit/0.46/qiskit.circuit.library.FunctionalPauliRotations.md new file mode 100644 index 00000000000..1684121a616 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.FunctionalPauliRotations.md @@ -0,0 +1,188 @@ +--- +title: FunctionalPauliRotations +description: API reference for qiskit.circuit.library.FunctionalPauliRotations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.FunctionalPauliRotations +--- + +# FunctionalPauliRotations + + + +`qiskit.circuit.library.FunctionalPauliRotations(num_state_qubits=None, basis='Y', name='F')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/functional_pauli_rotations.py "view source code") + +Bases: `BlueprintCircuit`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class for functional Pauli rotations. + +Create a new functional Pauli rotation circuit. + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits representing the state $|x\rangle$. +* **basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The kind of Pauli rotation to use. Must be ‘X’, ‘Y’ or ‘Z’. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit object. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### basis + +The kind of Pauli rotation to be used. + +Set the basis to ‘X’, ‘Y’ or ‘Z’ for controlled-X, -Y, or -Z rotations respectively. + +**Returns** + +The kind of Pauli rotation used in controlled rotation. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 169` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +The minimum number of ancilla qubits in the circuit. + +**Returns** + +The minimal number of ancillas required. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits representing the state $|x\rangle$. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GMS.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GMS.md new file mode 100644 index 00000000000..5f3778d8236 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GMS.md @@ -0,0 +1,247 @@ +--- +title: GMS +description: API reference for qiskit.circuit.library.GMS +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GMS +--- + +# GMS + + + +`qiskit.circuit.library.GMS(num_qubits, theta)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/gms.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Global Mølmer–Sørensen gate. + +**Circuit symbol:** + +```python + ┌───────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 GMS ├ + │ │ +q_2: ┤2 ├ + └───────────┘ +``` + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-GMS-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-GMS-1.png) + +The Mølmer–Sørensen gate is native to ion-trap systems. The global MS can be applied to multiple ions to entangle multiple qubits simultaneously \[1]. + +In the two-qubit case, this is equivalent to an XX(theta) interaction, and is thus reduced to the RXXGate. The global MS gate is a sum of XX interactions on all pairs \[2]. + +$$ +GMS(\chi_{12}, \chi_{13}, ..., \chi_{n-1 n}) = +exp(-i \sum_{i=1}^{n} \sum_{j=i+1}^{n} X{\otimes}X \frac{\chi_{ij}}{2}) +$$ + +**References:** + +\[1] Sørensen, A. and Mølmer, K., Multi-particle entanglement of hot trapped ions. Physical Review Letters. 82 (9): 1835–1838. [arXiv:9810040](https://arxiv.org/abs/quant-ph/9810040) + +\[2] Maslov, D. and Nam, Y., Use of global interactions in efficient quantum circuit constructions. New Journal of Physics, 20(3), p.033018. [arXiv:1707.06356](https://arxiv.org/abs/1707.06356) + +Create a new Global Mølmer–Sørensen (GMS) gate. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – width of gate. +* **theta** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a num\_qubits x num\_qubits symmetric matrix of interaction angles for each qubit pair. The upper triangle is considered. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 170` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GR.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GR.md new file mode 100644 index 00000000000..05a546b6989 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GR.md @@ -0,0 +1,241 @@ +--- +title: GR +description: API reference for qiskit.circuit.library.GR +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GR +--- + +# GR + + + +`qiskit.circuit.library.GR(num_qubits, theta, phi)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/gr.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Global R gate. + +**Circuit symbol:** + +```python + ┌──────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 GR(ϴ,φ) ├ + │ │ +q_2: ┤2 ├ + └──────────┘ +``` + +The global R gate is native to atomic systems (ion traps, cold neutrals). The global R can be applied to multiple qubits simultaneously. + +In the one-qubit case, this is equivalent to an R(theta, phi) operation, and is thus reduced to the RGate. The global R gate is a direct sum of R operations on all individual qubits. + +$$ +GR(\theta, \phi) = \exp(-i \sum_{i=1}^{n} (\cos(\phi)X_i + \sin(\phi)Y_i) \theta/2) +$$ + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-GR-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-GR-1.png) + +Create a new Global R (GR) gate. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **theta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – rotation angle about axis determined by phi +* **phi** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – angle of rotation axis in xy-plane + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 179` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GRX.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GRX.md new file mode 100644 index 00000000000..97ceb86234e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GRX.md @@ -0,0 +1,240 @@ +--- +title: GRX +description: API reference for qiskit.circuit.library.GRX +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GRX +--- + +# GRX + + + +`qiskit.circuit.library.GRX(num_qubits, theta)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/gr.py "view source code") + +Bases: [`GR`](qiskit.circuit.library.GR "qiskit.circuit.library.generalized_gates.gr.GR") + +Global RX gate. + +**Circuit symbol:** + +```python + ┌──────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 GRX(ϴ) ├ + │ │ +q_2: ┤2 ├ + └──────────┘ +``` + +The global RX gate is native to atomic systems (ion traps, cold neutrals). The global RX can be applied to multiple qubits simultaneously. + +In the one-qubit case, this is equivalent to an RX(theta) operations, and is thus reduced to the RXGate. The global RX gate is a direct sum of RX operations on all individual qubits. + +$$ +GRX(\theta) = \exp(-i \sum_{i=1}^{n} X_i \theta/2) +$$ + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-GRX-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-GRX-1.png) + +Create a new Global RX (GRX) gate. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **theta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – rotation angle about x-axis + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 180` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GRY.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GRY.md new file mode 100644 index 00000000000..ebbf81c46f2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GRY.md @@ -0,0 +1,240 @@ +--- +title: GRY +description: API reference for qiskit.circuit.library.GRY +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GRY +--- + +# GRY + + + +`qiskit.circuit.library.GRY(num_qubits, theta)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/gr.py "view source code") + +Bases: [`GR`](qiskit.circuit.library.GR "qiskit.circuit.library.generalized_gates.gr.GR") + +Global RY gate. + +**Circuit symbol:** + +```python + ┌──────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 GRY(ϴ) ├ + │ │ +q_2: ┤2 ├ + └──────────┘ +``` + +The global RY gate is native to atomic systems (ion traps, cold neutrals). The global RY can be applied to multiple qubits simultaneously. + +In the one-qubit case, this is equivalent to an RY(theta) operation, and is thus reduced to the RYGate. The global RY gate is a direct sum of RY operations on all individual qubits. + +$$ +GRY(\theta) = \exp(-i \sum_{i=1}^{n} Y_i \theta/2) +$$ + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-GRY-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-GRY-1.png) + +Create a new Global RY (GRY) gate. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **theta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – rotation angle about y-axis + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 180` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GRZ.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GRZ.md new file mode 100644 index 00000000000..b0e9595effa --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GRZ.md @@ -0,0 +1,240 @@ +--- +title: GRZ +description: API reference for qiskit.circuit.library.GRZ +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GRZ +--- + +# GRZ + + + +`qiskit.circuit.library.GRZ(num_qubits, phi)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/gr.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Global RZ gate. + +**Circuit symbol:** + +```python + ┌──────────┐ +q_0: ┤0 ├ + │ │ +q_1: ┤1 GRZ(φ) ├ + │ │ +q_2: ┤2 ├ + └──────────┘ +``` + +The global RZ gate is native to atomic systems (ion traps, cold neutrals). The global RZ can be applied to multiple qubits simultaneously. + +In the one-qubit case, this is equivalent to an RZ(phi) operation, and is thus reduced to the RZGate. The global RZ gate is a direct sum of RZ operations on all individual qubits. + +$$ +GRZ(\phi) = \exp(-i \sum_{i=1}^{n} Z_i \phi) +$$ + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-GRZ-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-GRZ-1.png) + +Create a new Global RZ (GRZ) gate. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **phi** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – rotation angle about z-axis + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 190` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GlobalPhaseGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GlobalPhaseGate.md new file mode 100644 index 00000000000..b3e0d99bcf4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GlobalPhaseGate.md @@ -0,0 +1,145 @@ +--- +title: GlobalPhaseGate +description: API reference for qiskit.circuit.library.GlobalPhaseGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GlobalPhaseGate +--- + +# GlobalPhaseGate + + + +`qiskit.circuit.library.GlobalPhaseGate(phase, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/global_phase.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +The global phase gate ($e^{i\theta}$). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Mathematical Representation:** + +$$ +\text{GlobalPhaseGate}\ = + \begin{pmatrix} + e^{i\theta} + \end{pmatrix} + + +$$ + +**Parameters** + +* **phase** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The value of phase it takes. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for the gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.GlobalPhaseGate.base_class "qiskit.circuit.library.GlobalPhaseGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted GLobalPhaseGate gate. + +$\text{GlobalPhaseGate}(\lambda)^{\dagger} = \text{GlobalPhaseGate}(-\lambda)$ + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GraphState.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GraphState.md new file mode 100644 index 00000000000..38157921792 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GraphState.md @@ -0,0 +1,245 @@ +--- +title: GraphState +description: API reference for qiskit.circuit.library.GraphState +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GraphState +--- + +# GraphState + + + +`qiskit.circuit.library.GraphState(adjacency_matrix)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/graph_state.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Circuit to prepare a graph state. + +Given a graph G = (V, E), with the set of vertices V and the set of edges E, the corresponding graph state is defined as + +$$ +|G\rangle = \prod_{(a,b) \in E} CZ_{(a,b)} {|+\rangle}^{\otimes V} +$$ + +Such a state can be prepared by first preparing all qubits in the $+$ state, then applying a $CZ$ gate for each corresponding graph edge. + +Graph state preparation circuits are Clifford circuits, and thus easy to simulate classically. However, by adding a layer of measurements in a product basis at the end, there is evidence that the circuit becomes hard to simulate \[2]. + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-GraphState-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-GraphState-1.png) + +**References:** + +**\[1] M. Hein, J. Eisert, H.J. Briegel, Multi-party Entanglement in Graph States,** + +[arXiv:0307130](https://arxiv.org/pdf/quant-ph/0307130.pdf) + +**\[2] D. Koh, Further Extensions of Clifford Circuits & their Classical Simulation Complexities.** + +[arXiv:1512.07892](https://arxiv.org/pdf/1512.07892.pdf) + +Create graph state preparation circuit. + +**Parameters** + +**adjacency\_matrix** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *| np.ndarray*) – input graph as n-by-n list of 0-1 lists + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If adjacency\_matrix is not symmetric. + +The circuit prepares a graph state with the given adjacency matrix. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 195` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.GroverOperator.md b/docs/api/qiskit/0.46/qiskit.circuit.library.GroverOperator.md new file mode 100644 index 00000000000..90d206d52b4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.GroverOperator.md @@ -0,0 +1,380 @@ +--- +title: GroverOperator +description: API reference for qiskit.circuit.library.GroverOperator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.GroverOperator +--- + +# GroverOperator + + + +`qiskit.circuit.library.GroverOperator(oracle, state_preparation=None, zero_reflection=None, reflection_qubits=None, insert_barriers=False, mcx_mode='noancilla', name='Q')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/grover_operator.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +The Grover operator. + +Grover’s search algorithm \[1, 2] consists of repeated applications of the so-called Grover operator used to amplify the amplitudes of the desired output states. This operator, $\mathcal{Q}$, consists of the phase oracle, $\mathcal{S}_f$, zero phase-shift or zero reflection, $\mathcal{S}_0$, and an input state preparation $\mathcal{A}$: + +$$ +\mathcal{Q} = \mathcal{A} \mathcal{S}_0 \mathcal{A}^\dagger \mathcal{S}_f + + +$$ + +In the standard Grover search we have $\mathcal{A} = H^{\otimes n}$: + +$$ +\mathcal{Q} = H^{\otimes n} \mathcal{S}_0 H^{\otimes n} \mathcal{S}_f + = D \mathcal{S_f} + + +$$ + +The operation $D = H^{\otimes n} \mathcal{S}_0 H^{\otimes n}$ is also referred to as diffusion operator. In this formulation we can see that Grover’s operator consists of two steps: first, the phase oracle multiplies the good states by -1 (with $\mathcal{S}_f$) and then the whole state is reflected around the mean (with $D$). + +This class allows setting a different state preparation, as in quantum amplitude amplification (a generalization of Grover’s algorithm), $\mathcal{A}$ might not be a layer of Hardamard gates \[3]. + +The action of the phase oracle $\mathcal{S}_f$ is defined as + +$$ +\mathcal{S}_f: |x\rangle \mapsto (-1)^{f(x)}|x\rangle + + +$$ + +where $f(x) = 1$ if $x$ is a good state and 0 otherwise. To highlight the fact that this oracle flips the phase of the good states and does not flip the state of a result qubit, we call $\mathcal{S}_f$ a phase oracle. + +Note that you can easily construct a phase oracle from a bitflip oracle by sandwiching the controlled X gate on the result qubit by a X and H gate. For instance + +```python +Bitflip oracle Phaseflip oracle +q_0: ──■── q_0: ────────────■──────────── + ┌─┴─┐ ┌───┐┌───┐┌─┴─┐┌───┐┌───┐ +out: ┤ X ├ out: ┤ X ├┤ H ├┤ X ├┤ H ├┤ X ├ + └───┘ └───┘└───┘└───┘└───┘└───┘ +``` + +There is some flexibility in defining the oracle and $\mathcal{A}$ operator. Before the Grover operator is applied in Grover’s algorithm, the qubits are first prepared with one application of the $\mathcal{A}$ operator (or Hadamard gates in the standard formulation). Thus, we always have operation of the form $\mathcal{A} \mathcal{S}_f \mathcal{A}^\dagger$. Therefore it is possible to move bitflip logic into $\mathcal{A}$ and leaving the oracle only to do phaseflips via Z gates based on the bitflips. One possible use-case for this are oracles that do not uncompute the state qubits. + +The zero reflection $\mathcal{S}_0$ is usually defined as + +$$ +\mathcal{S}_0 = 2 |0\rangle^{\otimes n} \langle 0|^{\otimes n} - \mathbb{I}_n + + +$$ + +where $\mathbb{I}_n$ is the identity on $n$ qubits. By default, this class implements the negative version $2 |0\rangle^{\otimes n} \langle 0|^{\otimes n} - \mathbb{I}_n$, since this can simply be implemented with a multi-controlled Z sandwiched by X gates on the target qubit and the introduced global phase does not matter for Grover’s algorithm. + +**Examples** + +```python +>>> from qiskit.circuit import QuantumCircuit +>>> from qiskit.circuit.library import GroverOperator +>>> oracle = QuantumCircuit(2) +>>> oracle.z(0) # good state = first qubit is |1> +>>> grover_op = GroverOperator(oracle, insert_barriers=True) +>>> grover_op.decompose().draw() + ┌───┐ ░ ┌───┐ ░ ┌───┐ ┌───┐ ░ ┌───┐ +state_0: ┤ Z ├─░─┤ H ├─░─┤ X ├───────■──┤ X ├──────░─┤ H ├ + └───┘ ░ ├───┤ ░ ├───┤┌───┐┌─┴─┐├───┤┌───┐ ░ ├───┤ +state_1: ──────░─┤ H ├─░─┤ X ├┤ H ├┤ X ├┤ H ├┤ X ├─░─┤ H ├ + ░ └───┘ ░ └───┘└───┘└───┘└───┘└───┘ ░ └───┘ +``` + +```python +>>> oracle = QuantumCircuit(1) +>>> oracle.z(0) # the qubit state |1> is the good state +>>> state_preparation = QuantumCircuit(1) +>>> state_preparation.ry(0.2, 0) # non-uniform state preparation +>>> grover_op = GroverOperator(oracle, state_preparation) +>>> grover_op.decompose().draw() + ┌───┐┌──────────┐┌───┐┌───┐┌───┐┌─────────┐ +state_0: ┤ Z ├┤ RY(-0.2) ├┤ X ├┤ Z ├┤ X ├┤ RY(0.2) ├ + └───┘└──────────┘└───┘└───┘└───┘└─────────┘ +``` + +```python +>>> oracle = QuantumCircuit(4) +>>> oracle.z(3) +>>> reflection_qubits = [0, 3] +>>> state_preparation = QuantumCircuit(4) +>>> state_preparation.cry(0.1, 0, 3) +>>> state_preparation.ry(0.5, 3) +>>> grover_op = GroverOperator(oracle, state_preparation, +... reflection_qubits=reflection_qubits) +>>> grover_op.decompose().draw() + ┌───┐ ┌───┐ +state_0: ──────────────────────■──────┤ X ├───────■──┤ X ├──────────■──────────────── + │ └───┘ │ └───┘ │ +state_1: ──────────────────────┼──────────────────┼─────────────────┼──────────────── + │ │ │ +state_2: ──────────────────────┼──────────────────┼─────────────────┼──────────────── + ┌───┐┌──────────┐┌────┴─────┐┌───┐┌───┐┌─┴─┐┌───┐┌───┐┌────┴────┐┌─────────┐ +state_3: ┤ Z ├┤ RY(-0.5) ├┤ RY(-0.1) ├┤ X ├┤ H ├┤ X ├┤ H ├┤ X ├┤ RY(0.1) ├┤ RY(0.5) ├ + └───┘└──────────┘└──────────┘└───┘└───┘└───┘└───┘└───┘└─────────┘└─────────┘ +``` + +```python +>>> mark_state = Statevector.from_label('011') +>>> diffuse_operator = 2 * DensityMatrix.from_label('000') - Operator.from_label('III') +>>> grover_op = GroverOperator(oracle=mark_state, zero_reflection=diffuse_operator) +>>> grover_op.decompose().draw(fold=70) + ┌─────────────────┐ ┌───┐ » +state_0: ┤0 ├──────┤ H ├──────────────────────────» + │ │┌─────┴───┴─────┐ ┌───┐ » +state_1: ┤1 UCRZ(0,pi,0,0) ├┤0 ├─────┤ H ├──────────» + │ ││ UCRZ(pi/2,0) │┌────┴───┴────┐┌───┐» +state_2: ┤2 ├┤1 ├┤ UCRZ(-pi/4) ├┤ H ├» + └─────────────────┘└───────────────┘└─────────────┘└───┘» +« ┌─────────────────┐ ┌───┐ +«state_0: ┤0 ├──────┤ H ├───────────────────────── +« │ │┌─────┴───┴─────┐ ┌───┐ +«state_1: ┤1 UCRZ(pi,0,0,0) ├┤0 ├────┤ H ├────────── +« │ ││ UCRZ(pi/2,0) │┌───┴───┴────┐┌───┐ +«state_2: ┤2 ├┤1 ├┤ UCRZ(pi/4) ├┤ H ├ +« └─────────────────┘└───────────────┘└────────────┘└───┘ +``` + +**References** + +**\[1]: L. K. Grover (1996), A fast quantum mechanical algorithm for database search,** + +[arXiv:quant-ph/9605043](https://arxiv.org/abs/quant-ph/9605043). + +**\[2]: I. Chuang & M. Nielsen, Quantum Computation and Quantum Information,** + +Cambridge: Cambridge University Press, 2000. Chapter 6.1.2. + +**\[3]: Brassard, G., Hoyer, P., Mosca, M., & Tapp, A. (2000).** + +Quantum Amplitude Amplification and Estimation. [arXiv:quant-ph/0005055](http://arxiv.org/abs/quant-ph/0005055). + +**Parameters** + +* **oracle** (*Union\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")*]*) – The phase oracle implementing a reflection about the bad state. Note that this is not a bitflip oracle, see the docstring for more information. +* **state\_preparation** (*Optional\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – The operator preparing the good and bad state. For Grover’s algorithm, this is a n-qubit Hadamard gate and for amplitude amplification or estimation the operator $\mathcal{A}$. +* **zero\_reflection** (*Optional\[Union\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")*,* [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")*]]*) – The reflection about the zero state, $\mathcal{S}_0$. +* **reflection\_qubits** (*Optional\[List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Qubits on which the zero reflection acts on. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether barriers should be inserted between the reflections and A. +* **mcx\_mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The mode to use for building the default zero reflection. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 197` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### oracle + +The oracle implementing a reflection about the bad state. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reflection\_qubits + +Reflection qubits, on which S0 is applied (if S0 is not user-specified). + + + +### state\_preparation + +The subcircuit implementing the A operator or Hadamards. + + + +### zero\_reflection + +The subcircuit implementing the reflection about 0. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.HGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.HGate.md new file mode 100644 index 00000000000..5c77f0b5226 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.HGate.md @@ -0,0 +1,173 @@ +--- +title: HGate +description: API reference for qiskit.circuit.library.HGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.HGate +--- + +# HGate + + + +`qiskit.circuit.library.HGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/h.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +Single-qubit Hadamard gate. + +This gate is a pi rotation about the X+Z axis, and has the effect of changing computation basis from $|0\rangle,|1\rangle$ to $|+\rangle,|-\rangle$ and vice-versa. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`h()`](qiskit.circuit.QuantumCircuit#h "qiskit.circuit.QuantumCircuit.h") method. + +**Circuit symbol:** + +```python + ┌───┐ +q_0: ┤ H ├ + └───┘ +``` + +**Matrix Representation:** + +$$ +H = \frac{1}{\sqrt{2}} + \begin{pmatrix} + 1 & 1 \\ + 1 & -1 + \end{pmatrix} +$$ + +Create new H gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.HGate.base_class "qiskit.circuit.library.HGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-H gate. + +One control qubit returns a CH gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted H gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.HRSCumulativeMultiplier.md b/docs/api/qiskit/0.46/qiskit.circuit.library.HRSCumulativeMultiplier.md new file mode 100644 index 00000000000..c81fb1044d6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.HRSCumulativeMultiplier.md @@ -0,0 +1,277 @@ +--- +title: HRSCumulativeMultiplier +description: API reference for qiskit.circuit.library.HRSCumulativeMultiplier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.HRSCumulativeMultiplier +--- + +# HRSCumulativeMultiplier + + + +`qiskit.circuit.library.HRSCumulativeMultiplier(num_state_qubits, num_result_qubits=None, adder=None, name='HRSCumulativeMultiplier')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/multipliers/hrs_cumulative_multiplier.py "view source code") + +Bases: `Multiplier` + +A multiplication circuit to store product of two input registers out-of-place. + +Circuit uses the approach from \[1]. As an example, a multiplier circuit that performs a non-modular multiplication on two 3-qubit sized registers with the default adder is as follows (where `Adder` denotes the `CDKMRippleCarryAdder`): + +```python + a_0: ────■───────────────────────── + │ + a_1: ────┼─────────■─────────────── + │ │ + a_2: ────┼─────────┼─────────■───── + ┌───┴────┐┌───┴────┐┌───┴────┐ + b_0: ┤0 ├┤0 ├┤0 ├ + │ ││ ││ │ + b_1: ┤1 ├┤1 ├┤1 ├ + │ ││ ││ │ + b_2: ┤2 ├┤2 ├┤2 ├ + │ ││ ││ │ +out_0: ┤3 ├┤ ├┤ ├ + │ ││ ││ │ +out_1: ┤4 ├┤3 ├┤ ├ + │ Adder ││ Adder ││ Adder │ +out_2: ┤5 ├┤4 ├┤3 ├ + │ ││ ││ │ +out_3: ┤6 ├┤5 ├┤4 ├ + │ ││ ││ │ +out_4: ┤ ├┤6 ├┤5 ├ + │ ││ ││ │ +out_5: ┤ ├┤ ├┤6 ├ + │ ││ ││ │ +aux_0: ┤7 ├┤7 ├┤7 ├ + └────────┘└────────┘└────────┘ +``` + +Multiplication in this circuit is implemented in a classical approach by performing a series of shifted additions using one of the input registers while the qubits from the other input register act as control qubits for the adders. + +**References:** + +\[1] Häner et al., Optimizing Quantum Circuits for Arithmetic, 2018. [arXiv:1805.12445](https://arxiv.org/pdf/1805.12445.pdf) + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits in either input register for state $|a\rangle$ or $|b\rangle$. The two input registers must have the same number of qubits. +* **num\_result\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of result qubits to limit the output to. If number of result qubits is $n$, multiplication modulo $2^n$ is performed to limit the output to the specified number of qubits. Default value is `2 * num_state_qubits` to represent any possible result from the multiplication of the two inputs. +* **adder** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *| None*) – Half adder circuit to be used for performing multiplication. The CDKMRippleCarryAdder is used as default if no adder is provided. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit object. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If `num_result_qubits` is not default and a custom adder is provided. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 197` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### num\_result\_qubits + +The number of result qubits to limit the output to. + +**Returns** + +The number of result qubits. + + + +### num\_state\_qubits + +The number of state qubits, i.e. the number of bits in each input register. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.HamiltonianGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.HamiltonianGate.md new file mode 100644 index 00000000000..238f01bb122 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.HamiltonianGate.md @@ -0,0 +1,181 @@ +--- +title: HamiltonianGate +description: API reference for qiskit.circuit.library.HamiltonianGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.HamiltonianGate +--- + +# HamiltonianGate + + + +`qiskit.circuit.library.HamiltonianGate(data, time, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/hamiltonian_gate.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Class for representing evolution by a Hamiltonian operator as a gate. + +This gate resolves to a [`UnitaryGate`](qiskit.circuit.library.UnitaryGate "qiskit.circuit.library.UnitaryGate") as $U(t) = \exp(-i t H)$, which can be decomposed into basis gates if it is 2 qubits or less, or simulated directly in Aer for more qubits. + +**Parameters** + +* **data** (*np.ndarray |* [*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| BaseOperator*) – A hermitian operator. +* **time** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")) – Time evolution parameter. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Unitary name for backend \[Default: None]. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if input data is not an N-qubit unitary operator. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.HamiltonianGate.base_class "qiskit.circuit.library.HamiltonianGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the unitary. + +### conjugate + + + +`conjugate()` + +Return the conjugate of the Hamiltonian. + +### inverse + + + +`inverse()` + +Return the adjoint of the unitary. + +### qasm + + + +`qasm()` + +Raise an error, as QASM is not defined for the HamiltonianGate. + + + The method `qiskit.circuit.library.hamiltonian_gate.HamiltonianGate.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. + + +### transpose + + + +`transpose()` + +Return the transpose of the Hamiltonian. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Hamiltonian parameter has to be an ndarray, operator or float. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.HiddenLinearFunction.md b/docs/api/qiskit/0.46/qiskit.circuit.library.HiddenLinearFunction.md new file mode 100644 index 00000000000..fd6852f11f6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.HiddenLinearFunction.md @@ -0,0 +1,247 @@ +--- +title: HiddenLinearFunction +description: API reference for qiskit.circuit.library.HiddenLinearFunction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.HiddenLinearFunction +--- + +# HiddenLinearFunction + + + +`qiskit.circuit.library.HiddenLinearFunction(adjacency_matrix)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/hidden_linear_function.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Circuit to solve the hidden linear function problem. + +The 2D Hidden Linear Function problem is determined by a 2D adjacency matrix A, where only elements that are nearest-neighbor on a grid have non-zero entries. Each row/column corresponds to one binary variable $x_i$. + +The hidden linear function problem is as follows: + +Consider the quadratic form + +$$ +q(x) = \sum_{i,j=1}^{n}{x_i x_j} ~(\mathrm{mod}~ 4) +$$ + +and restrict $q(x)$ onto the nullspace of A. This results in a linear function. + +$$ +2 \sum_{i=1}^{n}{z_i x_i} ~(\mathrm{mod}~ 4) \forall x \in \mathrm{Ker}(A) +$$ + +and the goal is to recover this linear function (equivalently a vector $[z_0, ..., z_{n-1}]$). There can be multiple solutions. + +In \[1] it is shown that the present circuit solves this problem on a quantum computer in constant depth, whereas any corresponding solution on a classical computer would require circuits that grow logarithmically with $n$. Thus this circuit is an example of quantum advantage with shallow circuits. + +**Reference Circuit:** + +> ![../\_images/qiskit-circuit-library-HiddenLinearFunction-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-HiddenLinearFunction-1.png) + +**Reference:** + +\[1] S. Bravyi, D. Gosset, R. Koenig, Quantum Advantage with Shallow Circuits, 2017. [arXiv:1704.00690](https://arxiv.org/abs/1704.00690) + +Create new HLF circuit. + +**Parameters** + +**adjacency\_matrix** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a symmetric n-by-n list of 0-1 lists. n will be the number of qubits. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If A is not symmetric. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 199` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.IGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.IGate.md new file mode 100644 index 00000000000..8616cf72a7d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.IGate.md @@ -0,0 +1,156 @@ +--- +title: IGate +description: API reference for qiskit.circuit.library.IGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.IGate +--- + +# IGate + + + +`qiskit.circuit.library.IGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/i.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +Identity gate. + +Identity gate corresponds to a single-qubit gate wait cycle, and should not be optimized or unrolled (it is an opaque gate). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`i()`](qiskit.circuit.QuantumCircuit#i "qiskit.circuit.QuantumCircuit.i") and [`id()`](qiskit.circuit.QuantumCircuit#id "qiskit.circuit.QuantumCircuit.id") methods. + +**Matrix Representation:** + +$$ +I = \begin{pmatrix} + 1 & 0 \\ + 0 & 1 + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌───┐ +q_0: ┤ I ├ + └───┘ +``` + +Create new Identity gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.IGate.base_class "qiskit.circuit.library.IGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Invert this gate. + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.IQP.md b/docs/api/qiskit/0.46/qiskit.circuit.library.IQP.md new file mode 100644 index 00000000000..7dc7738ae27 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.IQP.md @@ -0,0 +1,235 @@ +--- +title: IQP +description: API reference for qiskit.circuit.library.IQP +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.IQP +--- + +# IQP + + + +`qiskit.circuit.library.IQP(interactions)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/iqp.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Instantaneous quantum polynomial (IQP) circuit. + +The circuit consists of a column of Hadamard gates, a column of powers of T gates, a sequence of powers of CS gates (up to $\frac{n^2-n}{2}$ of them), and a final column of Hadamard gates, as introduced in \[1]. + +The circuit is parameterized by an n x n interactions matrix. The powers of each T gate are given by the diagonal elements of the interactions matrix. The powers of the CS gates are given by the upper triangle of the interactions matrix. + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-IQP-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-IQP-1.png) + +**Expanded Circuit:** + +> ![../\_images/qiskit-circuit-library-IQP-2.png](/images/api/qiskit/0.46/qiskit-circuit-library-IQP-2.png) + +**References:** + +\[1] M. J. Bremner et al. Average-case complexity versus approximate simulation of commuting quantum computations, Phys. Rev. Lett. 117, 080501 (2016). [arXiv:1504.07999](https://arxiv.org/abs/1504.07999) + +Create IQP circuit. + +**Parameters** + +**interactions** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *| np.ndarray*) – input n-by-n symmetric matrix. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the inputs is not as symmetric matrix. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 204` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.Initialize.md b/docs/api/qiskit/0.46/qiskit.circuit.library.Initialize.md new file mode 100644 index 00000000000..61548344e8d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.Initialize.md @@ -0,0 +1,170 @@ +--- +title: Initialize +description: API reference for qiskit.circuit.library.Initialize +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.Initialize +--- + +# Initialize + + + +`qiskit.circuit.library.Initialize(params, num_qubits=None, normalize=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/data_preparation/initializer.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Complex amplitude initialization. + +Class that initializes some flexible collection of qubit registers, implemented by calling the [`StatePreparation`](qiskit.circuit.library.StatePreparation "qiskit.circuit.library.StatePreparation") class. Note that `Initialize` is an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") and not a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") since it contains a reset instruction, which is not unitary. + +**Parameters** + +* **params** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *| Sequence\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – + + The state to initialize to, can be either of the following. + + * Statevector or vector of complex amplitudes to initialize to. + * Labels of basis states of the Pauli eigenstates Z, X, Y. See [`Statevector.from_label()`](qiskit.quantum_info.Statevector#from_label "qiskit.quantum_info.Statevector.from_label"). Notice the order of the labels is reversed with respect to the qubit index to be applied to. Example label ‘01’ initializes the qubit zero to $|1\rangle$ and the qubit one to $|0\rangle$. + * An integer that is used as a bitmap indicating which qubits to initialize to $|1\rangle$. Example: setting params to 5 would initialize qubit 0 and qubit 2 to $|1\rangle$ and qubit 1 to $|0\rangle$. + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – This parameter is only used if params is an int. Indicates the total number of qubits in the initialize call. Example: initialize covers 5 qubits and params is 3. This allows qubits 0 and 1 to be initialized to $|1\rangle$ and the remaining 3 qubits to be initialized to $|0\rangle$. + +* **normalize** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to normalize an input array to a unit vector. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.Initialize.base_class "qiskit.circuit.library.Initialize.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Return initialize params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### gates\_to\_uncompute + + + +`gates_to_uncompute()` + +Call to create a circuit with gates that take the desired vector to zero. + +**Returns** + +Circuit to take `self.params` vector to $|{00\ldots0}\rangle$ + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.InnerProduct.md b/docs/api/qiskit/0.46/qiskit.circuit.library.InnerProduct.md new file mode 100644 index 00000000000..19811da0aa3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.InnerProduct.md @@ -0,0 +1,246 @@ +--- +title: InnerProduct +description: API reference for qiskit.circuit.library.InnerProduct +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.InnerProduct +--- + +# InnerProduct + + + +`qiskit.circuit.library.InnerProduct(num_qubits)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/boolean_logic/inner_product.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +A 2n-qubit Boolean function that computes the inner product of two n-qubit vectors over $F_2$. + +This implementation is a phase oracle which computes the following transform. + +$$ +\mathcal{IP}_{2n} : F_2^{2n} \rightarrow {-1, 1} +\mathcal{IP}_{2n}(x_1, \cdots, x_n, y_1, \cdots, y_n) = (-1)^{x.y} +$$ + +The corresponding unitary is a diagonal, which induces a -1 phase on any inputs where the inner product of the top and bottom registers is 1. Otherwise it keeps the input intact. + +```python +q0_0: ─■────────── + │ +q0_1: ─┼──■─────── + │ │ +q0_2: ─┼──┼──■──── + │ │ │ +q0_3: ─┼──┼──┼──■─ + │ │ │ │ +q1_0: ─■──┼──┼──┼─ + │ │ │ +q1_1: ────■──┼──┼─ + │ │ +q1_2: ───────■──┼─ + │ +q1_3: ──────────■─ +``` + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-InnerProduct-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-InnerProduct-1.png) + +Return a circuit to compute the inner product of 2 n-qubit registers. + +**Parameters** + +**num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – width of top and bottom registers (half total circuit width) + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 161` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.IntegerComparator.md b/docs/api/qiskit/0.46/qiskit.circuit.library.IntegerComparator.md new file mode 100644 index 00000000000..adf614c8b63 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.IntegerComparator.md @@ -0,0 +1,201 @@ +--- +title: IntegerComparator +description: API reference for qiskit.circuit.library.IntegerComparator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.IntegerComparator +--- + +# IntegerComparator + + + +`qiskit.circuit.library.IntegerComparator(num_state_qubits=None, value=None, geq=True, name='cmp')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/integer_comparator.py "view source code") + +Bases: `BlueprintCircuit` + +Integer Comparator. + +Operator compares basis states $|i\rangle_n$ against a classically given integer $L$ of fixed value and flips a target qubit if $i \geq L$ (or $<$ depending on the parameter `geq`): + +$$ +|i\rangle_n |0\rangle \mapsto |i\rangle_n |i \geq L\rangle +$$ + +This operation is based on two’s complement implementation of binary subtraction but only uses carry bits and no actual result bits. If the most significant carry bit (the results bit) is 1, the $\geq$ condition is `True` otherwise it is `False`. + +Create a new fixed value comparator circuit. + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Number of state qubits. If this is set it will determine the number of qubits required for the circuit. +* **value** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The fixed value to compare with. +* **geq** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, evaluate a `>=` condition, else `<`. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### geq + +Return whether the comparator compares greater or less equal. + +**Returns** + +True, if the comparator compares `>=`, False if `<`. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 163` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +Deprecated. Use num\_ancillas instead. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of qubits encoding the state for the comparison. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### value + +The value to compare the qubit register to. + +**Returns** + +The value against which the value of the qubit register is compared. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.Isometry.md b/docs/api/qiskit/0.46/qiskit.circuit.library.Isometry.md new file mode 100644 index 00000000000..01f4b2657e9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.Isometry.md @@ -0,0 +1,174 @@ +--- +title: Isometry +description: API reference for qiskit.circuit.library.Isometry +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.Isometry +--- + +# Isometry + + + +`qiskit.circuit.library.Isometry(isometry, num_ancillas_zero, num_ancillas_dirty, epsilon=1e-10)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/isometry.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Decomposition of arbitrary isometries from $m$ to $n$ qubits. + +In particular, this allows to decompose unitaries (m=n) and to do state preparation ($m=0$). + +The decomposition is based on \[1]. + +**References:** + +**\[1] Iten et al., Quantum circuits for isometries (2016).** + +[Phys. Rev. A 93, 032318](https://journals.aps.org/pra/abstract/10.1103/PhysRevA.93.032318). + +**Parameters** + +* **isometry** (*np.ndarray*) – An isometry from $m$ to :math\`n\` qubits, i.e., a complex `np.ndarray` of dimension $2^n \times 2^m$ with orthonormal columns (given in the computational basis specified by the order of the ancillas and the input qubits, where the ancillas are considered to be more significant than the input qubits). +* **num\_ancillas\_zero** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of additional ancillas that start in the state $|0\rangle$ (the $n-m$ ancillas required for providing the output of the isometry are not accounted for here). +* **num\_ancillas\_dirty** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of additional ancillas that start in an arbitrary state. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Error tolerance of calculations. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.Isometry.base_class "qiskit.circuit.library.Isometry.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inv\_gate + + + +`inv_gate()` + +Return the adjoint of the unitary. + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Isometry parameter has to be an ndarray. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.LinearAmplitudeFunction.md b/docs/api/qiskit/0.46/qiskit.circuit.library.LinearAmplitudeFunction.md new file mode 100644 index 00000000000..62fa6a465d5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.LinearAmplitudeFunction.md @@ -0,0 +1,283 @@ +--- +title: LinearAmplitudeFunction +description: API reference for qiskit.circuit.library.LinearAmplitudeFunction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.LinearAmplitudeFunction +--- + +# LinearAmplitudeFunction + + + +`qiskit.circuit.library.LinearAmplitudeFunction(num_state_qubits, slope, offset, domain, image, rescaling_factor=1, breakpoints=None, name='F')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/linear_amplitude_function.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +A circuit implementing a (piecewise) linear function on qubit amplitudes. + +An amplitude function $F$ of a function $f$ is a mapping + +$$ +F|x\rangle|0\rangle = \sqrt{1 - \hat{f}(x)} |x\rangle|0\rangle + \sqrt{\hat{f}(x)} + |x\rangle|1\rangle. +$$ + +for a function $\hat{f}: \{ 0, ..., 2^n - 1 \} \rightarrow [0, 1]$, where $|x\rangle$ is a $n$ qubit state. + +This circuit implements $F$ for piecewise linear functions $\hat{f}$. In this case, the mapping $F$ can be approximately implemented using a Taylor expansion and linearly controlled Pauli-Y rotations, see \[1, 2] for more detail. This approximation uses a `rescaling_factor` to determine the accuracy of the Taylor expansion. + +In general, the function of interest $f$ is defined from some interval $[a,b]$, the `domain` to $[c,d]$, the `image`, instead of $\{ 1, ..., N \}$ to $[0, 1]$. Using an affine transformation we can rescale $f$ to $\hat{f}$: + +$$ +\hat{f}(x) = \frac{f(\phi(x)) - c}{d - c} +$$ + +with + +$$ +\phi(x) = a + \frac{b - a}{2^n - 1} x. +$$ + +If $f$ is a piecewise linear function on $m$ intervals $[p_{i-1}, p_i], i \in \{1, ..., m\}$ with slopes $\alpha_i$ and offsets $\beta_i$ it can be written as + +$$ +f(x) = \sum_{i=1}^m 1_{[p_{i-1}, p_i]}(x) (\alpha_i x + \beta_i) +$$ + +where $1_{[a, b]}$ is an indication function that is 1 if the argument is in the interval $[a, b]$ and otherwise 0. The breakpoints $p_i$ can be specified by the `breakpoints` argument. + +**References** + +**\[1]: Woerner, S., & Egger, D. J. (2018).** + +Quantum Risk Analysis. [arXiv:1806.06893](http://arxiv.org/abs/1806.06893) + +**\[2]: Gacon, J., Zoufal, C., & Woerner, S. (2020).** + +Quantum-Enhanced Simulation-Based Optimization. [arXiv:2005.10780](http://arxiv.org/abs/2005.10780) + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits used to encode the variable $x$. +* **slope** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The slope of the linear function. Can be a list of slopes if it is a piecewise linear function. +* **offset** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The offset of the linear function. Can be a list of offsets if it is a piecewise linear function. +* **domain** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The domain of the function as tuple $(x_\min{}, x_\max{})$. +* **image** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The image of the function as tuple $(f_\min{}, f_\max{})$. +* **rescaling\_factor** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The rescaling factor to adjust the accuracy in the Taylor approximation. +* **breakpoints** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – The breakpoints if the function is piecewise linear. If None, the function is not piecewise. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 163` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### post\_processing + + + +`post_processing(scaled_value)` + +Map the function value of the approximated $\hat{f}$ to $f$. + +**Parameters** + +**scaled\_value** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – A function value from the Taylor expansion of $\hat{f}(x)$. + +**Returns** + +The `scaled_value` mapped back to the domain of $f$, by first inverting the transformation used for the Taylor approximation and then mapping back from $[0, 1]$ to the original domain. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.LinearFunction.md b/docs/api/qiskit/0.46/qiskit.circuit.library.LinearFunction.md new file mode 100644 index 00000000000..626008c96ca --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.LinearFunction.md @@ -0,0 +1,251 @@ +--- +title: LinearFunction +description: API reference for qiskit.circuit.library.LinearFunction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.LinearFunction +--- + +# LinearFunction + + + +`qiskit.circuit.library.LinearFunction(linear, validate_input=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/linear_function.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +A linear reversible circuit on n qubits. + +Internally, a linear function acting on n qubits is represented as a n x n matrix of 0s and 1s in numpy array format. + +A linear function can be synthesized into CX and SWAP gates using the Patel–Markov–Hayes algorithm, as implemented in [`synth_cnot_count_full_pmh()`](synthesis#qiskit.synthesis.synth_cnot_count_full_pmh "qiskit.synthesis.synth_cnot_count_full_pmh") based on reference \[1]. + +For efficiency, the internal n x n matrix is stored in the format expected by cnot\_synth, which is the big-endian (and not the little-endian) bit-ordering convention. + +**Example:** the circuit + +```python +q_0: ──■── + ┌─┴─┐ +q_1: ┤ X ├ + └───┘ +q_2: ───── +``` + +is represented by a 3x3 linear matrix + +$$ +\begin{pmatrix} + 1 & 0 & 0 \\ + 1 & 1 & 0 \\ + 0 & 0 & 1 +\end{pmatrix} +$$ + +**References:** + +\[1] Ketan N. Patel, Igor L. Markov, and John P. Hayes, Optimal synthesis of linear reversible circuits, Quantum Inf. Comput. 8(3) (2008). [Online at umich.edu.](https://web.eecs.umich.edu/~imarkov/pubs/jour/qic08-cnot.pdf) + +Create a new linear function. + +**Parameters** + +* **linear** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*] | np.ndarray\[*[*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*] |* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*LinearFunction*](#qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction") *|*[*PermutationGate*](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate") *|*[*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – data from which a linear function can be constructed. It can be either a nxn matrix (describing the linear transformation), a permutation (which is a special case of a linear function), another linear function, a clifford (when it corresponds to a linear function), or a quantum circuit composed of linear gates (CX and SWAP) and other objects described above, including nested subcircuits. +* **validate\_input** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, performs more expensive input validation checks, such as checking that a given n x n matrix is invertible. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the input is invalid: either the input matrix is not square or not invertible, or the input quantum circuit contains non-linear objects (for example, a Hadamard gate, or a Clifford that does not correspond to a linear function). + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.LinearFunction.base_class "qiskit.circuit.library.LinearFunction.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### linear + +Returns the n x n matrix representing this linear function. + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### original\_circuit + +Returns the original circuit used to construct this linear function (including None, when the linear function is not constructed from a circuit). + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### extend\_with\_identity + + + +`extend_with_identity(num_qubits, positions)` + +Extend linear function to a linear function over nq qubits, with identities on other subsystems. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits of the extended function. +* **positions** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – describes the positions of original qubits in the extended function’s qubits. + +**Returns** + +extended linear function. + +**Return type** + +[LinearFunction](#qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction") + +### function\_str + + + +`function_str()` + +Return string representation of the linear function viewed as a linear transformation. + +### is\_permutation + + + +`is_permutation()` + +Returns whether this linear function is a permutation, that is whether every row and every column of the n x n matrix has exactly one 1. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### mat\_str + + + +`mat_str()` + +Return string representation of the linear function viewed as a matrix with 0/1 entries. + +### permutation\_pattern + + + +`permutation_pattern()` + +This method first checks if a linear function is a permutation and raises a qiskit.circuit.exceptions.CircuitError if not. In the case that this linear function is a permutation, returns the permutation pattern. + +### synthesize + + + +`synthesize()` + +Synthesizes the linear function into a quantum circuit. + +**Returns** + +A circuit implementing the evolution. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Parameter validation + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.LinearPauliRotations.md b/docs/api/qiskit/0.46/qiskit.circuit.library.LinearPauliRotations.md new file mode 100644 index 00000000000..791c681ac04 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.LinearPauliRotations.md @@ -0,0 +1,235 @@ +--- +title: LinearPauliRotations +description: API reference for qiskit.circuit.library.LinearPauliRotations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.LinearPauliRotations +--- + +# LinearPauliRotations + + + +`qiskit.circuit.library.LinearPauliRotations(num_state_qubits=None, slope=1, offset=0, basis='Y', name='LinRot')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/linear_pauli_rotations.py "view source code") + +Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") + +Linearly-controlled X, Y or Z rotation. + +For a register of state qubits $|x\rangle$, a target qubit $|0\rangle$ and the basis `'Y'` this circuit acts as: + +```python + q_0: ─────────────────────────■───────── ... ────────────────────── + │ + . + │ +q_(n-1): ─────────────────────────┼───────── ... ───────────■────────── + ┌────────────┐ ┌───────┴───────┐ ┌─────────┴─────────┐ + q_n: ─┤ RY(offset) ├──┤ RY(2^0 slope) ├ ... ┤ RY(2^(n-1) slope) ├ + └────────────┘ └───────────────┘ └───────────────────┘ +``` + +This can for example be used to approximate linear functions, with $a =$ `slope`$/2$ and $b =$ `offset`$/2$ and the basis `'Y'`: + +$$ +|x\rangle |0\rangle \mapsto \cos(ax + b)|x\rangle|0\rangle + \sin(ax + b)|x\rangle |1\rangle +$$ + +Since for small arguments $\sin(x) \approx x$ this operator can be used to approximate linear functions. + +Create a new linear rotation circuit. + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits representing the state $|x\rangle$. +* **slope** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The slope of the controlled rotation. +* **offset** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The offset of the controlled rotation. +* **basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The type of Pauli rotation (‘X’, ‘Y’, ‘Z’). +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit object. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### basis + +The kind of Pauli rotation to be used. + +Set the basis to ‘X’, ‘Y’ or ‘Z’ for controlled-X, -Y, or -Z rotations respectively. + +**Returns** + +The kind of Pauli rotation used in controlled rotation. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 163` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +The minimum number of ancilla qubits in the circuit. + +**Returns** + +The minimal number of ancillas required. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits representing the state $|x\rangle$. + +**Returns** + +The number of state qubits. + + + +### offset + +The angle of the single qubit offset rotation on the target qubit. + +Before applying the controlled rotations, a single rotation of angle `offset` is applied to the target qubit. + +**Returns** + +The offset angle. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### slope + +The multiplicative factor in the rotation angle of the controlled rotations. + +The rotation angles are `slope * 2^0`, `slope * 2^1`, … , `slope * 2^(n-1)` where `n` is the number of state qubits. + +**Returns** + +The rotation angle common in all controlled rotations. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MCMT.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MCMT.md new file mode 100644 index 00000000000..4b1d0dfad2b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MCMT.md @@ -0,0 +1,263 @@ +--- +title: MCMT +description: API reference for qiskit.circuit.library.MCMT +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MCMT +--- + +# MCMT + + + +`qiskit.circuit.library.MCMT(gate, num_ctrl_qubits, num_target_qubits)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/mcmt.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +The multi-controlled multi-target gate, for an arbitrary singly controlled target gate. + +For example, the H gate controlled on 3 qubits and acting on 2 target qubit is represented as: + +```python +───■──── + │ +───■──── + │ +───■──── +┌──┴───┐ +┤0 ├ +│ 2-H │ +┤1 ├ +└──────┘ +``` + +This default implementations requires no ancilla qubits, by broadcasting the target gate to the number of target qubits and using Qiskit’s generic control routine to control the broadcasted target on the control qubits. If ancilla qubits are available, a more efficient variant using the so-called V-chain decomposition can be used. This is implemented in [`MCMTVChain`](qiskit.circuit.library.MCMTVChain "qiskit.circuit.library.MCMTVChain"). + +Create a new multi-control multi-target gate. + +**Parameters** + +* **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| Callable\[\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*],* [*circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*]*) – The gate to be applied controlled on the control qubits and applied to the target qubits. Can be either a Gate or a circuit method. If it is a callable, it will be casted to a Gate. +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of control qubits. +* **num\_target\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of target qubits. + +**Raises** + +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the gate cannot be casted to a controlled gate. +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the number of controls or targets is 0. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 163` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +Return the number of ancillas. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return the controlled version of the MCMT circuit. + +### inverse + + + +`inverse()` + +Return the inverse MCMT circuit, which is itself. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MCMTVChain.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MCMTVChain.md new file mode 100644 index 00000000000..56c154d4f78 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MCMTVChain.md @@ -0,0 +1,279 @@ +--- +title: MCMTVChain +description: API reference for qiskit.circuit.library.MCMTVChain +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MCMTVChain +--- + +# MCMTVChain + + + +`qiskit.circuit.library.MCMTVChain(gate, num_ctrl_qubits, num_target_qubits)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/mcmt.py "view source code") + +Bases: [`MCMT`](qiskit.circuit.library.MCMT "qiskit.circuit.library.generalized_gates.mcmt.MCMT") + +The MCMT implementation using the CCX V-chain. + +This implementation requires ancillas but is decomposed into a much shallower circuit than the default implementation in [`MCMT`](qiskit.circuit.library.MCMT "qiskit.circuit.library.MCMT"). + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-MCMTVChain-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-MCMTVChain-1.png) + +**Examples:** + +> ```python +> >>> from qiskit.circuit.library import HGate +> >>> MCMTVChain(HGate(), 3, 2).draw() +> ``` +> +> **q\_0: ──■────────────────────────■──** +> +> │ │ +> +> **q\_1: ──■────────────────────────■──** +> +> │ │ +> +> **q\_2: ──┼────■──────────────■────┼──** +> +> │ │ ┌───┐ │ │ +> +> **q\_3: ──┼────┼──┤ H ├───────┼────┼──** +> +> │ │ └─┬─┘┌───┐ │ │ +> +> **q\_4: ──┼────┼────┼──┤ H ├──┼────┼──** +> +> ┌─┴─┐ │ │ └─┬─┘ │ ┌─┴─┐ +> +> **q\_5: ┤ X ├──■────┼────┼────■──┤ X ├** +> +> └───┘┌─┴─┐ │ │ ┌─┴─┐└───┘ +> +> **q\_6: ─────┤ X ├──■────■──┤ X ├─────** +> +> └───┘ └───┘ + +Create a new multi-control multi-target gate. + +**Parameters** + +* **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| Callable\[\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*],* [*circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*]*) – The gate to be applied controlled on the control qubits and applied to the target qubits. Can be either a Gate or a circuit method. If it is a callable, it will be casted to a Gate. +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of control qubits. +* **num\_target\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of target qubits. + +**Raises** + +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the gate cannot be casted to a controlled gate. +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the number of controls or targets is 0. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 164` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +Return the number of ancilla qubits required. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### inverse + + + +`inverse()` + +Return the inverse MCMT circuit, which is itself. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MCPhaseGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MCPhaseGate.md new file mode 100644 index 00000000000..9b66055be80 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MCPhaseGate.md @@ -0,0 +1,206 @@ +--- +title: MCPhaseGate +description: API reference for qiskit.circuit.library.MCPhaseGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MCPhaseGate +--- + +# MCPhaseGate + + + +`qiskit.circuit.library.MCPhaseGate(lam, num_ctrl_qubits, label=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/p.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +Multi-controlled-Phase gate. + +This is a diagonal and symmetric gate that induces a phase on the state of the target qubit, depending on the state of the control qubits. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`mcp()`](qiskit.circuit.QuantumCircuit#mcp "qiskit.circuit.QuantumCircuit.mcp") method. + +**Circuit symbol:** + +```python + q_0: ───■──── + │ + . + │ +q_(n-1): ───■──── + ┌──┴───┐ + q_n: ┤ P(λ) ├ + └──────┘ +``` + + + `CPhaseGate`: The singly-controlled-version of this gate. + + +Create new MCPhase gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.MCPhaseGate.base_class "qiskit.circuit.library.MCPhaseGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Controlled version of this gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted MCU1 gate ($MCU1(\lambda)^{\dagger} = MCU1(-\lambda)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MCXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXGate.md new file mode 100644 index 00000000000..e4b71c94a71 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXGate.md @@ -0,0 +1,207 @@ +--- +title: MCXGate +description: API reference for qiskit.circuit.library.MCXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MCXGate +--- + +# MCXGate + + + +`qiskit.circuit.library.MCXGate(num_ctrl_qubits=None, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.controlledgate.ControlledGate") + +The general, multi-controlled X gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`mcx()`](qiskit.circuit.QuantumCircuit#mcx "qiskit.circuit.QuantumCircuit.mcx") method. + +Create new MCX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.MCXGate.base_class "qiskit.circuit.library.MCXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_ancilla\_qubits + +The number of ancilla qubits. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a multi-controlled-X gate with more control lines. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### get\_num\_ancilla\_qubits + + + +`static get_num_ancilla_qubits(num_ctrl_qubits, mode='noancilla')` + +Get the number of required ancilla qubits without instantiating the class. + +This staticmethod might be necessary to check the number of ancillas before creating the gate, or to use the number of ancillas in the initialization. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### inverse + + + +`inverse()` + +Invert this gate. The MCX is its own inverse. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MCXGrayCode.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXGrayCode.md new file mode 100644 index 00000000000..4e02d35a033 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXGrayCode.md @@ -0,0 +1,171 @@ +--- +title: MCXGrayCode +description: API reference for qiskit.circuit.library.MCXGrayCode +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MCXGrayCode +--- + +# MCXGrayCode + + + +`qiskit.circuit.library.MCXGrayCode(num_ctrl_qubits=None, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.standard_gates.x.MCXGate") + +Implement the multi-controlled X gate using the Gray code. + +This delegates the implementation to the MCU1 gate, since $X = H \cdot U1(\pi) \cdot H$. + +Create new MCX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.MCXGrayCode.base_class "qiskit.circuit.library.MCXGrayCode.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_ancilla\_qubits + +The number of ancilla qubits. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Invert this gate. The MCX is its own inverse. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MCXRecursive.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXRecursive.md new file mode 100644 index 00000000000..f4aaa5c9e3f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXRecursive.md @@ -0,0 +1,179 @@ +--- +title: MCXRecursive +description: API reference for qiskit.circuit.library.MCXRecursive +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MCXRecursive +--- + +# MCXRecursive + + + +`qiskit.circuit.library.MCXRecursive(num_ctrl_qubits=None, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.standard_gates.x.MCXGate") + +Implement the multi-controlled X gate using recursion. + +Using a single ancilla qubit, the multi-controlled X gate is recursively split onto four sub-registers. This is done until we reach the 3- or 4-controlled X gate since for these we have a concrete implementation that do not require ancillas. + +Create new MCX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.MCXRecursive.base_class "qiskit.circuit.library.MCXRecursive.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_ancilla\_qubits + +The number of ancilla qubits. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### get\_num\_ancilla\_qubits + + + +`static get_num_ancilla_qubits(num_ctrl_qubits, mode='recursion')` + +Get the number of required ancilla qubits. + +### inverse + + + +`inverse()` + +Invert this gate. The MCX is its own inverse. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MCXVChain.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXVChain.md new file mode 100644 index 00000000000..ad8646ee796 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MCXVChain.md @@ -0,0 +1,177 @@ +--- +title: MCXVChain +description: API reference for qiskit.circuit.library.MCXVChain +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MCXVChain +--- + +# MCXVChain + + + +`qiskit.circuit.library.MCXVChain(num_ctrl_qubits=None, dirty_ancillas=False, label=None, ctrl_state=None, *, duration=None, unit='dt', _base_label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`MCXGate`](qiskit.circuit.library.MCXGate "qiskit.circuit.library.standard_gates.x.MCXGate") + +Implement the multi-controlled X gate using a V-chain of CX gates. + +Create new MCX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.MCXVChain.base_class "qiskit.circuit.library.MCXVChain.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### ctrl\_state + +Return the control state of the gate as a decimal integer. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. If the gate has open controls, as determined from self.ctrl\_state, the returned definition is conjugated with X without changing the internal \_definition. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Get name of gate. If the gate has open controls the gate name will become: + +> \ + +where \ is the gate name for the default case of closed control qubits and \ is the integer value of the control state for the gate. + + + +### num\_ancilla\_qubits + +The number of ancilla qubits. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_ctrl\_qubits + +Get number of control qubits. + +**Returns** + +The number of control qubits for the gate. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +Get parameters from base\_gate. + +**Returns** + +List of gate parameters. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Controlled gate does not define a base gate + + + +### unit + +Get the time unit of duration. + +## Methods + +### get\_num\_ancilla\_qubits + + + +`static get_num_ancilla_qubits(num_ctrl_qubits, mode='v-chain')` + +Get the number of required ancilla qubits. + +### inverse + + + +`inverse()` + +Invert this gate. The MCX is its own inverse. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.MSGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.MSGate.md new file mode 100644 index 00000000000..7da50cb3367 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.MSGate.md @@ -0,0 +1,123 @@ +--- +title: MSGate +description: API reference for qiskit.circuit.library.MSGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.MSGate +--- + +# MSGate + + + +`qiskit.circuit.library.MSGate(num_qubits, theta, label=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/gms.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +MSGate has been deprecated. Please use `GMS` in `qiskit.circuit.generalized_gates` instead. + +Global Mølmer–Sørensen gate. + +The Mølmer–Sørensen gate is native to ion-trap systems. The global MS can be applied to multiple ions to entangle multiple qubits simultaneously. + +In the two-qubit case, this is equivalent to an XX(theta) interaction, and is thus reduced to the RXXGate. + +Create new MS gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.MSGate.base_class "qiskit.circuit.library.MSGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.Measure.md b/docs/api/qiskit/0.46/qiskit.circuit.library.Measure.md new file mode 100644 index 00000000000..bc7e942ea5c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.Measure.md @@ -0,0 +1,316 @@ +--- +title: Measure +description: API reference for qiskit.circuit.library.Measure +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.Measure +--- + +# Measure + + + +`qiskit.circuit.library.Measure(label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/measure.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Quantum measurement in the computational basis. + +Create new measurement instruction. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.Measure.base_class "qiskit.circuit.library.Measure.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.NLocal.md b/docs/api/qiskit/0.46/qiskit.circuit.library.NLocal.md new file mode 100644 index 00000000000..fc3277f1b2f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.NLocal.md @@ -0,0 +1,462 @@ +--- +title: NLocal +description: API reference for qiskit.circuit.library.NLocal +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.NLocal +--- + +# NLocal + + + +`qiskit.circuit.library.NLocal(num_qubits=None, rotation_blocks=None, entanglement_blocks=None, entanglement=None, reps=1, insert_barriers=False, parameter_prefix='θ', overwrite_block_parameters=True, skip_final_rotation_layer=False, skip_unentangled_qubits=False, initial_state=None, name='nlocal', flatten=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/n_local/n_local.py "view source code") + +Bases: `BlueprintCircuit` + +The n-local circuit class. + +The structure of the n-local circuit are alternating rotation and entanglement layers. In both layers, parameterized circuit-blocks act on the circuit in a defined way. In the rotation layer, the blocks are applied stacked on top of each other, while in the entanglement layer according to the `entanglement` strategy. The circuit blocks can have arbitrary sizes (smaller equal to the number of qubits in the circuit). Each layer is repeated `reps` times, and by default a final rotation layer is appended. + +For instance, a rotation block on 2 qubits and an entanglement block on 4 qubits using `'linear'` entanglement yields the following circuit. + +```python +┌──────┐ ░ ┌──────┐ ░ ┌──────┐ +┤0 ├─░─┤0 ├──────────────── ... ─░─┤0 ├ +│ Rot │ ░ │ │┌──────┐ ░ │ Rot │ +┤1 ├─░─┤1 ├┤0 ├──────── ... ─░─┤1 ├ +├──────┤ ░ │ Ent ││ │┌──────┐ ░ ├──────┤ +┤0 ├─░─┤2 ├┤1 ├┤0 ├ ... ─░─┤0 ├ +│ Rot │ ░ │ ││ Ent ││ │ ░ │ Rot │ +┤1 ├─░─┤3 ├┤2 ├┤1 ├ ... ─░─┤1 ├ +├──────┤ ░ └──────┘│ ││ Ent │ ░ ├──────┤ +┤0 ├─░─────────┤3 ├┤2 ├ ... ─░─┤0 ├ +│ Rot │ ░ └──────┘│ │ ░ │ Rot │ +┤1 ├─░─────────────────┤3 ├ ... ─░─┤1 ├ +└──────┘ ░ └──────┘ ░ └──────┘ + +| | ++---------------------------------+ + repeated reps times +``` + +If specified, barriers can be inserted in between every block. If an initial state object is provided, it is added in front of the NLocal. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits of the circuit. +* **rotation\_blocks** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] |* [*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*] | None*) – The blocks used in the rotation layers. If multiple are passed, these will be applied one after another (like new sub-layers). +* **entanglement\_blocks** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] |* [*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*] | None*) – The blocks used in the entanglement layers. If multiple are passed, these will be applied one after another. To use different entanglements for the sub-layers, see [`get_entangler_map()`](#qiskit.circuit.library.NLocal.get_entangler_map "qiskit.circuit.library.NLocal.get_entangler_map"). +* **entanglement** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – The indices specifying on which qubits the input blocks act. If `None`, the entanglement blocks are applied at the top of the circuit. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Specifies how often the rotation blocks and entanglement blocks are repeated. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, barriers are inserted in between each layer. If `False`, no barriers are inserted. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The prefix used if default parameters are generated. +* **overwrite\_block\_parameters** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]]*) – If the parameters in the added blocks should be overwritten. If `False`, the parameters in the blocks are not changed. +* **skip\_final\_rotation\_layer** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether a final rotation layer is added to the circuit. +* **skip\_unentangled\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, the rotation gates act only on qubits that are entangled. If `False`, the rotation gates act on all qubits. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object which can be used to describe an initial state prepended to the NLocal circuit. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The name of the circuit. +* **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Set this to `True` to output a flat circuit instead of nesting it inside multiple layers of gate objects. By default currently the contents of the output circuit will be wrapped in nested objects for cleaner visualization. However, if you’re using this circuit for anything besides visualization its **strongly** recommended to set this flag to `True` to avoid a large performance overhead for parameter binding. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `reps` parameter is less than or equal to 0. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `reps` parameter is not an int value. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see [`get_entangler_map()`](#qiskit.circuit.library.NLocal.get_entangler_map "qiskit.circuit.library.NLocal.get_entangler_map") for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 165` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of total parameters that can be set to distinct values. + +This does not change when the parameters are bound or exchanged for same parameters, and therefore is different from `num_parameters` which counts the number of unique [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects currently in the circuit. + +**Returns** + +The number of parameters originally available in the circuit. + + + This quantity does not require the circuit to be built yet. + + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If `None` is returned, problem is fully unbounded. + + + +### parameters + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + +## Methods + +### add\_layer + + + +`add_layer(other, entanglement=None, front=False)` + +Append another layer to the NLocal. + +**Parameters** + +* **other** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")) – The layer to compose, can be another NLocal, an Instruction or Gate, or a QuantumCircuit. +* **entanglement** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – The entanglement or qubit indices. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, `other` is appended to the front, else to the back. + +**Returns** + +self, such that chained composes are possible. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If other is not compatible, i.e. is no Instruction and does not have a to\_instruction method. + +**Return type** + +[NLocal](#qiskit.circuit.library.NLocal "qiskit.circuit.library.NLocal") + +### assign\_parameters + + + +`assign_parameters(parameters, inplace=False, **kwargs)` + +Assign parameters to the n-local circuit. + +This method also supports passing a list instead of a dictionary. If a list is passed, the list must have the same length as the number of unbound parameters in the circuit. The parameters are assigned in the order of the parameters in [`ordered_parameters()`](#qiskit.circuit.library.NLocal.ordered_parameters "qiskit.circuit.library.NLocal.ordered_parameters"). + +**Returns** + +A copy of the NLocal circuit with the specified parameters. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the parameters are given as list and do not match the number of parameters. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") | None + +### get\_entangler\_map + + + +`get_entangler_map(rep_num, block_num, num_block_qubits)` + +Get the entangler map for in the repetition `rep_num` and the block `block_num`. + +The entangler map for the current block is derived from the value of `self.entanglement`. Below the different cases are listed, where `i` and `j` denote the repetition number and the block number, respectively, and `n` the number of qubits in the block. + +| entanglement type | entangler map | +| -------------------------------- | -------------------------------------------------- | +| `None` | `[[0, ..., n - 1]]` | +| `str` (e.g `'full'`) | the specified connectivity on `n` qubits | +| `List[int]` | \[`entanglement`] | +| `List[List[int]]` | `entanglement` | +| `List[List[List[int]]]` | `entanglement[i]` | +| `List[List[List[List[int]]]]` | `entanglement[i][j]` | +| `List[str]` | the connectivity specified in `entanglement[i]` | +| `List[List[str]]` | the connectivity specified in `entanglement[i][j]` | +| `Callable[int, str]` | same as `List[str]` | +| `Callable[int, List[List[int]]]` | same as `List[List[List[int]]]` | + +Note that all indices are to be taken modulo the length of the array they act on, i.e. no out-of-bounds index error will be raised but we re-iterate from the beginning of the list. + +**Parameters** + +* **rep\_num** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The current repetition we are in. +* **block\_num** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The block number within the entanglement layers. +* **num\_block\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits in the block. + +**Returns** + +The entangler map for the current block in the current repetition. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the value of `entanglement` could not be cast to a corresponding entangler map. + +**Return type** + +[*Sequence*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Sequence "(in Python v3.12)")\[[*Sequence*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Sequence "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")]] + +### get\_unentangled\_qubits + + + +`get_unentangled_qubits()` + +Get the indices of unentangled qubits in a set. + +**Returns** + +The unentangled qubits. + +**Return type** + +[set](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + +### print\_settings + + + +`print_settings()` + +Returns information about the setting. + +**Returns** + +The class name and the attributes/parameters of the instance as `str`. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.OR.md b/docs/api/qiskit/0.46/qiskit.circuit.library.OR.md new file mode 100644 index 00000000000..1dd502a2a2f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.OR.md @@ -0,0 +1,227 @@ +--- +title: OR +description: API reference for qiskit.circuit.library.OR +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.OR +--- + +# OR + + + +`qiskit.circuit.library.OR(num_variable_qubits, flags=None, mcx_mode='noancilla')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/boolean_logic/quantum_or.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +A circuit implementing the logical OR operation on a number of qubits. + +For the OR operation the state $|1\rangle$ is interpreted as `True`. The result qubit is flipped, if the state of any variable qubit is `True`. The OR is implemented using a multi-open-controlled X gate (i.e. flips if the state is $|0\rangle$) and applying an X gate on the result qubit. Using a list of flags, qubits can be skipped or negated. + +The OR gate without special flags: + +![../\_images/qiskit-circuit-library-OR-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-OR-1.png) + +Using flags we can negate qubits or skip them. For instance, if we have 5 qubits and want to return `True` if the first qubit is `False` or one of the last two are `True` we use the flags `[-1, 0, 0, 1, 1]`. + +![../\_images/qiskit-circuit-library-OR-2.png](/images/api/qiskit/0.46/qiskit-circuit-library-OR-2.png) + +Create a new logical OR circuit. + +**Parameters** + +* **num\_variable\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The qubits of which the OR is computed. The result will be written into an additional result qubit. +* **flags** (*Optional\[List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – A list of +1/0/-1 marking negations or omissions of qubits. +* **mcx\_mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The mode to be used to implement the multi-controlled X gate. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 168` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PauliEvolutionGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliEvolutionGate.md new file mode 100644 index 00000000000..985bd6ab6ee --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliEvolutionGate.md @@ -0,0 +1,191 @@ +--- +title: PauliEvolutionGate +description: API reference for qiskit.circuit.library.PauliEvolutionGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PauliEvolutionGate +--- + +# PauliEvolutionGate + + + +`qiskit.circuit.library.PauliEvolutionGate(operator, time=1.0, label=None, synthesis=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/pauli_evolution.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Time-evolution of an operator consisting of Paulis. + +For an operator $H$ consisting of Pauli terms and (real) evolution time $t$ this gate implements + +$$ +U(t) = e^{-itH}. +$$ + +This gate serves as a high-level definition of the evolution and can be synthesized into a circuit using different algorithms. + +The evolution gates are related to the Pauli rotation gates by a factor of 2. For example the time evolution of the Pauli $X$ operator is connected to the Pauli $X$ rotation $R_X$ by + +$$ +U(t) = e^{-itX} = R_X(2t). +$$ + +**Examples:** + +```python +from qiskit.circuit import QuantumCircuit +from qiskit.circuit.library import PauliEvolutionGate +from qiskit.opflow import I, Z, X + +# build the evolution gate +operator = (Z ^ Z) - 0.1 * (X ^ I) +evo = PauliEvolutionGate(operator, time=0.2) + +# plug it into a circuit +circuit = QuantumCircuit(2) +circuit.append(evo, range(2)) +print(circuit.draw()) +``` + +The above will print (note that the `-0.1` coefficient is not printed!): + +```python + ┌──────────────────────────┐ +q_0: ┤0 ├ + │ exp(-it (ZZ + XI))(0.2) │ +q_1: ┤1 ├ + └──────────────────────────┘ +``` + +**References:** + +\[1] G. Li et al. Paulihedral: A Generalized Block-Wise Compiler Optimization Framework For Quantum Simulation Kernels (2021). \[[arXiv:2109.03371](https://arxiv.org/abs/2109.03371)] + +**Parameters** + +* **operator** ([*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *|*[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.PauliOp") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") *|*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The operator to evolve. Can also be provided as list of non-commuting operators where the elements are sums of commuting operators. For example: `[XY + YX, ZZ + ZI + IZ, YY]`. +* **time** (*Union\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – The evolution time. +* **label** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – A label for the gate to display in visualizations. Per default, the label is set to `exp(-it )` where `` is the sum of the Paulis. Note that the label does not include any coefficients of the Paulis. See the class docstring for an example. +* **synthesis** (*Optional\[*[*EvolutionSynthesis*](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis")*]*) – A synthesis strategy. If None, the default synthesis is the Lie-Trotter product formula with a single repetition. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.PauliEvolutionGate.base_class "qiskit.circuit.library.PauliEvolutionGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### time + +Return the evolution time as stored in the gate parameters. + +**Returns** + +The evolution time. + + + +### unit + +Get the time unit of duration. + +## Methods + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Gate parameters should be int, float, or ParameterExpression + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PauliFeatureMap.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliFeatureMap.md new file mode 100644 index 00000000000..8ee9fc54600 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliFeatureMap.md @@ -0,0 +1,418 @@ +--- +title: PauliFeatureMap +description: API reference for qiskit.circuit.library.PauliFeatureMap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PauliFeatureMap +--- + +# PauliFeatureMap + + + +`qiskit.circuit.library.PauliFeatureMap(feature_dimension=None, reps=2, entanglement='full', alpha=2.0, paulis=None, data_map_func=None, parameter_prefix='x', insert_barriers=False, name='PauliFeatureMap')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/data_preparation/pauli_feature_map.py "view source code") + +Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") + +The Pauli Expansion circuit. + +The Pauli Expansion circuit is a data encoding circuit that transforms input data $\vec{x} \in \mathbb{R}^n$, where n is the `feature_dimension`, as + +$$ +U_{\Phi(\vec{x})}=\exp\left(i\sum_{S \in \mathcal{I}} +\phi_S(\vec{x})\prod_{i\in S} P_i\right). +$$ + +Here, $S$ is a set of qubit indices that describes the connections in the feature map, $\mathcal{I}$ is a set containing all these index sets, and $P_i \in \{I, X, Y, Z\}$. Per default the data-mapping $\phi_S$ is + +$$ +\phi_S(\vec{x}) = \begin{cases} + x_i \text{ if } S = \{i\} \\ + \prod_{j \in S} (\pi - x_j) \text{ if } |S| > 1 + \end{cases}. +$$ + +The possible connections can be set using the `entanglement` and `paulis` arguments. For example, for single-qubit $Z$ rotations and two-qubit $YY$ interactions between all qubit pairs, we can set: + +```python +feature_map = PauliFeatureMap(..., paulis=["Z", "YY"], entanglement="full") +``` + +which will produce blocks of the form + +```python +┌───┐┌──────────────┐┌──────────┐ ┌───────────┐ +┤ H ├┤ U1(2.0*x[0]) ├┤ RX(pi/2) ├──■───────────────────────────────────────■──┤ RX(-pi/2) ├ +├───┤├──────────────┤├──────────┤┌─┴─┐┌─────────────────────────────────┐┌─┴─┐├───────────┤ +┤ H ├┤ U1(2.0*x[1]) ├┤ RX(pi/2) ├┤ X ├┤ U1(2.0*(pi - x[0])*(pi - x[1])) ├┤ X ├┤ RX(-pi/2) ├ +└───┘└──────────────┘└──────────┘└───┘└─────────────────────────────────┘└───┘└───────────┘ +``` + +The circuit contains `reps` repetitions of this transformation. + +Please refer to [`ZFeatureMap`](qiskit.circuit.library.ZFeatureMap "qiskit.circuit.library.ZFeatureMap") for the case of single-qubit Pauli-$Z$ rotations and to [`ZZFeatureMap`](qiskit.circuit.library.ZZFeatureMap "qiskit.circuit.library.ZZFeatureMap") for the single- and two-qubit Pauli-$Z$ rotations. + +**Examples** + +```python +>>> prep = PauliFeatureMap(2, reps=1, paulis=['ZZ']) +>>> print(prep) + ┌───┐ +q_0: ┤ H ├──■───────────────────────────────────────■── + ├───┤┌─┴─┐┌─────────────────────────────────┐┌─┴─┐ +q_1: ┤ H ├┤ X ├┤ U1(2.0*(pi - x[0])*(pi - x[1])) ├┤ X ├ + └───┘└───┘└─────────────────────────────────┘└───┘ +``` + +```python +>>> prep = PauliFeatureMap(2, reps=1, paulis=['Z', 'XX']) +>>> print(prep) + ┌───┐┌──────────────┐┌───┐ ┌───┐ +q_0: ┤ H ├┤ U1(2.0*x[0]) ├┤ H ├──■───────────────────────────────────────■──┤ H ├ + ├───┤├──────────────┤├───┤┌─┴─┐┌─────────────────────────────────┐┌─┴─┐├───┤ +q_1: ┤ H ├┤ U1(2.0*x[1]) ├┤ H ├┤ X ├┤ U1(2.0*(pi - x[0])*(pi - x[1])) ├┤ X ├┤ H ├ + └───┘└──────────────┘└───┘└───┘└─────────────────────────────────┘└───┘└───┘ +``` + +```python +>>> prep = PauliFeatureMap(2, reps=1, paulis=['ZY']) +>>> print(prep) + ┌───┐┌──────────┐ ┌───────────┐ +q_0: ┤ H ├┤ RX(pi/2) ├──■───────────────────────────────────────■──┤ RX(-pi/2) ├ + ├───┤└──────────┘┌─┴─┐┌─────────────────────────────────┐┌─┴─┐└───────────┘ +q_1: ┤ H ├────────────┤ X ├┤ U1(2.0*(pi - x[0])*(pi - x[1])) ├┤ X ├───────────── + └───┘ └───┘└─────────────────────────────────┘└───┘ +``` + +```python +>>> from qiskit.circuit.library import EfficientSU2 +>>> prep = PauliFeatureMap(3, reps=3, paulis=['Z', 'YY', 'ZXZ']) +>>> wavefunction = EfficientSU2(3) +>>> classifier = prep.compose(wavefunction +>>> classifier.num_parameters +27 +>>> classifier.count_ops() +OrderedDict([('cx', 39), ('rx', 36), ('u1', 21), ('h', 15), ('ry', 12), ('rz', 12)]) +``` + +References: + +\[1] Havlicek et al. Supervised learning with quantum enhanced feature spaces, [Nature 567, 209-212 (2019)](https://www.nature.com/articles/s41586-019-0980-2). + +Create a new Pauli expansion circuit. + +**Parameters** + +* **feature\_dimension** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Number of qubits in the circuit. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of repeated circuits. +* **entanglement** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] |* [*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Specifies the entanglement structure. Refer to [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.NLocal") for detail. +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The Pauli rotation factor, multiplicative to the pauli rotations +* **paulis** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – A list of strings for to-be-used paulis. If None are provided, `['Z', 'ZZ']` will be used. +* **data\_map\_func** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A mapping function for data x which can be supplied to override the default mapping from `self_product()`. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The prefix used if default parameters are generated. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, barriers are inserted in between the evolution instructions and hadamard layers. + +## Attributes + + + +### alpha + +The Pauli rotation factor (alpha). + +**Returns** + +The Pauli rotation factor. + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### feature\_dimension + +Returns the feature dimension (which is equal to the number of qubits). + +**Returns** + +The feature dimension of this feature map. + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 173` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of distinct parameters. + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If `None` is returned, problem is fully unbounded. + + + +### parameters + + + +### paulis + +The Pauli strings used in the entanglement of the qubits. + +**Returns** + +The Pauli strings as list. + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + +## Methods + +### pauli\_block + + + +`pauli_block(pauli_string)` + +Get the Pauli block for the feature map circuit. + +### pauli\_evolution + + + +`pauli_evolution(pauli_string, time)` + +Get the evolution block for the given pauli string. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PauliGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliGate.md new file mode 100644 index 00000000000..81b9602d8bc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliGate.md @@ -0,0 +1,148 @@ +--- +title: PauliGate +description: API reference for qiskit.circuit.library.PauliGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PauliGate +--- + +# PauliGate + + + +`qiskit.circuit.library.PauliGate(label)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/pauli.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +A multi-qubit Pauli gate. + +This gate exists for optimization purposes for the quantum statevector simulation, since applying multiple pauli gates to different qubits at once can be done via a single pass on the statevector. + +The functionality is equivalent to applying the pauli gates sequentially using standard Qiskit gates. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`pauli()`](qiskit.circuit.QuantumCircuit#pauli "qiskit.circuit.QuantumCircuit.pauli") method. + +Create a new gate. + +**Parameters** + +* **name** – The Qobj name of the gate. +* **num\_qubits** – The number of qubits the gate acts on. +* **params** – A list of parameters. +* **label** – An optional label for the gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.PauliGate.base_class "qiskit.circuit.library.PauliGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted pauli gate (itself). + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Gate parameters should be int, float, or ParameterExpression + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PauliTwoDesign.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliTwoDesign.md new file mode 100644 index 00000000000..282be122251 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PauliTwoDesign.md @@ -0,0 +1,329 @@ +--- +title: PauliTwoDesign +description: API reference for qiskit.circuit.library.PauliTwoDesign +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PauliTwoDesign +--- + +# PauliTwoDesign + + + +`qiskit.circuit.library.PauliTwoDesign(num_qubits=None, reps=3, seed=None, insert_barriers=False, name='PauliTwoDesign')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/n_local/pauli_two_design.py "view source code") + +Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") + +The Pauli Two-Design ansatz. + +This class implements a particular form of a 2-design circuit \[1], which is frequently studied in quantum machine learning literature, such as e.g. the investigating of Barren plateaus in variational algorithms \[2]. + +The circuit consists of alternating rotation and entanglement layers with an initial layer of $\sqrt{H} = RY(\pi/4)$ gates. The rotation layers contain single qubit Pauli rotations, where the axis is chosen uniformly at random to be X, Y or Z. The entanglement layers is compromised of pairwise CZ gates with a total depth of 2. + +For instance, the circuit could look like this (but note that choosing a different seed yields different Pauli rotations). + +```python + ┌─────────┐┌──────────┐ ░ ┌──────────┐ ░ ┌──────────┐ +q_0: ┤ RY(π/4) ├┤ RZ(θ[0]) ├─■─────░─┤ RY(θ[4]) ├─■─────░──┤ RZ(θ[8]) ├ + ├─────────┤├──────────┤ │ ░ ├──────────┤ │ ░ ├──────────┤ +q_1: ┤ RY(π/4) ├┤ RZ(θ[1]) ├─■──■──░─┤ RY(θ[5]) ├─■──■──░──┤ RX(θ[9]) ├ + ├─────────┤├──────────┤ │ ░ ├──────────┤ │ ░ ┌┴──────────┤ +q_2: ┤ RY(π/4) ├┤ RX(θ[2]) ├─■──■──░─┤ RY(θ[6]) ├─■──■──░─┤ RX(θ[10]) ├ + ├─────────┤├──────────┤ │ ░ ├──────────┤ │ ░ ├───────────┤ +q_3: ┤ RY(π/4) ├┤ RZ(θ[3]) ├─■─────░─┤ RX(θ[7]) ├─■─────░─┤ RY(θ[11]) ├ + └─────────┘└──────────┘ ░ └──────────┘ ░ └───────────┘ +``` + +**Examples** + +```python +from qiskit.circuit.library import PauliTwoDesign +circuit = PauliTwoDesign(4, reps=2, seed=5, insert_barriers=True) +circuit.draw('mpl') +``` + +![../\_images/qiskit-circuit-library-PauliTwoDesign-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-PauliTwoDesign-1.png) + +**References** + +**\[1]: Nakata et al., Unitary 2-designs from random X- and Z-diagonal unitaries.** + +[arXiv:1502.07514](https://arxiv.org/pdf/1502.07514.pdf) + +**\[2]: McClean et al., Barren plateaus in quantum neural network training landscapes.** + +[arXiv:1803.11173](https://arxiv.org/pdf/1803.11173.pdf) + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits of the Pauli Two-Design circuit. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Specifies how often a block consisting of a rotation layer and entanglement layer is repeated. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The seed for randomly choosing the axes of the Pauli rotations. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, barriers are inserted in between each layer. If `False`, no barriers are inserted. Defaults to `False`. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 174` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +Return the number of settable parameters. + +**Returns** + +The number of possibly distinct parameters. + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If `None` is returned, problem is fully unbounded. + + + +### parameters + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.Permutation.md b/docs/api/qiskit/0.46/qiskit.circuit.library.Permutation.md new file mode 100644 index 00000000000..67683df9d9f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.Permutation.md @@ -0,0 +1,229 @@ +--- +title: Permutation +description: API reference for qiskit.circuit.library.Permutation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.Permutation +--- + +# Permutation + + + +`qiskit.circuit.library.Permutation(num_qubits, pattern=None, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/permutation.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +An n\_qubit circuit that permutes qubits. + +Return an n\_qubit permutation circuit implemented using SWAPs. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – circuit width. +* **pattern** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | np.ndarray | None*) – permutation pattern, describing which qubits occupy the positions 0, 1, 2, etc. after applying the permutation, that is `pattern[k] = m` when the permutation maps qubit `m` to position `k`. As an example, the pattern `[2, 4, 3, 0, 1]` means that qubit `2` goes to position `0`, qubit `4` goes to the position `1`, etc. The pattern can also be `None`, in which case a random permutation over `num_qubits` is created. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – random seed in case a random permutation is requested. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if permutation pattern is malformed. + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-Permutation-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-Permutation-1.png) + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-Permutation-2.png](/images/api/qiskit/0.46/qiskit-circuit-library-Permutation-2.png) + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 192` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PermutationGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PermutationGate.md new file mode 100644 index 00000000000..469398a0091 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PermutationGate.md @@ -0,0 +1,157 @@ +--- +title: PermutationGate +description: API reference for qiskit.circuit.library.PermutationGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PermutationGate +--- + +# PermutationGate + + + +`qiskit.circuit.library.PermutationGate(pattern)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/permutation.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +A gate that permutes qubits. + +Return a permutation gate. + +**Parameters** + +**pattern** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – permutation pattern, describing which qubits occupy the positions 0, 1, 2, etc. after applying the permutation, that is `pattern[k] = m` when the permutation maps qubit `m` to position `k`. As an example, the pattern `[2, 4, 3, 0, 1]` means that qubit `2` goes to position `0`, qubit `4` goes to the position `1`, etc. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if permutation pattern is malformed. + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-PermutationGate-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-PermutationGate-1.png) + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-PermutationGate-2.png](/images/api/qiskit/0.46/qiskit-circuit-library-PermutationGate-2.png) + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.PermutationGate.base_class "qiskit.circuit.library.PermutationGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### pattern + +Returns the permutation pattern defining this permutation. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Returns the inverse of the permutation. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Parameter validation. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseEstimation.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseEstimation.md new file mode 100644 index 00000000000..ee66766b1eb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseEstimation.md @@ -0,0 +1,246 @@ +--- +title: PhaseEstimation +description: API reference for qiskit.circuit.library.PhaseEstimation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PhaseEstimation +--- + +# PhaseEstimation + + + +`qiskit.circuit.library.PhaseEstimation(num_evaluation_qubits, unitary, iqft=None, name='QPE')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/phase_estimation.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Phase Estimation circuit. + +In the Quantum Phase Estimation (QPE) algorithm \[1, 2, 3], the Phase Estimation circuit is used to estimate the phase $\phi$ of an eigenvalue $e^{2\pi i\phi}$ of a unitary operator $U$, provided with the corresponding eigenstate $|\psi\rangle$. That is + +$$ +U|\psi\rangle = e^{2\pi i\phi} |\psi\rangle +$$ + +This estimation (and thereby this circuit) is a central routine to several well-known algorithms, such as Shor’s algorithm or Quantum Amplitude Estimation. + +**References:** + +**\[1]: Kitaev, A. Y. (1995). Quantum measurements and the Abelian Stabilizer Problem. 1–22.** + +[quant-ph/9511026](http://arxiv.org/abs/quant-ph/9511026) + +**\[2]: Michael A. Nielsen and Isaac L. Chuang. 2011.** + +Quantum Computation and Quantum Information: 10th Anniversary Edition (10th ed.). Cambridge University Press, New York, NY, USA. + +**\[3]: Qiskit** + +[textbook](https://github.com/Qiskit/textbook/blob/main/notebooks/ch-algorithms/quantum-phase-estimation.ipynb) + +**Parameters** + +* **num\_evaluation\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of evaluation qubits. +* **unitary** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The unitary operation $U$ which will be repeated and controlled. +* **iqft** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *| None*) – A inverse Quantum Fourier Transform, per default the inverse of [`QFT`](qiskit.circuit.library.QFT "qiskit.circuit.library.QFT") is used. Note that the QFT should not include the usual swaps! +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. + + + The inverse QFT should not include a swap of the qubit order. + + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-PhaseEstimation-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-PhaseEstimation-1.png) + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 246` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseGate.md new file mode 100644 index 00000000000..0d5ed6963c0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseGate.md @@ -0,0 +1,203 @@ +--- +title: PhaseGate +description: API reference for qiskit.circuit.library.PhaseGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PhaseGate +--- + +# PhaseGate + + + +`qiskit.circuit.library.PhaseGate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/p.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Single-qubit rotation about the Z axis. + +This is a diagonal gate. It can be implemented virtually in hardware via framechanges (i.e. at zero error and duration). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`p()`](qiskit.circuit.QuantumCircuit#p "qiskit.circuit.QuantumCircuit.p") method. + +**Circuit symbol:** + +```python + ┌──────┐ +q_0: ┤ P(λ) ├ + └──────┘ +``` + +**Matrix Representation:** + +$$ +P(\lambda) = + \begin{pmatrix} + 1 & 0 \\ + 0 & e^{i\lambda} + \end{pmatrix} +$$ + +**Examples:** + +> $$ +> P(\lambda = \pi) = Z +> $$ +> +> $$ +> P(\lambda = \pi/2) = S +> $$ +> +> $$ +> P(\lambda = \pi/4) = T +> $$ + + + `RZGate`: This gate is equivalent to RZ up to a phase factor. + + > $$ + > P(\lambda) = e^{i{\lambda}/2} RZ(\lambda) + > $$ + + Reference for virtual Z gate implementation: [1612.00858](https://arxiv.org/abs/1612.00858) + + +Create new Phase gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.PhaseGate.base_class "qiskit.circuit.library.PhaseGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-Phase gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted Phase gate ($Phase(\lambda)^{\dagger} = Phase(-\lambda)$) + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseOracle.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseOracle.md new file mode 100644 index 00000000000..417bd3cacce --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PhaseOracle.md @@ -0,0 +1,283 @@ +--- +title: PhaseOracle +description: API reference for qiskit.circuit.library.PhaseOracle +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PhaseOracle +--- + +# PhaseOracle + + + +`qiskit.circuit.library.PhaseOracle(expression, synthesizer=None, var_order=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/phase_oracle.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Phase Oracle. + +The Phase Oracle object constructs circuits for any arbitrary input logical expressions. A logical expression is composed of logical operators & (AND), | (OR), \~ (NOT), and ^ (XOR). as well as symbols for literals (variables). For example, ‘a & b’, and (v0 | \~v1) & (\~v2 & v3) are both valid string representation of boolean logical expressions. + +For convenience, this oracle, in addition to parsing arbitrary logical expressions, also supports input strings in the [DIMACS CNF format](http://www.satcompetition.org/2009/format-benchmarks2009.html), which is the standard format for specifying SATisfiability (SAT) problem instances in [Conjunctive Normal Form (CNF)](https://en.wikipedia.org/wiki/Conjunctive_normal_form), which is a conjunction of one or more clauses, where a clause is a disjunction of one or more literals. See `qiskit.circuit.library.phase_oracle.PhaseOracle.from_dimacs_file()`. + +From 16 variables on, possible performance issues should be expected when using the default synthesizer. + +Creates a PhaseOracle object + +**Parameters** + +* **expression** (*Union\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, ClassicalElement]*) – A Python-like boolean expression. +* **synthesizer** (*Optional\[Callable\[\[*[*BooleanExpression*](qiskit.circuit.classicalfunction.BooleanExpression "qiskit.circuit.classicalfunction.BooleanExpression")*],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]]*) – Optional. A function to convert a BooleanExpression into a QuantumCircuit If None is provided, Tweedledum’s pkrm\_synth with phase\_esop will be used. +* **var\_order** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list with the order in which variables will be created. (default: by appearance) + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 248` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### evaluate\_bitstring + + + +`evaluate_bitstring(bitstring)` + +Evaluate the oracle on a bitstring. This evaluation is done classically without any quantum circuit. + +**Parameters** + +**bitstring** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The bitstring for which to evaluate. The input bitstring is expected to be in little-endian order. + +**Returns** + +True if the bitstring is a good state, False otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### from\_dimacs\_file + + + +`classmethod from_dimacs_file(filename)` + +Create a PhaseOracle from the string in the DIMACS format. + +It is possible to build a PhaseOracle from a file in [DIMACS CNF format](http://www.satcompetition.org/2009/format-benchmarks2009.html), which is the standard format for specifying SATisfiability (SAT) problem instances in [Conjunctive Normal Form (CNF)](https://en.wikipedia.org/wiki/Conjunctive_normal_form), which is a conjunction of one or more clauses, where a clause is a disjunction of one or more literals. + +The following is an example of a CNF expressed in the DIMACS format: + +```python +c DIMACS CNF file with 3 satisfying assignments: 1 -2 3, -1 -2 -3, 1 2 -3. +p cnf 3 5 +-1 -2 -3 0 +1 -2 3 0 +1 2 -3 0 +1 -2 -3 0 +-1 2 3 0 +``` + +The first line, following the c character, is a comment. The second line specifies that the CNF is over three boolean variables — let us call them $x_1, x_2, x_3$, and contains five clauses. The five clauses, listed afterwards, are implicitly joined by the logical AND operator, $\land$, while the variables in each clause, represented by their indices, are implicitly disjoined by the logical OR operator, $lor$. The $-$ symbol preceding a boolean variable index corresponds to the logical NOT operator, $lnot$. Character 0 (zero) marks the end of each clause. Essentially, the code above corresponds to the following CNF: + +$(\lnot x_1 \lor \lnot x_2 \lor \lnot x_3) \land (x_1 \lor \lnot x_2 \lor x_3) \land (x_1 \lor x_2 \lor \lnot x_3) \land (x_1 \lor \lnot x_2 \lor \lnot x_3) \land (\lnot x_1 \lor x_2 \lor x_3)$. + +**Parameters** + +**filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A file in DIMACS format. + +**Returns** + +A quantum circuit with a phase oracle. + +**Return type** + +[PhaseOracle](#qiskit.circuit.library.PhaseOracle "qiskit.circuit.library.PhaseOracle") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseChebyshev.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseChebyshev.md new file mode 100644 index 00000000000..67e2a5ceb11 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseChebyshev.md @@ -0,0 +1,241 @@ +--- +title: PiecewiseChebyshev +description: API reference for qiskit.circuit.library.PiecewiseChebyshev +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PiecewiseChebyshev +--- + +# PiecewiseChebyshev + + + +`qiskit.circuit.library.PiecewiseChebyshev(f_x, degree=None, breakpoints=None, num_state_qubits=None, name='pw_cheb')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/piecewise_chebyshev.py "view source code") + +Bases: `BlueprintCircuit` + +Piecewise Chebyshev approximation to an input function. + +For a given function $f(x)$ and degree $d$, this class implements a piecewise polynomial Chebyshev approximation on $n$ qubits to $f(x)$ on the given intervals. All the polynomials in the approximation are of degree $d$. + +The values of the parameters are calculated according to \[1] and see \[2] for a more detailed explanation of the circuit construction and how it acts on the qubits. + +**Examples** + +```python +import numpy as np +from qiskit import QuantumCircuit +from qiskit.circuit.library.arithmetic.piecewise_chebyshev import PiecewiseChebyshev +f_x, degree, breakpoints, num_state_qubits = lambda x: np.arcsin(1 / x), 2, [2, 4], 2 +pw_approximation = PiecewiseChebyshev(f_x, degree, breakpoints, num_state_qubits) +pw_approximation._build() +qc = QuantumCircuit(pw_approximation.num_qubits) +qc.h(list(range(num_state_qubits))) +qc.append(pw_approximation.to_instruction(), qc.qubits) +qc.draw(output='mpl') +``` + +![../\_images/qiskit-circuit-library-PiecewiseChebyshev-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-PiecewiseChebyshev-1.png) + +**References** + +**\[1]: Haener, T., Roetteler, M., & Svore, K. M. (2018).** + +Optimizing Quantum Circuits for Arithmetic. [arXiv:1805.12445](http://arxiv.org/abs/1805.12445) + +**\[2]: Carrera Vazquez, A., Hiptmair, H., & Woerner, S. (2022).** + +Enhancing the Quantum Linear Systems Algorithm Using Richardson Extrapolation. [ACM Transactions on Quantum Computing 3, 1, Article 2](https://doi.org/10.1145/3490631) + +**Parameters** + +* **f\_x** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – the function to be approximated. Constant functions should be specified as f\_x = constant. +* **degree** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – the degree of the polynomials. Defaults to `1`. +* **breakpoints** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – the breakpoints to define the piecewise-linear function. Defaults to the full interval. +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – number of qubits representing the state. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit object. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### breakpoints + +The breakpoints for the piecewise approximation. + +**Returns** + +The breakpoints for the piecewise approximation. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### degree + +The degree of the polynomials. + +**Returns** + +The degree of the polynomials. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### f\_x + +The function to be approximated. + +**Returns** + +The function to be approximated. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 250` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits representing the state $|x\rangle$. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### polynomials + +The polynomials for the piecewise approximation. + +**Returns** + +The polynomials for the piecewise approximation. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the input function is not in the correct format. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseLinearPauliRotations.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseLinearPauliRotations.md new file mode 100644 index 00000000000..27872c7ab47 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewiseLinearPauliRotations.md @@ -0,0 +1,278 @@ +--- +title: PiecewiseLinearPauliRotations +description: API reference for qiskit.circuit.library.PiecewiseLinearPauliRotations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PiecewiseLinearPauliRotations +--- + +# PiecewiseLinearPauliRotations + + + +`qiskit.circuit.library.PiecewiseLinearPauliRotations(num_state_qubits=None, breakpoints=None, slopes=None, offsets=None, basis='Y', name='pw_lin')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/piecewise_linear_pauli_rotations.py "view source code") + +Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") + +Piecewise-linearly-controlled Pauli rotations. + +For a piecewise linear (not necessarily continuous) function $f(x)$, which is defined through breakpoints, slopes and offsets as follows. Suppose the breakpoints $(x_0, ..., x_J)$ are a subset of $[0, 2^n-1]$, where $n$ is the number of state qubits. Further on, denote the corresponding slopes and offsets by $a_j$ and $b_j$ respectively. Then f(x) is defined as: + +$$ +f(x) = \begin{cases} + 0, x < x_0 \\ + a_j (x - x_j) + b_j, x_j \leq x < x_{j+1} + \end{cases} +$$ + +where we implicitly assume $x_{J+1} = 2^n$. + +Construct piecewise-linearly-controlled Pauli rotations. + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits representing the state. +* **breakpoints** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – The breakpoints to define the piecewise-linear function. Defaults to `[0]`. +* **slopes** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | np.ndarray | None*) – The slopes for different segments of the piecewise-linear function. Defaults to `[1]`. +* **offsets** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | np.ndarray | None*) – The offsets for different segments of the piecewise-linear function. Defaults to `[0]`. +* **basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The type of Pauli rotation (`'X'`, `'Y'`, `'Z'`). +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### basis + +The kind of Pauli rotation to be used. + +Set the basis to ‘X’, ‘Y’ or ‘Z’ for controlled-X, -Y, or -Z rotations respectively. + +**Returns** + +The kind of Pauli rotation used in controlled rotation. + + + +### breakpoints + +The breakpoints of the piecewise linear function. + +The function is linear in the intervals `[point_i, point_{i+1}]` where the last point implicitly is `2**(num_state_qubits + 1)`. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### contains\_zero\_breakpoint + +Whether 0 is the first breakpoint. + +**Returns** + +True, if 0 is the first breakpoint, otherwise False. + + + +### data + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 310` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### mapped\_offsets + +The offsets mapped to the internal representation. + +**Returns** + +The mapped offsets. + + + +### mapped\_slopes + +The slopes mapped to the internal representation. + +**Returns** + +The mapped slopes. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +The minimum number of ancilla qubits in the circuit. + +**Returns** + +The minimal number of ancillas required. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits representing the state $|x\rangle$. + +**Returns** + +The number of state qubits. + + + +### offsets + +The breakpoints of the piecewise linear function. + +The function is linear in the intervals `[point_i, point_{i+1}]` where the last point implicitly is `2**(num_state_qubits + 1)`. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### slopes + +The breakpoints of the piecewise linear function. + +The function is linear in the intervals `[point_i, point_{i+1}]` where the last point implicitly is `2**(num_state_qubits + 1)`. + +## Methods + +### evaluate + + + +`evaluate(x)` + +Classically evaluate the piecewise linear rotation. + +**Parameters** + +**x** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value to be evaluated at. + +**Returns** + +Value of piecewise linear function at x. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewisePolynomialPauliRotations.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewisePolynomialPauliRotations.md new file mode 100644 index 00000000000..8899b5cde63 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PiecewisePolynomialPauliRotations.md @@ -0,0 +1,310 @@ +--- +title: PiecewisePolynomialPauliRotations +description: API reference for qiskit.circuit.library.PiecewisePolynomialPauliRotations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PiecewisePolynomialPauliRotations +--- + +# PiecewisePolynomialPauliRotations + + + +`qiskit.circuit.library.PiecewisePolynomialPauliRotations(num_state_qubits=None, breakpoints=None, coeffs=None, basis='Y', name='pw_poly')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/piecewise_polynomial_pauli_rotations.py "view source code") + +Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") + +Piecewise-polynomially-controlled Pauli rotations. + +This class implements a piecewise polynomial (not necessarily continuous) function, $f(x)$, on qubit amplitudes, which is defined through breakpoints and coefficients as follows. Suppose the breakpoints $(x_0, ..., x_J)$ are a subset of $[0, 2^n-1]$, where $n$ is the number of state qubits. Further on, denote the corresponding coefficients by $[a_{j,1},...,a_{j,d}]$, where $d$ is the highest degree among all polynomials. + +Then $f(x)$ is defined as: + +$$ +f(x) = \begin{cases} + 0, x < x_0 \\ + \sum_{i=0}^{i=d}a_{j,i}/2 x^i, x_j \leq x < x_{j+1} + \end{cases} +$$ + +where if given the same number of breakpoints as polynomials, we implicitly assume $x_{J+1} = 2^n$. + + + Note the $1/2$ factor in the coefficients of $f(x)$, this is consistent with Qiskit’s Pauli rotations. + + +**Examples** + +```python +>>> from qiskit import QuantumCircuit +>>> from qiskit.circuit.library.arithmetic.piecewise_polynomial_pauli_rotations import\ +... PiecewisePolynomialPauliRotations +>>> qubits, breakpoints, coeffs = (2, [0, 2], [[0, -1.2],[-1, 1, 3]]) +>>> poly_r = PiecewisePolynomialPauliRotations(num_state_qubits=qubits, +...breakpoints=breakpoints, coeffs=coeffs) +>>> +>>> qc = QuantumCircuit(poly_r.num_qubits) +>>> qc.h(list(range(qubits))); +>>> qc.append(poly_r.to_instruction(), list(range(qc.num_qubits))); +>>> qc.draw() + ┌───┐┌──────────┐ +q_0: ┤ H ├┤0 ├ + ├───┤│ │ +q_1: ┤ H ├┤1 ├ + └───┘│ │ +q_2: ─────┤2 ├ + │ pw_poly │ +q_3: ─────┤3 ├ + │ │ +q_4: ─────┤4 ├ + │ │ +q_5: ─────┤5 ├ + └──────────┘ +``` + +**References** + +**\[1]: Haener, T., Roetteler, M., & Svore, K. M. (2018).** + +Optimizing Quantum Circuits for Arithmetic. [arXiv:1805.12445](http://arxiv.org/abs/1805.12445) + +**\[2]: Carrera Vazquez, A., Hiptmair, R., & Woerner, S. (2022).** + +Enhancing the Quantum Linear Systems Algorithm using Richardson Extrapolation. [ACM Transactions on Quantum Computing 3, 1, Article 2](https://doi.org/10.1145/3490631) + +**Parameters** + +* **num\_state\_qubits** (*Optional\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The number of qubits representing the state. +* **breakpoints** (*Optional\[List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – The breakpoints to define the piecewise-linear function. Defaults to `[0]`. +* **coeffs** (*Optional\[List\[List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]]*) – The coefficients of the polynomials for different segments of the +* **x** (*piecewise-linear function. coeffs\[j]\[i] is the coefficient of the i-th power of*) – +* **polynomial.** (*for the j-th*) – Defaults to linear: `[[1]]`. +* **basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The type of Pauli rotation (`'X'`, `'Y'`, `'Z'`). +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### basis + +The kind of Pauli rotation to be used. + +Set the basis to ‘X’, ‘Y’ or ‘Z’ for controlled-X, -Y, or -Z rotations respectively. + +**Returns** + +The kind of Pauli rotation used in controlled rotation. + + + +### breakpoints + +The breakpoints of the piecewise polynomial function. + +The function is polynomial in the intervals `[point_i, point_{i+1}]` where the last point implicitly is `2**(num_state_qubits + 1)`. + +**Returns** + +The list of breakpoints. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### coeffs + +The coefficients of the polynomials. + +**Returns** + +The polynomial coefficients per interval as nested lists. + + + +### contains\_zero\_breakpoint + +Whether 0 is the first breakpoint. + +**Returns** + +True, if 0 is the first breakpoint, otherwise False. + + + +### data + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 250` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### mapped\_coeffs + +The coefficients mapped to the internal representation, since we only compare x>=breakpoint. + +**Returns** + +The mapped coefficients. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +The minimum number of ancilla qubits in the circuit. + +**Returns** + +The minimal number of ancillas required. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits representing the state $|x\rangle$. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### evaluate + + + +`evaluate(x)` + +Classically evaluate the piecewise polynomial rotation. + +**Parameters** + +**x** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value to be evaluated at. + +**Returns** + +Value of piecewise polynomial function at x. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.PolynomialPauliRotations.md b/docs/api/qiskit/0.46/qiskit.circuit.library.PolynomialPauliRotations.md new file mode 100644 index 00000000000..758cda3a6d2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.PolynomialPauliRotations.md @@ -0,0 +1,238 @@ +--- +title: PolynomialPauliRotations +description: API reference for qiskit.circuit.library.PolynomialPauliRotations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.PolynomialPauliRotations +--- + +# PolynomialPauliRotations + + + +`qiskit.circuit.library.PolynomialPauliRotations(num_state_qubits=None, coeffs=None, basis='Y', name='poly')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/polynomial_pauli_rotations.py "view source code") + +Bases: [`FunctionalPauliRotations`](qiskit.circuit.library.FunctionalPauliRotations "qiskit.circuit.library.arithmetic.functional_pauli_rotations.FunctionalPauliRotations") + +A circuit implementing polynomial Pauli rotations. + +For a polynomial $p(x)$, a basis state $|i\rangle$ and a target qubit $|0\rangle$ this operator acts as: + +$$ +|i\rangle |0\rangle \mapsto \cos\left(\frac{p(i)}{2}\right) |i\rangle |0\rangle ++ \sin\left(\frac{p(i)}{2}\right) |i\rangle |1\rangle +$$ + +Let n be the number of qubits representing the state, d the degree of p(x) and q\_i the qubits, where q\_0 is the least significant qubit. Then for + +$$ +x = \sum_{i=0}^{n-1} 2^i q_i, +$$ + +we can write + +$$ +p(x) = \sum_{j=0}^{j=d} c_j x^j +$$ + +where $c$ are the input coefficients, `coeffs`. + +Prepare an approximation to a state with amplitudes specified by a polynomial. + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits representing the state. +* **coeffs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – The coefficients of the polynomial. `coeffs[i]` is the coefficient of the i-th power of x. Defaults to linear: \[0, 1]. +* **basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The type of Pauli rotation (‘X’, ‘Y’, ‘Z’). +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### basis + +The kind of Pauli rotation to be used. + +Set the basis to ‘X’, ‘Y’ or ‘Z’ for controlled-X, -Y, or -Z rotations respectively. + +**Returns** + +The kind of Pauli rotation used in controlled rotation. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### coeffs + +The coefficients of the polynomial. + +`coeffs[i]` is the coefficient of the i-th power of the function input $x$, that means that the rotation angles are based on the coefficients value, following the formula + +$$ +c_j x^j , j=0, ..., d +$$ + +where $d$ is the degree of the polynomial $p(x)$ and $c$ are the coefficients `coeffs`. + +**Returns** + +The coefficients of the polynomial. + + + +### data + + + +### degree + +Return the degree of the polynomial, equals to the number of coefficients minus 1. + +**Returns** + +The degree of the polynomial. If the coefficients have not been set, return 0. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 253` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancilla\_qubits + +The minimum number of ancilla qubits in the circuit. + +**Returns** + +The minimal number of ancillas required. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits representing the state $|x\rangle$. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.QAOAAnsatz.md b/docs/api/qiskit/0.46/qiskit.circuit.library.QAOAAnsatz.md new file mode 100644 index 00000000000..d25abeacc79 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.QAOAAnsatz.md @@ -0,0 +1,345 @@ +--- +title: QAOAAnsatz +description: API reference for qiskit.circuit.library.QAOAAnsatz +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.QAOAAnsatz +--- + +# QAOAAnsatz + + + +`qiskit.circuit.library.QAOAAnsatz(cost_operator=None, reps=1, initial_state=None, mixer_operator=None, name='QAOA', flatten=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/n_local/qaoa_ansatz.py "view source code") + +Bases: [`EvolvedOperatorAnsatz`](qiskit.circuit.library.EvolvedOperatorAnsatz "qiskit.circuit.library.evolved_operator_ansatz.EvolvedOperatorAnsatz") + +A generalized QAOA quantum circuit with a support of custom initial states and mixers. + +**References** + +**\[1]: Farhi et al., A Quantum Approximate Optimization Algorithm.** + +[arXiv:1411.4028](https://arxiv.org/pdf/1411.4028) + +**Parameters** + +* **cost\_operator** (*BaseOperator or* [*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase")*, optional*) – The operator representing the cost of the optimization problem, denoted as $U(C, \gamma)$ in the original paper. Must be set either in the constructor or via property setter. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The integer parameter p, which determines the depth of the circuit, as specified in the original paper, default is 1. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*, optional*) – An optional initial state to use. If None is passed then a set of Hadamard gates is applied as an initial state to all qubits. +* **mixer\_operator** (*BaseOperator or* [*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*, optional*) – An optional custom mixer to use instead of the global X-rotations, denoted as $U(B, \beta)$ in the original paper. Can be an operator or an optionally parameterized quantum circuit. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A name of the circuit, default ‘qaoa’ +* **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Set this to `True` to output a flat circuit instead of nesting it inside multiple layers of gate objects. By default currently the contents of the output circuit will be wrapped in nested objects for cleaner visualization. However, if you’re using this circuit for anything besides visualization its **strongly** recommended to set this flag to `True` to avoid a large performance overhead for parameter binding. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### cost\_operator + +Returns an operator representing the cost of the optimization problem. + +**Returns** + +cost operator. + +**Return type** + +BaseOperator or [OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### evolution + +The evolution converter used to compute the evolution. + +**Returns** + +The evolution converter used to compute the evolution. + +**Return type** + +[EvolutionBase](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.EvolutionBase") or [EvolutionSynthesis](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Returns an optional initial state as a circuit + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 310` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### mixer\_operator + +Returns an optional mixer operator expressed as an operator or a quantum circuit. + +**Returns** + +mixer operator or circuit. + +**Return type** + +BaseOperator or [OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") or [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), optional + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of total parameters that can be set to distinct values. + +This does not change when the parameters are bound or exchanged for same parameters, and therefore is different from `num_parameters` which counts the number of unique [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects currently in the circuit. + +**Returns** + +The number of parameters originally available in the circuit. + + + This quantity does not require the circuit to be built yet. + + + + +### num\_qubits + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### operators + +The operators that are evolved in this circuit. + +**Returns** + +**The operators to be evolved** + +(and circuits) in this ansatz. + +**Return type** + +List\[Union\[BaseOperator, [OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase"), [QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")]] + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If None is returned, problem is fully unbounded. + + + +### parameters + + + +### preferred\_init\_points + +Getter of preferred initial points based on the given initial state. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +Returns the reps parameter, which determines the depth of the circuit. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.QFT.md b/docs/api/qiskit/0.46/qiskit.circuit.library.QFT.md new file mode 100644 index 00000000000..d8e18d99d3c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.QFT.md @@ -0,0 +1,249 @@ +--- +title: QFT +description: API reference for qiskit.circuit.library.QFT +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.QFT +--- + +# QFT + + + +`qiskit.circuit.library.QFT(num_qubits=None, approximation_degree=0, do_swaps=True, inverse=False, insert_barriers=False, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/basis_change/qft.py "view source code") + +Bases: `BlueprintCircuit` + +Quantum Fourier Transform Circuit. + +The Quantum Fourier Transform (QFT) on $n$ qubits is the operation + +$$ +|j\rangle \mapsto \frac{1}{2^{n/2}} \sum_{k=0}^{2^n - 1} e^{2\pi ijk / 2^n} |k\rangle +$$ + +The circuit that implements this transformation can be implemented using Hadamard gates on each qubit, a series of controlled-U1 (or Z, depending on the phase) gates and a layer of Swap gates. The layer of Swap gates can in principle be dropped if the QFT appears at the end of the circuit, since then the re-ordering can be done classically. They can be turned off using the `do_swaps` attribute. + +For 4 qubits, the circuit that implements this transformation is: + +![../\_images/qiskit-circuit-library-QFT-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-QFT-1.png) + +The inverse QFT can be obtained by calling the `inverse` method on this class. The respective circuit diagram is: + +![../\_images/qiskit-circuit-library-QFT-2.png](/images/api/qiskit/0.46/qiskit-circuit-library-QFT-2.png) + +One method to reduce circuit depth is to implement the QFT approximately by ignoring controlled-phase rotations where the angle is beneath a threshold. This is discussed in more detail in [https://arxiv.org/abs/quant-ph/9601018](https://arxiv.org/abs/quant-ph/9601018) or [https://arxiv.org/abs/quant-ph/0403071](https://arxiv.org/abs/quant-ph/0403071). + +Here, this can be adjusted using the `approximation_degree` attribute: the smallest `approximation_degree` rotation angles are dropped from the QFT. For instance, a QFT on 5 qubits with approximation degree 2 yields (the barriers are dropped in this example): + +![../\_images/qiskit-circuit-library-QFT-3.png](/images/api/qiskit/0.46/qiskit-circuit-library-QFT-3.png) + +Construct a new QFT circuit. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits on which the QFT acts. +* **approximation\_degree** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The degree of approximation (0 for no approximation). +* **do\_swaps** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to include the final swaps in the QFT. +* **inverse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, the inverse Fourier transform is constructed. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, barriers are inserted as visualization improvement. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### approximation\_degree + +The approximation degree of the QFT. + +**Returns** + +The currently set approximation degree. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### do\_swaps + +Whether the final swaps of the QFT are applied or not. + +**Returns** + +True, if the final swaps are applied, False if not. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### insert\_barriers + +Whether barriers are inserted for better visualization or not. + +**Returns** + +True, if barriers are inserted, False if not. + + + +### instances + +`= 208` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + + + +### num\_qubits + +The number of qubits in the QFT circuit. + +**Returns** + +The number of qubits in the circuit. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### inverse + + + +`inverse()` + +Invert this circuit. + +**Returns** + +The inverted circuit. + +**Return type** + +[*QFT*](#qiskit.circuit.library.QFT "qiskit.circuit.library.basis_change.qft.QFT") + +### is\_inverse + + + +`is_inverse()` + +Whether the inverse Fourier transform is implemented. + +**Returns** + +True, if the inverse Fourier transform is implemented, False otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.QuadraticForm.md b/docs/api/qiskit/0.46/qiskit.circuit.library.QuadraticForm.md new file mode 100644 index 00000000000..385b536442b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.QuadraticForm.md @@ -0,0 +1,272 @@ +--- +title: QuadraticForm +description: API reference for qiskit.circuit.library.QuadraticForm +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.QuadraticForm +--- + +# QuadraticForm + + + +`qiskit.circuit.library.QuadraticForm(num_result_qubits=None, quadratic=None, linear=None, offset=None, little_endian=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/quadratic_form.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Implements a quadratic form on binary variables encoded in qubit registers. + +A quadratic form on binary variables is a quadratic function $Q$ acting on a binary variable of $n$ bits, $x = x_0 ... x_{n-1}$. For an integer matrix $A$, an integer vector $b$ and an integer $c$ the function can be written as + +$$ +Q(x) = x^T A x + x^T b + c +$$ + +If $A$, $b$ or $c$ contain scalar values, this circuit computes only an approximation of the quadratic form. + +Provided with $m$ qubits to encode the value, this circuit computes $Q(x) \mod 2^m$ in \[two’s complement]\([https://stackoverflow.com/questions/1049722/what-is-2s-complement](https://stackoverflow.com/questions/1049722/what-is-2s-complement)) representation. + +$$ +|x\rangle_n |0\rangle_m \mapsto |x\rangle_n |(Q(x) + 2^m) \mod 2^m \rangle_m +$$ + +Since we use two’s complement e.g. the value of $Q(x) = 3$ requires 2 bits to represent the value and 1 bit for the sign: 3 = ‘011’ where the first 0 indicates a positive value. On the other hand, $Q(x) = -3$ would be -3 = ‘101’, where the first 1 indicates a negative value and 01 is the two’s complement of 3. + +If the value of $Q(x)$ is too large to be represented with m qubits, the resulting bitstring is $(Q(x) + 2^m) \mod 2^m)$. + +The implementation of this circuit is discussed in \[1], Fig. 6. + +**References** + +**\[1]: Gilliam et al., Grover Adaptive Search for Constrained Polynomial Binary Optimization.** + +[arXiv:1912.04088](https://arxiv.org/pdf/1912.04088.pdf) + +**Parameters** + +* **num\_result\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits to encode the result. Called $m$ in the class documentation. +* **quadratic** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]] | None*) – A matrix containing the quadratic coefficients, $A$. +* **linear** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] | None*) – An array containing the linear coefficients, $b$. +* **offset** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – A constant offset, $c$. +* **little\_endian** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Encode the result in little endianness. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `linear` and `quadratic` have mismatching sizes. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `num_result_qubits` is unspecified but cannot be determined because some values of the quadratic form are parameterized. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 322` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + +## Methods + +### required\_result\_qubits + + + +`static required_result_qubits(quadratic, linear, offset)` + +Get the number of required result qubits. + +**Parameters** + +* **quadratic** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – A matrix containing the quadratic coefficients. +* **linear** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – An array containing the linear coefficients. +* **offset** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – A constant offset. + +**Returns** + +The number of qubits needed to represent the value of the quadratic form in twos complement. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.QuantumVolume.md b/docs/api/qiskit/0.46/qiskit.circuit.library.QuantumVolume.md new file mode 100644 index 00000000000..620a6ab7643 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.QuantumVolume.md @@ -0,0 +1,234 @@ +--- +title: QuantumVolume +description: API reference for qiskit.circuit.library.QuantumVolume +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.QuantumVolume +--- + +# QuantumVolume + + + +`qiskit.circuit.library.QuantumVolume(num_qubits, depth=None, seed=None, classical_permutation=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/quantum_volume.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +A quantum volume model circuit. + +The model circuits are random instances of circuits used to measure the Quantum Volume metric, as introduced in \[1]. + +The model circuits consist of layers of Haar random elements of SU(4) applied between corresponding pairs of qubits in a random bipartition. + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-QuantumVolume-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-QuantumVolume-1.png) + +**Expanded Circuit:** + +![../\_images/qiskit-circuit-library-QuantumVolume-2.png](/images/api/qiskit/0.46/qiskit-circuit-library-QuantumVolume-2.png) + +**References:** + +\[1] A. Cross et al. Validating quantum computers using randomized model circuits, Phys. Rev. A 100, 032328 (2019). \[[arXiv:1811.12926](https://arxiv.org/abs/1811.12926)] + +Create quantum volume model circuit of size num\_qubits x depth. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of active qubits in model circuit. +* **depth** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – layers of SU(4) operations in model circuit. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Generator*](https://numpy.org/doc/stable/reference/random/generator.html#numpy.random.Generator "(in NumPy v1.26)") *| None*) – Random number generator or generator seed. +* **classical\_permutation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – use classical permutations at every layer, rather than quantum. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 325` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RC3XGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RC3XGate.md new file mode 100644 index 00000000000..d4617ce80b3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RC3XGate.md @@ -0,0 +1,123 @@ +--- +title: RC3XGate +description: API reference for qiskit.circuit.library.RC3XGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RC3XGate +--- + +# RC3XGate + + + +`qiskit.circuit.library.RC3XGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The simplified 3-controlled Toffoli gate. + +The simplified Toffoli gate implements the Toffoli gate up to relative phases. Note, that the simplified Toffoli is not equivalent to the Toffoli. But can be used in places where the Toffoli gate is uncomputed again. + +This concrete implementation is from [https://arxiv.org/abs/1508.03273](https://arxiv.org/abs/1508.03273), the complete circuit of Fig. 4. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rcccx()`](qiskit.circuit.QuantumCircuit#rcccx "qiskit.circuit.QuantumCircuit.rcccx") method. + +Create a new RC3X gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RC3XGate.base_class "qiskit.circuit.library.RC3XGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RCCXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RCCXGate.md new file mode 100644 index 00000000000..3c9d4e88933 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RCCXGate.md @@ -0,0 +1,123 @@ +--- +title: RCCXGate +description: API reference for qiskit.circuit.library.RCCXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RCCXGate +--- + +# RCCXGate + + + +`qiskit.circuit.library.RCCXGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The simplified Toffoli gate, also referred to as Margolus gate. + +The simplified Toffoli gate implements the Toffoli gate up to relative phases. This implementation requires three CX gates which is the minimal amount possible, as shown in [https://arxiv.org/abs/quant-ph/0312225](https://arxiv.org/abs/quant-ph/0312225). Note, that the simplified Toffoli is not equivalent to the Toffoli. But can be used in places where the Toffoli gate is uncomputed again. + +This concrete implementation is from [https://arxiv.org/abs/1508.03273](https://arxiv.org/abs/1508.03273), the dashed box of Fig. 3. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rccx()`](qiskit.circuit.QuantumCircuit#rccx "qiskit.circuit.QuantumCircuit.rccx") method. + +Create a new simplified CCX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RCCXGate.base_class "qiskit.circuit.library.RCCXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RGQFTMultiplier.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RGQFTMultiplier.md new file mode 100644 index 00000000000..831bf1e42b8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RGQFTMultiplier.md @@ -0,0 +1,256 @@ +--- +title: RGQFTMultiplier +description: API reference for qiskit.circuit.library.RGQFTMultiplier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RGQFTMultiplier +--- + +# RGQFTMultiplier + + + +`qiskit.circuit.library.RGQFTMultiplier(num_state_qubits, num_result_qubits=None, name='RGQFTMultiplier')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/multipliers/rg_qft_multiplier.py "view source code") + +Bases: `Multiplier` + +A QFT multiplication circuit to store product of two input registers out-of-place. + +Multiplication in this circuit is implemented using the procedure of Fig. 3 in \[1], where weighted sum rotations are implemented as given in Fig. 5 in \[1]. QFT is used on the output register and is followed by rotations controlled by input registers. The rotations transform the state into the product of two input registers in QFT base, which is reverted from QFT base using inverse QFT. As an example, a circuit that performs a modular QFT multiplication on two 2-qubit sized input registers with an output register of 2 qubits, is as follows: + +```python + a_0: ────────────────────────────────────────■───────■──────■──────■──────────────── + │ │ │ │ + a_1: ─────────■───────■───────■───────■──────┼───────┼──────┼──────┼──────────────── + │ │ │ │ │ │ │ │ + b_0: ─────────┼───────┼───────■───────■──────┼───────┼──────■──────■──────────────── + │ │ │ │ │ │ │ │ + b_1: ─────────■───────■───────┼───────┼──────■───────■──────┼──────┼──────────────── + ┌──────┐ │P(4π) │ │P(2π) │ │P(2π) │ │P(π) │ ┌───────┐ +out_0: ┤0 ├─■───────┼───────■───────┼──────■───────┼──────■──────┼───────┤0 ├ + │ qft │ │P(2π) │P(π) │P(π) │P(π/2) │ iqft │ +out_1: ┤1 ├─────────■───────────────■──────────────■─────────────■───────┤1 ├ + └──────┘ └───────┘ +``` + +**References:** + +\[1] Ruiz-Perez et al., Quantum arithmetic with the Quantum Fourier Transform, 2017. [arXiv:1411.5949](https://arxiv.org/pdf/1411.5949.pdf) + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits in either input register for state $|a\rangle$ or $|b\rangle$. The two input registers must have the same number of qubits. +* **num\_result\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of result qubits to limit the output to. If number of result qubits is $n$, multiplication modulo $2^n$ is performed to limit the output to the specified number of qubits. Default value is `2 * num_state_qubits` to represent any possible result from the multiplication of the two inputs. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit object. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 456` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### num\_result\_qubits + +The number of result qubits to limit the output to. + +**Returns** + +The number of result qubits. + + + +### num\_state\_qubits + +The number of state qubits, i.e. the number of bits in each input register. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RGate.md new file mode 100644 index 00000000000..d96f8b9f6fe --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RGate.md @@ -0,0 +1,159 @@ +--- +title: RGate +description: API reference for qiskit.circuit.library.RGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RGate +--- + +# RGate + + + +`qiskit.circuit.library.RGate(theta, phi, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/r.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Rotation θ around the cos(φ)x + sin(φ)y axis. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`r()`](qiskit.circuit.QuantumCircuit#r "qiskit.circuit.QuantumCircuit.r") method. + +**Circuit symbol:** + +```python + ┌──────┐ +q_0: ┤ R(ϴ) ├ + └──────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R(\theta, \phi) = e^{-i \rotationangle \left(\cos{\phi} x + \sin{\phi} y\right)} = + \begin{pmatrix} + \cos\left(\rotationangle\right) & -i e^{-i \phi} \sin\left(\rotationangle\right) \\ + -i e^{i \phi} \sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + +Create new r single-qubit gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RGate.base_class "qiskit.circuit.library.RGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Invert this gate. + +r(θ, φ)^dagger = r(-θ, φ) + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RVGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RVGate.md new file mode 100644 index 00000000000..15a56da24df --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RVGate.md @@ -0,0 +1,166 @@ +--- +title: RVGate +description: API reference for qiskit.circuit.library.RVGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RVGate +--- + +# RVGate + + + +`qiskit.circuit.library.RVGate(v_x, v_y, v_z, basis='U')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/rv.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Rotation around arbitrary rotation axis $v$ where $|v|$ is angle of rotation in radians. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rv()`](qiskit.circuit.QuantumCircuit#rv "qiskit.circuit.QuantumCircuit.rv") method. + +**Circuit symbol:** + +```python + ┌─────────────────┐ +q_0: ┤ RV(v_x,v_y,v_z) ├ + └─────────────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{|\vec{v}|} +\newcommand{\sinc}{\text{sinc}} + R(\vec{v}) = e^{-i \vec{v}\cdot\vec{\sigma}} = + \begin{pmatrix} + \cos\left(\rotationangle\right) -i v_z \sinc\left(\rotationangle\right) + & -(i v_x + v_y) \sinc\left(\rotationangle\right) \\ + -(i v_x - v_y) \sinc\left(\rotationangle\right) + & \cos\left(\rotationangle\right) + i v_z \sinc\left(\rotationangle\right) + \end{pmatrix} +$$ + +Create new rv single-qubit gate. + +**Parameters** + +* **v\_x** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – x-component +* **v\_y** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – y-component +* **v\_z** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – z-component +* **basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, optional*) – basis (see [`OneQubitEulerDecomposer`](qiskit.synthesis.OneQubitEulerDecomposer "qiskit.synthesis.one_qubit.one_qubit_decompose.OneQubitEulerDecomposer")) + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RVGate.base_class "qiskit.circuit.library.RVGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Invert this gate. + +### to\_matrix + + + +`to_matrix()` + +Return a numpy.array for the R(v) gate. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RXGate.md new file mode 100644 index 00000000000..65b3ef7a476 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RXGate.md @@ -0,0 +1,181 @@ +--- +title: RXGate +description: API reference for qiskit.circuit.library.RXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RXGate +--- + +# RXGate + + + +`qiskit.circuit.library.RXGate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/rx.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Single-qubit rotation about the X axis. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rx()`](qiskit.circuit.QuantumCircuit#rx "qiskit.circuit.QuantumCircuit.rx") method. + +**Circuit symbol:** + +```python + ┌───────┐ +q_0: ┤ Rx(ϴ) ├ + └───────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +RX(\theta) = \exp\left(-i \rotationangle X\right) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & -i\sin\left(\rotationangle\right) \\ + -i\sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + +Create new RX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RXGate.base_class "qiskit.circuit.library.RXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-RX gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted RX gate. + +$RX(\lambda)^{\dagger} = RX(-\lambda)$ + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RXXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RXXGate.md new file mode 100644 index 00000000000..bcf4ffee144 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RXXGate.md @@ -0,0 +1,183 @@ +--- +title: RXXGate +description: API reference for qiskit.circuit.library.RXXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RXXGate +--- + +# RXXGate + + + +`qiskit.circuit.library.RXXGate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/rxx.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +A parametric 2-qubit $X \otimes X$ interaction (rotation about XX). + +This gate is symmetric, and is maximally entangling at $\theta = \pi/2$. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rxx()`](qiskit.circuit.QuantumCircuit#rxx "qiskit.circuit.QuantumCircuit.rxx") method. + +**Circuit Symbol:** + +```python + ┌─────────┐ +q_0: ┤1 ├ + │ Rxx(ϴ) │ +q_1: ┤0 ├ + └─────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R_{XX}(\theta) = \exp\left(-i \rotationangle X{\otimes}X\right) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & 0 & 0 & -i\sin\left(\rotationangle\right) \\ + 0 & \cos\left(\rotationangle\right) & -i\sin\left(\rotationangle\right) & 0 \\ + 0 & -i\sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) & 0 \\ + -i\sin\left(\rotationangle\right) & 0 & 0 & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + +**Examples:** + +> $$ +> R_{XX}(\theta = 0) = I +> $$ +> +> $$ +> R_{XX}(\theta = \pi) = i X \otimes X +> $$ +> +> $$ +> R_{XX}\left(\theta = \frac{\pi}{2}\right) = \frac{1}{\sqrt{2}} +> \begin{pmatrix} +> 1 & 0 & 0 & -i \\ +> 0 & 1 & -i & 0 \\ +> 0 & -i & 1 & 0 \\ +> -i & 0 & 0 & 1 +> \end{pmatrix} +> $$ + +Create new RXX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RXXGate.base_class "qiskit.circuit.library.RXXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse RXX gate (i.e. with the negative rotation angle). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RYGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RYGate.md new file mode 100644 index 00000000000..3ae272d4b0a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RYGate.md @@ -0,0 +1,181 @@ +--- +title: RYGate +description: API reference for qiskit.circuit.library.RYGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RYGate +--- + +# RYGate + + + +`qiskit.circuit.library.RYGate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/ry.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Single-qubit rotation about the Y axis. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`ry()`](qiskit.circuit.QuantumCircuit#ry "qiskit.circuit.QuantumCircuit.ry") method. + +**Circuit symbol:** + +```python + ┌───────┐ +q_0: ┤ Ry(ϴ) ├ + └───────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +RY(\theta) = \exp\left(-i \rotationangle Y\right) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & -\sin\left(\rotationangle\right) \\ + \sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + +Create new RY gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RYGate.base_class "qiskit.circuit.library.RYGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-RY gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted RY gate. + +$RY(\lambda)^{\dagger} = RY(-\lambda)$ + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RYYGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RYYGate.md new file mode 100644 index 00000000000..6fc935d7584 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RYYGate.md @@ -0,0 +1,183 @@ +--- +title: RYYGate +description: API reference for qiskit.circuit.library.RYYGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RYYGate +--- + +# RYYGate + + + +`qiskit.circuit.library.RYYGate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/ryy.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +A parametric 2-qubit $Y \otimes Y$ interaction (rotation about YY). + +This gate is symmetric, and is maximally entangling at $\theta = \pi/2$. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`ryy()`](qiskit.circuit.QuantumCircuit#ryy "qiskit.circuit.QuantumCircuit.ryy") method. + +**Circuit Symbol:** + +```python + ┌─────────┐ +q_0: ┤1 ├ + │ Ryy(ϴ) │ +q_1: ┤0 ├ + └─────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R_{YY}(\theta) = \exp\left(-i \rotationangle Y{\otimes}Y\right) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & 0 & 0 & i\sin\left(\rotationangle\right) \\ + 0 & \cos\left(\rotationangle\right) & -i\sin\left(\rotationangle\right) & 0 \\ + 0 & -i\sin\left(\rotationangle\right) & \cos\left(\rotationangle\right) & 0 \\ + i\sin\left(\rotationangle\right) & 0 & 0 & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + +**Examples:** + +> $$ +> R_{YY}(\theta = 0) = I +> $$ +> +> $$ +> R_{YY}(\theta = \pi) = i Y \otimes Y +> $$ +> +> $$ +> R_{YY}\left(\theta = \frac{\pi}{2}\right) = \frac{1}{\sqrt{2}} +> \begin{pmatrix} +> 1 & 0 & 0 & i \\ +> 0 & 1 & -i & 0 \\ +> 0 & -i & 1 & 0 \\ +> i & 0 & 0 & 1 +> \end{pmatrix} +> $$ + +Create new RYY gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RYYGate.base_class "qiskit.circuit.library.RYYGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse RYY gate (i.e. with the negative rotation angle). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RZGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RZGate.md new file mode 100644 index 00000000000..715fbfb6b2f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RZGate.md @@ -0,0 +1,191 @@ +--- +title: RZGate +description: API reference for qiskit.circuit.library.RZGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RZGate +--- + +# RZGate + + + +`qiskit.circuit.library.RZGate(phi, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/rz.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Single-qubit rotation about the Z axis. + +This is a diagonal gate. It can be implemented virtually in hardware via framechanges (i.e. at zero error and duration). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rz()`](qiskit.circuit.QuantumCircuit#rz "qiskit.circuit.QuantumCircuit.rz") method. + +**Circuit symbol:** + +```python + ┌───────┐ +q_0: ┤ Rz(λ) ├ + └───────┘ +``` + +**Matrix Representation:** + +$$ +RZ(\lambda) = \exp\left(-i\frac{\lambda}{2}Z\right) = + \begin{pmatrix} + e^{-i\frac{\lambda}{2}} & 0 \\ + 0 & e^{i\frac{\lambda}{2}} + \end{pmatrix} +$$ + + + `U1Gate` This gate is equivalent to U1 up to a phase factor. + + > $$ + > U1(\lambda) = e^{i{\lambda}/2}RZ(\lambda) + > $$ + + Reference for virtual Z gate implementation: [1612.00858](https://arxiv.org/abs/1612.00858) + + +Create new RZ gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RZGate.base_class "qiskit.circuit.library.RZGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-RZ gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted RZ gate + +$RZ(\lambda)^{\dagger} = RZ(-\lambda)$ + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RZXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RZXGate.md new file mode 100644 index 00000000000..06caff0f53f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RZXGate.md @@ -0,0 +1,223 @@ +--- +title: RZXGate +description: API reference for qiskit.circuit.library.RZXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RZXGate +--- + +# RZXGate + + + +`qiskit.circuit.library.RZXGate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/rzx.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +A parametric 2-qubit $Z \otimes X$ interaction (rotation about ZX). + +This gate is maximally entangling at $\theta = \pi/2$. + +The cross-resonance gate (CR) for superconducting qubits implements a ZX interaction (however other terms are also present in an experiment). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rzx()`](qiskit.circuit.QuantumCircuit#rzx "qiskit.circuit.QuantumCircuit.rzx") method. + +**Circuit Symbol:** + +```python + ┌─────────┐ +q_0: ┤0 ├ + │ Rzx(θ) │ +q_1: ┤1 ├ + └─────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R_{ZX}(\theta)\ q_0, q_1 = \exp\left(-i \frac{\theta}{2} X{\otimes}Z\right) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & 0 & -i\sin\left(\rotationangle\right) & 0 \\ + 0 & \cos\left(\rotationangle\right) & 0 & i\sin\left(\rotationangle\right) \\ + -i\sin\left(\rotationangle\right) & 0 & \cos\left(\rotationangle\right) & 0 \\ + 0 & i\sin\left(\rotationangle\right) & 0 & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In the above example we apply the gate on (q\_0, q\_1) which results in the $X \otimes Z$ tensor order. Instead, if we apply it on (q\_1, q\_0), the matrix will be $Z \otimes X$: + + ```python + ┌─────────┐ + q_0: ┤1 ├ + │ Rzx(θ) │ + q_1: ┤0 ├ + └─────────┘ + ``` + + $$ + \newcommand{\rotationangle}{\frac{\theta}{2}} + + R_{ZX}(\theta)\ q_1, q_0 = exp(-i \frac{\theta}{2} Z{\otimes}X) = + \begin{pmatrix} + \cos(\rotationangle) & -i\sin(\rotationangle) & 0 & 0 \\ + -i\sin(\rotationangle) & \cos(\rotationangle) & 0 & 0 \\ + 0 & 0 & \cos(\rotationangle) & i\sin(\rotationangle) \\ + 0 & 0 & i\sin(\rotationangle) & \cos(\rotationangle) + \end{pmatrix} + $$ + + This is a direct sum of RX rotations, so this gate is equivalent to a uniformly controlled (multiplexed) RX gate: + + $$ + R_{ZX}(\theta)\ q_1, q_0 = + \begin{pmatrix} + RX(\theta) & 0 \\ + 0 & RX(-\theta) + \end{pmatrix} + $$ + + +**Examples:** + +> $$ +> R_{ZX}(\theta = 0) = I +> $$ +> +> $$ +> R_{ZX}(\theta = 2\pi) = -I +> $$ +> +> $$ +> R_{ZX}(\theta = \pi) = -i Z \otimes X +> $$ +> +> $$ +> RZX(\theta = \frac{\pi}{2}) = \frac{1}{\sqrt{2}} +> \begin{pmatrix} +> 1 & 0 & -i & 0 \\ +> 0 & 1 & 0 & i \\ +> -i & 0 & 1 & 0 \\ +> 0 & i & 0 & 1 +> \end{pmatrix} +> $$ + +Create new RZX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RZXGate.base_class "qiskit.circuit.library.RZXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse RZX gate (i.e. with the negative rotation angle). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RZZGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RZZGate.md new file mode 100644 index 00000000000..793ed5c02b1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RZZGate.md @@ -0,0 +1,195 @@ +--- +title: RZZGate +description: API reference for qiskit.circuit.library.RZZGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RZZGate +--- + +# RZZGate + + + +`qiskit.circuit.library.RZZGate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/rzz.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +A parametric 2-qubit $Z \otimes Z$ interaction (rotation about ZZ). + +This gate is symmetric, and is maximally entangling at $\theta = \pi/2$. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`rzz()`](qiskit.circuit.QuantumCircuit#rzz "qiskit.circuit.QuantumCircuit.rzz") method. + +**Circuit Symbol:** + +```python +q_0: ───■──── + │zz(θ) +q_1: ───■──── +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R_{ZZ}(\theta) = \exp\left(-i \rotationangle Z{\otimes}Z\right) = + \begin{pmatrix} + e^{-i \rotationangle} & 0 & 0 & 0 \\ + 0 & e^{i \rotationangle} & 0 & 0 \\ + 0 & 0 & e^{i \rotationangle} & 0 \\ + 0 & 0 & 0 & e^{-i \rotationangle} + \end{pmatrix} +$$ + +This is a direct sum of RZ rotations, so this gate is equivalent to a uniformly controlled (multiplexed) RZ gate: + +$$ +R_{ZZ}(\theta) = + \begin{pmatrix} + RZ(\theta) & 0 \\ + 0 & RZ(-\theta) + \end{pmatrix} +$$ + +**Examples:** + +> $$ +> R_{ZZ}(\theta = 0) = I +> $$ +> +> $$ +> R_{ZZ}(\theta = 2\pi) = -I +> $$ +> +> $$ +> R_{ZZ}(\theta = \pi) = - Z \otimes Z +> $$ +> +> $$ +> R_{ZZ}\left(\theta = \frac{\pi}{2}\right) = \frac{1}{\sqrt{2}} +> \begin{pmatrix} +> 1-i & 0 & 0 & 0 \\ +> 0 & 1+i & 0 & 0 \\ +> 0 & 0 & 1+i & 0 \\ +> 0 & 0 & 0 & 1-i +> \end{pmatrix} +> $$ + +Create new RZZ gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.RZZGate.base_class "qiskit.circuit.library.RZZGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse RZZ gate (i.e. with the negative rotation angle). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.RealAmplitudes.md b/docs/api/qiskit/0.46/qiskit.circuit.library.RealAmplitudes.md new file mode 100644 index 00000000000..d30a05b728c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.RealAmplitudes.md @@ -0,0 +1,389 @@ +--- +title: RealAmplitudes +description: API reference for qiskit.circuit.library.RealAmplitudes +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.RealAmplitudes +--- + +# RealAmplitudes + + + +`qiskit.circuit.library.RealAmplitudes(num_qubits=None, entanglement='reverse_linear', reps=3, skip_unentangled_qubits=False, skip_final_rotation_layer=False, parameter_prefix='θ', insert_barriers=False, initial_state=None, name='RealAmplitudes', flatten=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/n_local/real_amplitudes.py "view source code") + +Bases: [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.n_local.two_local.TwoLocal") + +The real-amplitudes 2-local circuit. + +The `RealAmplitudes` circuit is a heuristic trial wave function used as Ansatz in chemistry applications or classification circuits in machine learning. The circuit consists of alternating layers of $Y$ rotations and $CX$ entanglements. The entanglement pattern can be user-defined or selected from a predefined set. It is called `RealAmplitudes` since the prepared quantum states will only have real amplitudes, the complex part is always 0. + +For example a `RealAmplitudes` circuit with 2 repetitions on 3 qubits with `'reverse_linear'` entanglement is + +```python +┌──────────┐ ░ ░ ┌──────────┐ ░ ░ ┌──────────┐ +┤ Ry(θ[0]) ├─░────────■───░─┤ Ry(θ[3]) ├─░────────■───░─┤ Ry(θ[6]) ├ +├──────────┤ ░ ┌─┴─┐ ░ ├──────────┤ ░ ┌─┴─┐ ░ ├──────────┤ +┤ Ry(θ[1]) ├─░───■──┤ X ├─░─┤ Ry(θ[4]) ├─░───■──┤ X ├─░─┤ Ry(θ[7]) ├ +├──────────┤ ░ ┌─┴─┐└───┘ ░ ├──────────┤ ░ ┌─┴─┐└───┘ ░ ├──────────┤ +┤ Ry(θ[2]) ├─░─┤ X ├──────░─┤ Ry(θ[5]) ├─░─┤ X ├──────░─┤ Ry(θ[8]) ├ +└──────────┘ ░ └───┘ ░ └──────────┘ ░ └───┘ ░ └──────────┘ +``` + +The entanglement can be set using the `entanglement` keyword as string or a list of index-pairs. See the documentation of [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.TwoLocal") and `NLocal` for more detail. Additional options that can be set include the number of repetitions, skipping rotation gates on qubits that are not entangled, leaving out the final rotation layer and inserting barriers in between the rotation and entanglement layers. + +If some qubits are not entangled with other qubits it makes sense to not apply rotation gates on these qubits, since a sequence of $Y$ rotations can be reduced to a single $Y$ rotation with summed rotation angles. + +**Examples** + +```python +>>> ansatz = RealAmplitudes(3, reps=2) # create the circuit on 3 qubits +>>> print(ansatz) + ┌──────────┐ ┌──────────┐ ┌──────────┐ +q_0: ┤ Ry(θ[0]) ├──────────■──────┤ Ry(θ[3]) ├──────────■──────┤ Ry(θ[6]) ├ + ├──────────┤ ┌─┴─┐ ├──────────┤ ┌─┴─┐ ├──────────┤ +q_1: ┤ Ry(θ[1]) ├──■─────┤ X ├────┤ Ry(θ[4]) ├──■─────┤ X ├────┤ Ry(θ[7]) ├ + ├──────────┤┌─┴─┐┌──┴───┴───┐└──────────┘┌─┴─┐┌──┴───┴───┐└──────────┘ +q_2: ┤ Ry(θ[2]) ├┤ X ├┤ Ry(θ[5]) ├────────────┤ X ├┤ Ry(θ[8]) ├──────────── + └──────────┘└───┘└──────────┘ └───┘└──────────┘ +``` + +```python +>>> ansatz = RealAmplitudes(3, entanglement='full', reps=2) # it is the same unitary as above +>>> print(ansatz) + ┌──────────┐ ┌──────────┐ ┌──────────┐ +q_0: ┤ RY(θ[0]) ├──■────■──┤ RY(θ[3]) ├──────────────■────■──┤ RY(θ[6]) ├──────────── + ├──────────┤┌─┴─┐ │ └──────────┘┌──────────┐┌─┴─┐ │ └──────────┘┌──────────┐ +q_1: ┤ RY(θ[1]) ├┤ X ├──┼───────■──────┤ RY(θ[4]) ├┤ X ├──┼───────■──────┤ RY(θ[7]) ├ + ├──────────┤└───┘┌─┴─┐ ┌─┴─┐ ├──────────┤└───┘┌─┴─┐ ┌─┴─┐ ├──────────┤ +q_2: ┤ RY(θ[2]) ├─────┤ X ├───┤ X ├────┤ RY(θ[5]) ├─────┤ X ├───┤ X ├────┤ RY(θ[8]) ├ + └──────────┘ └───┘ └───┘ └──────────┘ └───┘ └───┘ └──────────┘ +``` + +```python +>>> ansatz = RealAmplitudes(3, entanglement='linear', reps=2, insert_barriers=True) +>>> qc = QuantumCircuit(3) # create a circuit and append the RY variational form +>>> qc.compose(ansatz, inplace=True) +>>> qc.draw() + ┌──────────┐ ░ ░ ┌──────────┐ ░ ░ ┌──────────┐ +q_0: ┤ RY(θ[0]) ├─░───■────────░─┤ RY(θ[3]) ├─░───■────────░─┤ RY(θ[6]) ├ + ├──────────┤ ░ ┌─┴─┐ ░ ├──────────┤ ░ ┌─┴─┐ ░ ├──────────┤ +q_1: ┤ RY(θ[1]) ├─░─┤ X ├──■───░─┤ RY(θ[4]) ├─░─┤ X ├──■───░─┤ RY(θ[7]) ├ + ├──────────┤ ░ └───┘┌─┴─┐ ░ ├──────────┤ ░ └───┘┌─┴─┐ ░ ├──────────┤ +q_2: ┤ RY(θ[2]) ├─░──────┤ X ├─░─┤ RY(θ[5]) ├─░──────┤ X ├─░─┤ RY(θ[8]) ├ + └──────────┘ ░ └───┘ ░ └──────────┘ ░ └───┘ ░ └──────────┘ +``` + +```python +>>> ansatz = RealAmplitudes(4, reps=1, entanglement='circular', insert_barriers=True) +>>> print(ansatz) + ┌──────────┐ ░ ┌───┐ ░ ┌──────────┐ +q_0: ┤ RY(θ[0]) ├─░─┤ X ├──■─────────────░─┤ RY(θ[4]) ├ + ├──────────┤ ░ └─┬─┘┌─┴─┐ ░ ├──────────┤ +q_1: ┤ RY(θ[1]) ├─░───┼──┤ X ├──■────────░─┤ RY(θ[5]) ├ + ├──────────┤ ░ │ └───┘┌─┴─┐ ░ ├──────────┤ +q_2: ┤ RY(θ[2]) ├─░───┼───────┤ X ├──■───░─┤ RY(θ[6]) ├ + ├──────────┤ ░ │ └───┘┌─┴─┐ ░ ├──────────┤ +q_3: ┤ RY(θ[3]) ├─░───■────────────┤ X ├─░─┤ RY(θ[7]) ├ + └──────────┘ ░ └───┘ ░ └──────────┘ +``` + +```python +>>> ansatz = RealAmplitudes(4, reps=2, entanglement=[[0,3], [0,2]], +... skip_unentangled_qubits=True) +>>> print(ansatz) + ┌──────────┐ ┌──────────┐ ┌──────────┐ +q_0: ┤ RY(θ[0]) ├──■───────■──────┤ RY(θ[3]) ├──■───────■──────┤ RY(θ[6]) ├ + └──────────┘ │ │ └──────────┘ │ │ └──────────┘ +q_1: ──────────────┼───────┼────────────────────┼───────┼────────────────── + ┌──────────┐ │ ┌─┴─┐ ┌──────────┐ │ ┌─┴─┐ ┌──────────┐ +q_2: ┤ RY(θ[1]) ├──┼─────┤ X ├────┤ RY(θ[4]) ├──┼─────┤ X ├────┤ RY(θ[7]) ├ + ├──────────┤┌─┴─┐┌──┴───┴───┐└──────────┘┌─┴─┐┌──┴───┴───┐└──────────┘ +q_3: ┤ RY(θ[2]) ├┤ X ├┤ RY(θ[5]) ├────────────┤ X ├┤ RY(θ[8]) ├──────────── + └──────────┘└───┘└──────────┘ └───┘└──────────┘ +``` + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits of the RealAmplitudes circuit. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Specifies how often the structure of a rotation layer followed by an entanglement layer is repeated. +* **entanglement** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Specifies the entanglement structure. Can be a string (‘full’, ‘linear’ ‘reverse\_linear, ‘circular’ or ‘sca’), a list of integer-pairs specifying the indices of qubits entangled with one another, or a callable returning such a list provided with the index of the entanglement layer. Default to ‘reverse\_linear’ entanglement. Note that ‘reverse\_linear’ entanglement provides the same unitary as ‘full’ with fewer entangling gates. See the Examples section of [`TwoLocal`](qiskit.circuit.library.TwoLocal "qiskit.circuit.library.TwoLocal") for more detail. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A QuantumCircuit object to prepend to the circuit. +* **skip\_unentangled\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, the single qubit gates are only applied to qubits that are entangled with another qubit. If False, the single qubit gates are applied to each qubit in the Ansatz. Defaults to False. +* **skip\_final\_rotation\_layer** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If False, a rotation layer is added at the end of the ansatz. If True, no rotation layer is added. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The parameterized gates require a parameter to be defined, for which we use [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector"). +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, barriers are inserted in between each layer. If False, no barriers are inserted. +* **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Set this to `True` to output a flat circuit instead of nesting it inside multiple layers of gate objects. By default currently the contents of the output circuit will be wrapped in nested objects for cleaner visualization. However, if you’re using this circuit for anything besides visualization its **strongly** recommended to set this flag to `True` to avoid a large performance overhead for parameter binding. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of total parameters that can be set to distinct values. + +This does not change when the parameters are bound or exchanged for same parameters, and therefore is different from `num_parameters` which counts the number of unique [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects currently in the circuit. + +**Returns** + +The number of parameters originally available in the circuit. + + + This quantity does not require the circuit to be built yet. + + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +Return the parameter bounds. + +**Returns** + +The parameter bounds. + + + +### parameters + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.Reset.md b/docs/api/qiskit/0.46/qiskit.circuit.library.Reset.md new file mode 100644 index 00000000000..e4a701a60dd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.Reset.md @@ -0,0 +1,316 @@ +--- +title: Reset +description: API reference for qiskit.circuit.library.Reset +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.Reset +--- + +# Reset + + + +`qiskit.circuit.library.Reset(label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/reset.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Qubit reset. + +Create new reset instruction. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.Reset.base_class "qiskit.circuit.library.Reset.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Invert this instruction. + +If the instruction is composite (i.e. has a definition), then its definition will be recursively inverted. + +Special instructions inheriting from Instruction can implement their own inverse (e.g. T and Tdg, Barrier, etc.) + +**Returns** + +a fresh instruction for the inverse + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the instruction is not composite and an inverse has not been implemented for it. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.SGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.SGate.md new file mode 100644 index 00000000000..e728a415e31 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.SGate.md @@ -0,0 +1,160 @@ +--- +title: SGate +description: API reference for qiskit.circuit.library.SGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.SGate +--- + +# SGate + + + +`qiskit.circuit.library.SGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/s.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +Single qubit S gate (Z\*\*0.5). + +It induces a $\pi/2$ phase, and is sometimes called the P gate (phase). + +This is a Clifford gate and a square-root of Pauli-Z. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`s()`](qiskit.circuit.QuantumCircuit#s "qiskit.circuit.QuantumCircuit.s") method. + +**Matrix Representation:** + +$$ +S = \begin{pmatrix} + 1 & 0 \\ + 0 & i + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌───┐ +q_0: ┤ S ├ + └───┘ +``` + +Equivalent to a $\pi/2$ radian rotation about the Z axis. + +Create new S gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.SGate.base_class "qiskit.circuit.library.SGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse of S (SdgGate). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.SXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.SXGate.md new file mode 100644 index 00000000000..9dbd8e82f2e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.SXGate.md @@ -0,0 +1,182 @@ +--- +title: SXGate +description: API reference for qiskit.circuit.library.SXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.SXGate +--- + +# SXGate + + + +`qiskit.circuit.library.SXGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/sx.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The single-qubit Sqrt(X) gate ($\sqrt{X}$). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`sx()`](qiskit.circuit.QuantumCircuit#sx "qiskit.circuit.QuantumCircuit.sx") method. + +**Matrix Representation:** + +$$ +\sqrt{X} = \frac{1}{2} \begin{pmatrix} + 1 + i & 1 - i \\ + 1 - i & 1 + i + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌────┐ +q_0: ┤ √X ├ + └────┘ +``` + + + A global phase difference exists between the definitions of $RX(\pi/2)$ and $\sqrt{X}$. + + $$ + RX(\pi/2) = \frac{1}{\sqrt{2}} \begin{pmatrix} + 1 & -i \\ + -i & 1 + \end{pmatrix} + = e^{-i \pi/4} \sqrt{X} + $$ + + +Create new SX gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.SXGate.base_class "qiskit.circuit.library.SXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-SX gate. + +One control returns a CSX gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[SingletonControlledGate](circuit_singleton#qiskit.circuit.singleton.SingletonControlledGate "qiskit.circuit.singleton.SingletonControlledGate") + +### inverse + + + +`inverse()` + +Return inverse SX gate (i.e. SXdg). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.SXdgGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.SXdgGate.md new file mode 100644 index 00000000000..849043ed5d1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.SXdgGate.md @@ -0,0 +1,148 @@ +--- +title: SXdgGate +description: API reference for qiskit.circuit.library.SXdgGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.SXdgGate +--- + +# SXdgGate + + + +`qiskit.circuit.library.SXdgGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/sx.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The inverse single-qubit Sqrt(X) gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`sxdg()`](qiskit.circuit.QuantumCircuit#sxdg "qiskit.circuit.QuantumCircuit.sxdg") method. + +$$ +\sqrt{X}^{\dagger} = \frac{1}{2} \begin{pmatrix} + 1 - i & 1 + i \\ + 1 + i & 1 - i + \end{pmatrix} +$$ + + + A global phase difference exists between the definitions of $RX(-\pi/2)$ and $\sqrt{X}^{\dagger}$. + + $$ + RX(-\pi/2) = \frac{1}{\sqrt{2}} \begin{pmatrix} + 1 & i \\ + i & 1 + \end{pmatrix} + = e^{-i \pi/4} \sqrt{X}^{\dagger} + $$ + + +Create new SXdg gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.SXdgGate.base_class "qiskit.circuit.library.SXdgGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse SXdg gate (i.e. SX). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.SdgGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.SdgGate.md new file mode 100644 index 00000000000..1607bf2903c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.SdgGate.md @@ -0,0 +1,160 @@ +--- +title: SdgGate +description: API reference for qiskit.circuit.library.SdgGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.SdgGate +--- + +# SdgGate + + + +`qiskit.circuit.library.SdgGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/s.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +Single qubit S-adjoint gate (\~Z\*\*0.5). + +It induces a $-\pi/2$ phase. + +This is a Clifford gate and a square-root of Pauli-Z. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`sdg()`](qiskit.circuit.QuantumCircuit#sdg "qiskit.circuit.QuantumCircuit.sdg") method. + +**Matrix Representation:** + +$$ +Sdg = \begin{pmatrix} + 1 & 0 \\ + 0 & -i + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌─────┐ +q_0: ┤ Sdg ├ + └─────┘ +``` + +Equivalent to a $-\pi/2$ radian rotation about the Z axis. + +Create new Sdg gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.SdgGate.base_class "qiskit.circuit.library.SdgGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse of Sdg (SGate). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.StatePreparation.md b/docs/api/qiskit/0.46/qiskit.circuit.library.StatePreparation.md new file mode 100644 index 00000000000..f5454e0cd7e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.StatePreparation.md @@ -0,0 +1,211 @@ +--- +title: StatePreparation +description: API reference for qiskit.circuit.library.StatePreparation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.StatePreparation +--- + +# StatePreparation + + + +`qiskit.circuit.library.StatePreparation(params, num_qubits=None, inverse=False, label=None, normalize=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/data_preparation/state_preparation.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Complex amplitude state preparation. + +Class that implements the (complex amplitude) state preparation of some flexible collection of qubit registers. + +**Parameters** + +* **params** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector")) – + + * Statevector: Statevector to initialize to. + * list: vector of complex amplitudes to initialize to. + * string: labels of basis states of the Pauli eigenstates Z, X, Y. See [`Statevector.from_label()`](qiskit.quantum_info.Statevector#from_label "qiskit.quantum_info.Statevector.from_label"). Notice the order of the labels is reversed with respect to the qubit index to be applied to. Example label ‘01’ initializes the qubit zero to $|1\rangle$ and the qubit one to $|0\rangle$. + * int: an integer that is used as a bitmap indicating which qubits to initialize to $|1\rangle$. Example: setting params to 5 would initialize qubit 0 and qubit 2 to $|1\rangle$ and qubit 1 to $|0\rangle$. + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – This parameter is only used if params is an int. Indicates the total number of qubits in the initialize call. Example: initialize covers 5 qubits and params is 3. This allows qubits 0 and 1 to be initialized to $|1\rangle$ and the remaining 3 qubits to be initialized to $|0\rangle$. + +* **inverse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, the inverse state is constructed. + +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – An optional label for the gate + +* **normalize** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to normalize an input array to a unit vector. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – `num_qubits` parameter used when `params` is not an integer + +When a Statevector argument is passed the state is prepared using a recursive initialization algorithm, including optimizations, from \[1], as well as some additional optimizations including removing zero rotations and double cnots. + +**References:** \[1] Shende, Bullock, Markov. Synthesis of Quantum Logic Circuits (2004) \[[https://arxiv.org/abs/quant-ph/0406176v5](https://arxiv.org/abs/quant-ph/0406176v5)] + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.StatePreparation.base_class "qiskit.circuit.library.StatePreparation.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation and handling of the arguments and its relationship. + +For example, `cx([q[0],q[1]], q[2])` means `cx(q[0], q[2]); cx(q[1], q[2])`. This method yields the arguments in the right grouping. In the given example: + +```python +in: [[q[0],q[1]], q[2]],[] +outs: [q[0], q[2]], [] + [q[1], q[2]], [] +``` + +The general broadcasting rules are: + +> * If len(qargs) == 1: +> +> ```python +> [q[0], q[1]] -> [q[0]],[q[1]] +> ``` +> +> * If len(qargs) == 2: +> +> ```python +> [[q[0], q[1]], [r[0], r[1]]] -> [q[0], r[0]], [q[1], r[1]] +> [[q[0]], [r[0], r[1]]] -> [q[0], r[0]], [q[0], r[1]] +> [[q[0], q[1]], [r[0]]] -> [q[0], r[0]], [q[1], r[0]] +> ``` +> +> * If len(qargs) >= 3: +> +> ```python +> [q[0], q[1]], [r[0], r[1]], ...] -> [q[0], r[0], ...], [q[1], r[1], ...] +> ``` + +**Parameters** + +* **qargs** – List of quantum bit arguments. +* **cargs** – List of classical bit arguments. + +**Returns** + +A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### inverse + + + +`inverse()` + +Return inverted StatePreparation + +### validate\_parameter + + + +`validate_parameter(parameter)` + +StatePreparation instruction parameter can be str, int, float, and complex. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.SwapGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.SwapGate.md new file mode 100644 index 00000000000..79b2c2e8936 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.SwapGate.md @@ -0,0 +1,181 @@ +--- +title: SwapGate +description: API reference for qiskit.circuit.library.SwapGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.SwapGate +--- + +# SwapGate + + + +`qiskit.circuit.library.SwapGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/swap.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The SWAP gate. + +This is a symmetric and Clifford gate. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`swap()`](qiskit.circuit.QuantumCircuit#swap "qiskit.circuit.QuantumCircuit.swap") method. + +**Circuit symbol:** + +```python +q_0: ─X─ + │ +q_1: ─X─ +``` + +**Matrix Representation:** + +$$ +SWAP = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 0 & 1 + \end{pmatrix} +$$ + +The gate is equivalent to a state swap and is a classical logic gate. + +$$ +|a, b\rangle \rightarrow |b, a\rangle +$$ + +Create new SWAP gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.SwapGate.base_class "qiskit.circuit.library.SwapGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-SWAP gate. + +One control returns a CSWAP (Fredkin) gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverse Swap gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.TGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.TGate.md new file mode 100644 index 00000000000..09bf8711113 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.TGate.md @@ -0,0 +1,160 @@ +--- +title: TGate +description: API reference for qiskit.circuit.library.TGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.TGate +--- + +# TGate + + + +`qiskit.circuit.library.TGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/t.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +Single qubit T gate (Z\*\*0.25). + +It induces a $\pi/4$ phase, and is sometimes called the pi/8 gate (because of how the RZ(pi/4) matrix looks like). + +This is a non-Clifford gate and a fourth-root of Pauli-Z. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`t()`](qiskit.circuit.QuantumCircuit#t "qiskit.circuit.QuantumCircuit.t") method. + +**Matrix Representation:** + +$$ +T = \begin{pmatrix} + 1 & 0 \\ + 0 & e^{i\pi/4} + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌───┐ +q_0: ┤ T ├ + └───┘ +``` + +Equivalent to a $\pi/4$ radian rotation about the Z axis. + +Create new T gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.TGate.base_class "qiskit.circuit.library.TGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse T gate (i.e. Tdg). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.TdgGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.TdgGate.md new file mode 100644 index 00000000000..952b408560e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.TdgGate.md @@ -0,0 +1,160 @@ +--- +title: TdgGate +description: API reference for qiskit.circuit.library.TdgGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.TdgGate +--- + +# TdgGate + + + +`qiskit.circuit.library.TdgGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/t.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +Single qubit T-adjoint gate (\~Z\*\*0.25). + +It induces a $-\pi/4$ phase. + +This is a non-Clifford gate and a fourth-root of Pauli-Z. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`tdg()`](qiskit.circuit.QuantumCircuit#tdg "qiskit.circuit.QuantumCircuit.tdg") method. + +**Matrix Representation:** + +$$ +Tdg = \begin{pmatrix} + 1 & 0 \\ + 0 & e^{-i\pi/4} + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌─────┐ +q_0: ┤ Tdg ├ + └─────┘ +``` + +Equivalent to a $-\pi/4$ radian rotation about the Z axis. + +Create new Tdg gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.TdgGate.base_class "qiskit.circuit.library.TdgGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse Tdg gate (i.e. T). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.TwoLocal.md b/docs/api/qiskit/0.46/qiskit.circuit.library.TwoLocal.md new file mode 100644 index 00000000000..9b04820924e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.TwoLocal.md @@ -0,0 +1,415 @@ +--- +title: TwoLocal +description: API reference for qiskit.circuit.library.TwoLocal +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.TwoLocal +--- + +# TwoLocal + + + +`qiskit.circuit.library.TwoLocal(num_qubits=None, rotation_blocks=None, entanglement_blocks=None, entanglement='full', reps=3, skip_unentangled_qubits=False, skip_final_rotation_layer=False, parameter_prefix='θ', insert_barriers=False, initial_state=None, name='TwoLocal', flatten=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/n_local/two_local.py "view source code") + +Bases: [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.n_local.n_local.NLocal") + +The two-local circuit. + +The two-local circuit is a parameterized circuit consisting of alternating rotation layers and entanglement layers. The rotation layers are single qubit gates applied on all qubits. The entanglement layer uses two-qubit gates to entangle the qubits according to a strategy set using `entanglement`. Both the rotation and entanglement gates can be specified as string (e.g. `'ry'` or `'cx'`), as gate-type (e.g. `RYGate` or `CXGate`) or as QuantumCircuit (e.g. a 1-qubit circuit or 2-qubit circuit). + +A set of default entanglement strategies is provided: + +* `'full'` entanglement is each qubit is entangled with all the others. +* `'linear'` entanglement is qubit $i$ entangled with qubit $i + 1$, for all $i \in \{0, 1, ... , n - 2\}$, where $n$ is the total number of qubits. +* `'reverse_linear'` entanglement is qubit $i$ entangled with qubit $i + 1$, for all $i \in \{n-2, n-3, ... , 1, 0\}$, where $n$ is the total number of qubits. Note that if `entanglement_blocks = 'cx'` then this option provides the same unitary as `'full'` with fewer entangling gates. +* `'pairwise'` entanglement is one layer where qubit $i$ is entangled with qubit $i + 1$, for all even values of $i$, and then a second layer where qubit $i$ is entangled with qubit $i + 1$, for all odd values of $i$. +* `'circular'` entanglement is linear entanglement but with an additional entanglement of the first and last qubit before the linear part. +* `'sca'` (shifted-circular-alternating) entanglement is a generalized and modified version of the proposed circuit 14 in [Sim et al.](https://arxiv.org/abs/1905.10876). It consists of circular entanglement where the ‘long’ entanglement connecting the first with the last qubit is shifted by one each block. Furthermore the role of control and target qubits are swapped every block (therefore alternating). + +The entanglement can further be specified using an entangler map, which is a list of index pairs, such as + +```python +>>> entangler_map = [(0, 1), (1, 2), (2, 0)] +``` + +If different entanglements per block should be used, provide a list of entangler maps. See the examples below on how this can be used. + +```python +>>> entanglement = [entangler_map_layer_1, entangler_map_layer_2, ... ] +``` + +Barriers can be inserted in between the different layers for better visualization using the `insert_barriers` attribute. + +For each parameterized gate a new parameter is generated using a `ParameterVector`. The name of these parameters can be chosen using the `parameter_prefix`. + +**Examples** + +```python +>>> two = TwoLocal(3, 'ry', 'cx', 'linear', reps=2, insert_barriers=True) +>>> print(two) # decompose the layers into standard gates + ┌──────────┐ ░ ░ ┌──────────┐ ░ ░ ┌──────────┐ +q_0: ┤ Ry(θ[0]) ├─░───■────────░─┤ Ry(θ[3]) ├─░───■────────░─┤ Ry(θ[6]) ├ + ├──────────┤ ░ ┌─┴─┐ ░ ├──────────┤ ░ ┌─┴─┐ ░ ├──────────┤ +q_1: ┤ Ry(θ[1]) ├─░─┤ X ├──■───░─┤ Ry(θ[4]) ├─░─┤ X ├──■───░─┤ Ry(θ[7]) ├ + ├──────────┤ ░ └───┘┌─┴─┐ ░ ├──────────┤ ░ └───┘┌─┴─┐ ░ ├──────────┤ +q_2: ┤ Ry(θ[2]) ├─░──────┤ X ├─░─┤ Ry(θ[5]) ├─░──────┤ X ├─░─┤ Ry(θ[8]) ├ + └──────────┘ ░ └───┘ ░ └──────────┘ ░ └───┘ ░ └──────────┘ +``` + +```python +>>> two = TwoLocal(3, ['ry','rz'], 'cz', 'full', reps=1, insert_barriers=True) +>>> qc = QuantumCircuit(3) +>>> qc += two +>>> print(qc.decompose().draw()) + ┌──────────┐┌──────────┐ ░ ░ ┌──────────┐ ┌──────────┐ +q_0: ┤ Ry(θ[0]) ├┤ Rz(θ[3]) ├─░──■──■─────░─┤ Ry(θ[6]) ├─┤ Rz(θ[9]) ├ + ├──────────┤├──────────┤ ░ │ │ ░ ├──────────┤┌┴──────────┤ +q_1: ┤ Ry(θ[1]) ├┤ Rz(θ[4]) ├─░──■──┼──■──░─┤ Ry(θ[7]) ├┤ Rz(θ[10]) ├ + ├──────────┤├──────────┤ ░ │ │ ░ ├──────────┤├───────────┤ +q_2: ┤ Ry(θ[2]) ├┤ Rz(θ[5]) ├─░─────■──■──░─┤ Ry(θ[8]) ├┤ Rz(θ[11]) ├ + └──────────┘└──────────┘ ░ ░ └──────────┘└───────────┘ +``` + +```python +>>> entangler_map = [[0, 1], [1, 2], [2, 0]] # circular entanglement for 3 qubits +>>> two = TwoLocal(3, 'x', 'crx', entangler_map, reps=1) +>>> print(two) # note: no barriers inserted this time! + ┌───┐ ┌──────────┐┌───┐ +q_0: |0>┤ X ├─────■───────────────────────┤ Rx(θ[2]) ├┤ X ├ + ├───┤┌────┴─────┐ ┌───┐└─────┬────┘└───┘ +q_1: |0>┤ X ├┤ Rx(θ[0]) ├─────■──────┤ X ├──────┼────────── + ├───┤└──────────┘┌────┴─────┐└───┘ │ ┌───┐ +q_2: |0>┤ X ├────────────┤ Rx(θ[1]) ├───────────■─────┤ X ├ + └───┘ └──────────┘ └───┘ +``` + +```python +>>> entangler_map = [[0, 3], [0, 2]] # entangle the first and last two-way +>>> two = TwoLocal(4, [], 'cry', entangler_map, reps=1) +>>> circuit = two + two +>>> print(circuit.decompose().draw()) # note, that the parameters are the same! +q_0: ─────■───────────■───────────■───────────■────── + │ │ │ │ +q_1: ─────┼───────────┼───────────┼───────────┼────── + │ ┌────┴─────┐ │ ┌────┴─────┐ +q_2: ─────┼──────┤ Ry(θ[1]) ├─────┼──────┤ Ry(θ[1]) ├ + ┌────┴─────┐└──────────┘┌────┴─────┐└──────────┘ +q_3: ┤ Ry(θ[0]) ├────────────┤ Ry(θ[0]) ├──────────── + └──────────┘ └──────────┘ +``` + +```python +>>> layer_1 = [(0, 1), (0, 2)] +>>> layer_2 = [(1, 2)] +>>> two = TwoLocal(3, 'x', 'cx', [layer_1, layer_2], reps=2, insert_barriers=True) +>>> print(two) + ┌───┐ ░ ░ ┌───┐ ░ ░ ┌───┐ +q_0: ┤ X ├─░───■────■───░─┤ X ├─░───────░─┤ X ├ + ├───┤ ░ ┌─┴─┐ │ ░ ├───┤ ░ ░ ├───┤ +q_1: ┤ X ├─░─┤ X ├──┼───░─┤ X ├─░───■───░─┤ X ├ + ├───┤ ░ └───┘┌─┴─┐ ░ ├───┤ ░ ┌─┴─┐ ░ ├───┤ +q_2: ┤ X ├─░──────┤ X ├─░─┤ X ├─░─┤ X ├─░─┤ X ├ + └───┘ ░ └───┘ ░ └───┘ ░ └───┘ ░ └───┘ +``` + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits of the two-local circuit. +* **rotation\_blocks** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – The gates used in the rotation layer. Can be specified via the name of a gate (e.g. `'ry'`) or the gate type itself (e.g. [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate")). If only one gate is provided, the gate same gate is applied to each qubit. If a list of gates is provided, all gates are applied to each qubit in the provided order. See the Examples section for more detail. +* **entanglement\_blocks** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – The gates used in the entanglement layer. Can be specified in the same format as `rotation_blocks`. +* **entanglement** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | Callable\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Specifies the entanglement structure. Can be a string (`'full'`, `'linear'`, `'reverse_linear'`, `'circular'` or `'sca'`), a list of integer-pairs specifying the indices of qubits entangled with one another, or a callable returning such a list provided with the index of the entanglement layer. Default to `'full'` entanglement. Note that if `entanglement_blocks = 'cx'`, then `'full'` entanglement provides the same unitary as `'reverse_linear'` but the latter option has fewer entangling gates. See the Examples section for more detail. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Specifies how often a block consisting of a rotation layer and entanglement layer is repeated. +* **skip\_unentangled\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, the single qubit gates are only applied to qubits that are entangled with another qubit. If `False`, the single qubit gates are applied to each qubit in the ansatz. Defaults to `False`. +* **skip\_final\_rotation\_layer** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False`, a rotation layer is added at the end of the ansatz. If `True`, no rotation layer is added. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The parameterized gates require a parameter to be defined, for which we use instances of [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter"). The name of each parameter will be this specified prefix plus its index. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, barriers are inserted in between each layer. If `False`, no barriers are inserted. Defaults to `False`. +* **initial\_state** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| None*) – A [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object to prepend to the circuit. +* **flatten** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Set this to `True` to output a flat circuit instead of nesting it inside multiple layers of gate objects. By default currently the contents of the output circuit will be wrapped in nested objects for cleaner visualization. However, if you’re using this circuit for anything besides visualization its **strongly** recommended to set this flag to `True` to avoid a large performance overhead for parameter binding. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see [`get_entangler_map()`](#qiskit.circuit.library.TwoLocal.get_entangler_map "qiskit.circuit.library.TwoLocal.get_entangler_map") for more detail on how the format is interpreted. + + + +### entanglement\_blocks + +The blocks in the entanglement layers. + +**Returns** + +The blocks in the entanglement layers. + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of total parameters that can be set to distinct values. + +This does not change when the parameters are bound or exchanged for same parameters, and therefore is different from `num_parameters` which counts the number of unique [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects currently in the circuit. + +**Returns** + +The number of parameters originally available in the circuit. + + + This quantity does not require the circuit to be built yet. + + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If `None` is returned, problem is fully unbounded. + + + +### parameters + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + +## Methods + +### get\_entangler\_map + + + +`get_entangler_map(rep_num, block_num, num_block_qubits)` + +Overloading to handle the special case of 1 qubit where the entanglement are ignored. + +**Return type** + +[*Sequence*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Sequence "(in Python v3.12)")\[[*Sequence*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Sequence "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")]] + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.U1Gate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.U1Gate.md new file mode 100644 index 00000000000..5d7b438b452 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.U1Gate.md @@ -0,0 +1,208 @@ +--- +title: U1Gate +description: API reference for qiskit.circuit.library.U1Gate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.U1Gate +--- + +# U1Gate + + + +`qiskit.circuit.library.U1Gate(theta, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/u1.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Single-qubit rotation about the Z axis. + +This is a diagonal gate. It can be implemented virtually in hardware via framechanges (i.e. at zero error and duration). + + + This gate is deprecated. Instead, the following replacements should be used + + $$ + U1(\lambda) = P(\lambda)= U(0,0,\lambda) + $$ + + ```python + circuit = QuantumCircuit(1) + circuit.p(lambda, 0) # or circuit.u(0, 0, lambda) + ``` + + +**Circuit symbol:** + +```python + ┌───────┐ +q_0: ┤ U1(λ) ├ + └───────┘ +``` + +**Matrix Representation:** + +$$ +U1(\lambda) = + \begin{pmatrix} + 1 & 0 \\ + 0 & e^{i\lambda} + \end{pmatrix} +$$ + +**Examples:** + +> $$ +> U1(\lambda = \pi) = Z +> $$ +> +> $$ +> U1(\lambda = \pi/2) = S +> $$ +> +> $$ +> U1(\lambda = \pi/4) = T +> $$ + + + `RZGate`: This gate is equivalent to RZ up to a phase factor. + + > $$ + > U1(\lambda) = e^{i{\lambda}/2} RZ(\lambda) + > $$ + + `U3Gate`: U3 is a generalization of U2 that covers all single-qubit rotations, using two X90 pulses. + + Reference for virtual Z gate implementation: [1612.00858](https://arxiv.org/abs/1612.00858) + + +Create new U1 gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.U1Gate.base_class "qiskit.circuit.library.U1Gate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-U1 gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted U1 gate ($U1(\lambda)^{\dagger} = U1(-\lambda)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.U2Gate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.U2Gate.md new file mode 100644 index 00000000000..c0cd19dcdfc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.U2Gate.md @@ -0,0 +1,187 @@ +--- +title: U2Gate +description: API reference for qiskit.circuit.library.U2Gate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.U2Gate +--- + +# U2Gate + + + +`qiskit.circuit.library.U2Gate(phi, lam, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/u2.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Single-qubit rotation about the X+Z axis. + +Implemented using one X90 pulse on IBM Quantum systems: + + + This gate is deprecated. Instead, the following replacements should be used + + $$ + U2(\phi, \lambda) = U\left(\frac{\pi}{2}, \phi, \lambda\right) + $$ + + ```python + circuit = QuantumCircuit(1) + circuit.u(pi/2, phi, lambda) + ``` + + +**Circuit symbol:** + +```python + ┌─────────┐ +q_0: ┤ U2(φ,λ) ├ + └─────────┘ +``` + +**Matrix Representation:** + +$$ +U2(\phi, \lambda) = \frac{1}{\sqrt{2}} + \begin{pmatrix} + 1 & -e^{i\lambda} \\ + e^{i\phi} & e^{i(\phi+\lambda)} + \end{pmatrix} +$$ + +**Examples:** + +$$ +U2(\phi,\lambda) = e^{i \frac{\phi + \lambda}{2}}RZ(\phi) +RY\left(\frac{\pi}{2}\right) RZ(\lambda) += e^{- i\frac{\pi}{4}} P\left(\frac{\pi}{2} + \phi\right) +\sqrt{X} P\left(\lambda- \frac{\pi}{2}\right) +$$ + +$$ +U2(0, \pi) = H +$$ + +$$ +U2(0, 0) = RY(\pi/2) +$$ + +$$ +U2(-\pi/2, \pi/2) = RX(\pi/2) +$$ + + + `U3Gate`: U3 is a generalization of U2 that covers all single-qubit rotations, using two X90 pulses. + + +Create new U2 gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.U2Gate.base_class "qiskit.circuit.library.U2Gate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverted U2 gate. + +$U2(\phi, \lambda)^{\dagger} =U2(-\lambda-\pi, -\phi+\pi)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.U3Gate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.U3Gate.md new file mode 100644 index 00000000000..e9f4b5fa741 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.U3Gate.md @@ -0,0 +1,204 @@ +--- +title: U3Gate +description: API reference for qiskit.circuit.library.U3Gate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.U3Gate +--- + +# U3Gate + + + +`qiskit.circuit.library.U3Gate(theta, phi, lam, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/u3.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Generic single-qubit rotation gate with 3 Euler angles. + + + This gate is deprecated. Instead, the following replacements should be used + + $$ + U3(\theta, \phi, \lambda) = U(\theta, \phi, \lambda) + $$ + + ```python + circuit = QuantumCircuit(1) + circuit.u(theta, phi, lambda) + ``` + + +**Circuit symbol:** + +```python + ┌───────────┐ +q_0: ┤ U3(ϴ,φ,λ) ├ + └───────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +U3(\theta, \phi, \lambda) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & -e^{i\lambda}\sin\left(\rotationangle\right) \\ + e^{i\phi}\sin\left(\rotationangle\right) & + e^{i(\phi+\lambda)}\cos\left(\rotationangle\right) + \end{pmatrix} +$$ + + + The matrix representation shown here differs from the [OpenQASM 2.0 specification](https://doi.org/10.48550/arXiv.1707.03429) by a global phase of $e^{i(\phi+\lambda)/2}$. + + +**Examples:** + +$$ +U3(\theta, \phi, \lambda) = e^{-i \frac{\pi + \theta}{2}} P(\phi + \pi) \sqrt{X} +P(\theta + \pi) \sqrt{X} P(\lambda) +$$ + +$$ +U3\left(\theta, -\frac{\pi}{2}, \frac{\pi}{2}\right) = RX(\theta) +$$ + +$$ +U3(\theta, 0, 0) = RY(\theta) +$$ + +Create new U3 gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.U3Gate.base_class "qiskit.circuit.library.U3Gate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-U3 gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted U3 gate. + +$U3(\theta,\phi,\lambda)^{\dagger} =U3(-\theta,-\lambda,-\phi)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UCGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UCGate.md new file mode 100644 index 00000000000..7170576bad6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UCGate.md @@ -0,0 +1,169 @@ +--- +title: UCGate +description: API reference for qiskit.circuit.library.UCGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UCGate +--- + +# UCGate + + + +`qiskit.circuit.library.UCGate(gate_list, up_to_diagonal=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/uc.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Uniformly controlled gate (also called multiplexed gate). + +These gates can have several control qubits and a single target qubit. If the k control qubits are in the state $|i\rangle$ (in the computational basis), a single-qubit unitary $U_i$ is applied to the target qubit. + +This gate is represented by a block-diagonal matrix, where each block is a $2\times 2$ unitary, that is + +$$ +\begin{pmatrix} + U_0 & 0 & \cdots & 0 \\ + 0 & U_1 & \cdots & 0 \\ + \vdots & & \ddots & \vdots \\ + 0 & 0 & \cdots & U_{2^{k-1}} +\end{pmatrix}. +$$ + +The decomposition is based on Ref. \[1]. + +**References:** + +**\[1] Bergholm et al., Quantum circuits with uniformly controlled one-qubit gates (2005).** + +[Phys. Rev. A 71, 052330](https://journals.aps.org/pra/abstract/10.1103/PhysRevA.71.052330). + +**Parameters** + +* **gate\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[np.ndarray]*) – List of two qubit unitaries $[U_0, ..., U_{2^{k-1}}]$, where each single-qubit unitary $U_i$ is given as a $2 \times 2$ numpy array. +* **up\_to\_diagonal** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Determines if the gate is implemented up to a diagonal. or if it is decomposed completely (default: False). If the `UCGate` $U$ is decomposed up to a diagonal $D$, this means that the circuit implements a unitary $U'$ such that $D U' = U$. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – in case of bad input to the constructor + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.UCGate.base_class "qiskit.circuit.library.UCGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return the inverse. + +This does not re-compute the decomposition for the multiplexer with the inverse of the gates but simply inverts the existing decomposition. + +**Return type** + +[*Gate*](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Uniformly controlled gate parameter has to be an ndarray. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UCPauliRotGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UCPauliRotGate.md new file mode 100644 index 00000000000..f9961b5a124 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UCPauliRotGate.md @@ -0,0 +1,122 @@ +--- +title: UCPauliRotGate +description: API reference for qiskit.circuit.library.UCPauliRotGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UCPauliRotGate +--- + +# UCPauliRotGate + + + +`qiskit.circuit.library.UCPauliRotGate(angle_list, rot_axis)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/uc_pauli_rot.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Uniformly controlled Pauli rotations. + +Implements the [`UCGate`](qiskit.circuit.library.UCGate "qiskit.circuit.library.UCGate") for the special case that all unitaries are Pauli rotations, $U_i = R_P(a_i)$ where $P \in \{X, Y, Z\}$ and $a_i \in \mathbb{R}$ is the rotation angle. + +**Parameters** + +* **angle\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of rotation angles $[a_0, ..., a_{2^{k-1}}]$. +* **rot\_axis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Rotation axis. Must be either of `"X"`, `"Y"` or `"Z"`. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.UCPauliRotGate.base_class "qiskit.circuit.library.UCPauliRotGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UCRXGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UCRXGate.md new file mode 100644 index 00000000000..4ea350c9129 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UCRXGate.md @@ -0,0 +1,121 @@ +--- +title: UCRXGate +description: API reference for qiskit.circuit.library.UCRXGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UCRXGate +--- + +# UCRXGate + + + +`qiskit.circuit.library.UCRXGate(angle_list)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/ucrx.py "view source code") + +Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") + +Uniformly controlled Pauli-X rotations. + +Implements the [`UCGate`](qiskit.circuit.library.UCGate "qiskit.circuit.library.UCGate") for the special case that all unitaries are Pauli-X rotations, $U_i = R_X(a_i)$ where $a_i \in \mathbb{R}$ is the rotation angle. + +**Parameters** + +**angle\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of rotation angles $[a_0, ..., a_{2^{k-1}}]$. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.UCRXGate.base_class "qiskit.circuit.library.UCRXGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UCRYGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UCRYGate.md new file mode 100644 index 00000000000..8a1b9e170dd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UCRYGate.md @@ -0,0 +1,121 @@ +--- +title: UCRYGate +description: API reference for qiskit.circuit.library.UCRYGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UCRYGate +--- + +# UCRYGate + + + +`qiskit.circuit.library.UCRYGate(angle_list)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/ucry.py "view source code") + +Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") + +Uniformly controlled Pauli-Y rotations. + +Implements the [`UCGate`](qiskit.circuit.library.UCGate "qiskit.circuit.library.UCGate") for the special case that all unitaries are Pauli-Y rotations, $U_i = R_Y(a_i)$ where $a_i \in \mathbb{R}$ is the rotation angle. + +**Parameters** + +**angle\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of rotation angles $[a_0, ..., a_{2^{k-1}}]$. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.UCRYGate.base_class "qiskit.circuit.library.UCRYGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UCRZGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UCRZGate.md new file mode 100644 index 00000000000..68a6143098a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UCRZGate.md @@ -0,0 +1,121 @@ +--- +title: UCRZGate +description: API reference for qiskit.circuit.library.UCRZGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UCRZGate +--- + +# UCRZGate + + + +`qiskit.circuit.library.UCRZGate(angle_list)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/ucrz.py "view source code") + +Bases: [`UCPauliRotGate`](qiskit.circuit.library.UCPauliRotGate "qiskit.circuit.library.generalized_gates.uc_pauli_rot.UCPauliRotGate") + +Uniformly controlled Pauli-Z rotations. + +Implements the [`UCGate`](qiskit.circuit.library.UCGate "qiskit.circuit.library.UCGate") for the special case that all unitaries are Pauli-Z rotations, $U_i = R_Z(a_i)$ where $a_i \in \mathbb{R}$ is the rotation angle. + +**Parameters** + +**angle\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of rotation angles $[a_0, ..., a_{2^{k-1}}]$. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.UCRZGate.base_class "qiskit.circuit.library.UCRZGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UGate.md new file mode 100644 index 00000000000..422fe3c621d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UGate.md @@ -0,0 +1,187 @@ +--- +title: UGate +description: API reference for qiskit.circuit.library.UGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UGate +--- + +# UGate + + + +`qiskit.circuit.library.UGate(theta, phi, lam, label=None, *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/u.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Generic single-qubit rotation gate with 3 Euler angles. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`u()`](qiskit.circuit.QuantumCircuit#u "qiskit.circuit.QuantumCircuit.u") method. + +**Circuit symbol:** + +```python + ┌──────────┐ +q_0: ┤ U(ϴ,φ,λ) ├ + └──────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +U(\theta, \phi, \lambda) = +\begin{pmatrix} + \cos\left(\rotationangle\right) & -e^{i\lambda}\sin\left(\rotationangle\right) \\ + e^{i\phi}\sin\left(\rotationangle\right) & e^{i(\phi+\lambda)}\cos\left(\rotationangle\right) +\end{pmatrix} +$$ + + + The matrix representation shown here is the same as in the [OpenQASM 3.0 specification](https://openqasm.com/language/gates.html#built-in-gates), which differs from the [OpenQASM 2.0 specification](https://doi.org/10.48550/arXiv.1707.03429) by a global phase of $e^{i(\phi+\lambda)/2}$. + + +**Examples:** + +$$ +U\left(\theta, -\frac{\pi}{2}, \frac{\pi}{2}\right) = RX(\theta) +$$ + +$$ +U(\theta, 0, 0) = RY(\theta) +$$ + +Create new U gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.UGate.base_class "qiskit.circuit.library.UGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-U gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted U gate. + +$U(\theta,\phi,\lambda)^{\dagger} =U(-\theta,-\lambda,-\phi)$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryGate.md new file mode 100644 index 00000000000..8b59d6c0cac --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryGate.md @@ -0,0 +1,209 @@ +--- +title: UnitaryGate +description: API reference for qiskit.circuit.library.UnitaryGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UnitaryGate +--- + +# UnitaryGate + + + +`qiskit.circuit.library.UnitaryGate(data, label=None, check_input=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/generalized_gates/unitary.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Class quantum gates specified by a unitary matrix. + +**Example** + +We can create a unitary gate from a unitary matrix then add it to a quantum circuit. The matrix can also be directly applied to the quantum circuit, see [`QuantumCircuit.unitary()`](qiskit.circuit.QuantumCircuit#unitary "qiskit.circuit.QuantumCircuit.unitary"). + +```python +from qiskit import QuantumCircuit +from qiskit.circuit.library import UnitaryGate + +matrix = [[0, 0, 0, 1], + [0, 0, 1, 0], + [1, 0, 0, 0], + [0, 1, 0, 0]] +gate = UnitaryGate(matrix) + +circuit = QuantumCircuit(2) +circuit.append(gate, [0, 1]) +``` + +Create a gate from a numeric unitary matrix. + +**Parameters** + +* **data** ([*numpy.ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate") *| BaseOperator*) – Unitary operator. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Unitary name for backend \[Default: None]. +* **check\_input** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `False` this asserts the input is known to be unitary and the checking to validate this will be skipped. This should only ever be used if you know the input is unitary, setting this to `False` and passing in a non-unitary matrix will result unexpected behavior and errors. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If input data is not an N-qubit unitary operator. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.UnitaryGate.base_class "qiskit.circuit.library.UnitaryGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the unitary. + +### conjugate + + + +`conjugate()` + +Return the conjugate of the unitary. + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return controlled version of gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of controls to add to gate (default is 1). +* **label** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional gate label. +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The control state in decimal or as a bit string (e.g. `"1011"`). If `None`, use `2**num_ctrl_qubits - 1`. + +**Returns** + +Controlled version of gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return the adjoint of the unitary. + +### transpose + + + +`transpose()` + +Return the transpose of the unitary. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Unitary gate parameter has to be an ndarray. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryOverlap.md b/docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryOverlap.md new file mode 100644 index 00000000000..4fcb29c8820 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.UnitaryOverlap.md @@ -0,0 +1,256 @@ +--- +title: UnitaryOverlap +description: API reference for qiskit.circuit.library.UnitaryOverlap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.UnitaryOverlap +--- + +# UnitaryOverlap + + + +`qiskit.circuit.library.UnitaryOverlap(unitary1, unitary2, prefix1='p1', prefix2='p2')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/overlap.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +Circuit that returns the overlap between two unitaries $U_2^{\dag} U_1$. + +The input quantum circuits must represent unitary operations, since they must be invertible. If the inputs will have parameters, they are replaced by [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector")s with names “p1” (for circuit `unitary1`) and “p2” (for circuit `unitary_2`) in the output circuit. + +This circuit is usually employed in computing the fidelity: + +```python +.. math:: + + \left|\langle 0| U_2^{\dag} U_1|0\rangle\right|^{2} +``` + +by computing the probability of being in the all-zeros bit-string, or equivalently, the expectation value of projector $|0\rangle\langle 0|$. + +Example: + +```python +import numpy as np +from qiskit.circuit.library import EfficientSU2, UnitaryOverlap +from qiskit.primitives import Sampler + +# get two circuit to prepare states of which we comput the overlap +circuit = EfficientSU2(2, reps=1) +unitary1 = circuit.assign_parameters(np.random.random(circuit.num_parameters)) +unitary2 = circuit.assign_parameters(np.random.random(circuit.num_parameters)) + +# create the overlap circuit +overlap = UnitaryOverap(unitary1, unitary2) + +# sample from the overlap +sampler = Sampler(options={"shots": 100}) +result = sampler.run(overlap).result() + +# the fidelity is the probability to measure 0 +fidelity = result.quasi_dists[0].get(0, 0) +``` + +**Parameters** + +* **unitary1** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – Unitary acting on the ket vector. +* **unitary2** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – Unitary whose inverse operates on the bra vector. +* **prefix1** – The name of the parameter vector associated to `unitary1`, if it is parameterized. Defaults to `"p1"`. +* **prefix2** – The name of the parameter vector associated to `unitary2`, if it is parameterized. Defaults to `"p2"`. + +**Raises** + +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Number of qubits in `unitary1` and `unitary2` does not match. +* [**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – Inputs contain measurements and/or resets. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.VBERippleCarryAdder.md b/docs/api/qiskit/0.46/qiskit.circuit.library.VBERippleCarryAdder.md new file mode 100644 index 00000000000..95cb4888005 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.VBERippleCarryAdder.md @@ -0,0 +1,255 @@ +--- +title: VBERippleCarryAdder +description: API reference for qiskit.circuit.library.VBERippleCarryAdder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.VBERippleCarryAdder +--- + +# VBERippleCarryAdder + + + +`qiskit.circuit.library.VBERippleCarryAdder(num_state_qubits, kind='full', name='VBERippleCarryAdder')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/adders/vbe_ripple_carry_adder.py "view source code") + +Bases: `Adder` + +The VBE ripple carry adder \[1]. + +This circuit performs inplace addition of two equally-sized quantum registers. As an example, a classical adder circuit that performs full addition (i.e. including a carry-in bit) on two 2-qubit sized registers is as follows: + +```python + ┌────────┐ ┌───────────┐┌──────┐ + cin_0: ┤0 ├───────────────────────┤0 ├┤0 ├ + │ │ │ ││ │ + a_0: ┤1 ├───────────────────────┤1 ├┤1 ├ + │ │┌────────┐ ┌──────┐│ ││ Sum │ + a_1: ┤ ├┤1 ├──■──┤1 ├┤ ├┤ ├ + │ ││ │ │ │ ││ ││ │ + b_0: ┤2 Carry ├┤ ├──┼──┤ ├┤2 Carry_dg ├┤2 ├ + │ ││ │┌─┴─┐│ ││ │└──────┘ + b_1: ┤ ├┤2 Carry ├┤ X ├┤2 Sum ├┤ ├──────── + │ ││ │└───┘│ ││ │ + cout_0: ┤ ├┤3 ├─────┤ ├┤ ├──────── + │ ││ │ │ ││ │ +helper_0: ┤3 ├┤0 ├─────┤0 ├┤3 ├──────── + └────────┘└────────┘ └──────┘└───────────┘ +``` + +Here *Carry* and *Sum* gates correspond to the gates introduced in \[1]. *Carry\_dg* correspond to the inverse of the *Carry* gate. Note that in this implementation the input register qubits are ordered as all qubits from the first input register, followed by all qubits from the second input register. This is different ordering as compared to Figure 2 in \[1], which leads to a different drawing of the circuit. + +**References:** + +\[1] Vedral et al., Quantum Networks for Elementary Arithmetic Operations, 1995. [arXiv:quant-ph/9511018](https://arxiv.org/pdf/quant-ph/9511018.pdf) + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The size of the register. +* **kind** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The kind of adder, can be `'full'` for a full adder, `'half'` for a half adder, or `'fixed'` for a fixed-sized adder. A full adder includes both carry-in and carry-out, a half only carry-out, and a fixed-sized adder neither carry-in nor carry-out. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `num_state_qubits` is lower than 1. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of state qubits, i.e. the number of bits in each input register. + +**Returns** + +The number of state qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.WeightedAdder.md b/docs/api/qiskit/0.46/qiskit.circuit.library.WeightedAdder.md new file mode 100644 index 00000000000..e9f59f146c8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.WeightedAdder.md @@ -0,0 +1,251 @@ +--- +title: WeightedAdder +description: API reference for qiskit.circuit.library.WeightedAdder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.WeightedAdder +--- + +# WeightedAdder + + + +`qiskit.circuit.library.WeightedAdder(num_state_qubits=None, weights=None, name='adder')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/arithmetic/weighted_adder.py "view source code") + +Bases: `BlueprintCircuit` + +A circuit to compute the weighted sum of qubit registers. + +Given $n$ qubit basis states $q_0, \ldots, q_{n-1} \in \{0, 1\}$ and non-negative integer weights $\lambda_0, \ldots, \lambda_{n-1}$, this circuit performs the operation + +$$ +|q_0 \ldots q_{n-1}\rangle |0\rangle_s +\mapsto |q_0 \ldots q_{n-1}\rangle |\sum_{j=0}^{n-1} \lambda_j q_j\rangle_s +$$ + +where $s$ is the number of sum qubits required. This can be computed as + +$$ +s = 1 + \left\lfloor \log_2\left( \sum_{j=0}^{n-1} \lambda_j \right) \right\rfloor +$$ + +or $s = 1$ if the sum of the weights is 0 (then the expression in the logarithm is invalid). + +For qubits in a circuit diagram, the first weight applies to the upper-most qubit. For an example where the state of 4 qubits is added into a sum register, the circuit can be schematically drawn as + +```python + ┌────────┐ + state_0: ┤0 ├ | state_0 * weights[0] + │ │ | + state_1: ┤1 ├ | + state_1 * weights[1] + │ │ | + state_2: ┤2 ├ | + state_2 * weights[2] + │ │ | + state_3: ┤3 ├ | + state_3 * weights[3] + │ │ + sum_0: ┤4 ├ | + │ Adder │ | + sum_1: ┤5 ├ | = sum_0 * 2^0 + sum_1 * 2^1 + sum_2 * 2^2 + │ │ | + sum_2: ┤6 ├ | + │ │ + carry_0: ┤7 ├ + │ │ + carry_1: ┤8 ├ + │ │ +control_0: ┤9 ├ + └────────┘ +``` + +Computes the weighted sum controlled by state qubits. + +**Parameters** + +* **num\_state\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of state qubits. +* **weights** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – List of weights, one for each state qubit. If none are provided they default to 1 for every qubit. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_carry\_qubits + +The number of carry qubits required to compute the sum. + +Note that this is not necessarily equal to the number of ancilla qubits, these can be queried using `num_ancilla_qubits`. + +**Returns** + +The number of carry qubits required to compute the sum. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_control\_qubits + +The number of additional control qubits required. + +Note that the total number of ancilla qubits can be obtained by calling the method `num_ancilla_qubits`. + +**Returns** + +The number of additional control qubits required (0 or 1). + + + +### num\_parameters + + + +### num\_qubits + +Return number of qubits. + + + +### num\_state\_qubits + +The number of qubits to be summed. + +**Returns** + +The number of state qubits. + + + +### num\_sum\_qubits + +The number of sum qubits in the circuit. + +**Returns** + +The number of qubits needed to represent the weighted sum of the qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### weights + +The weights for the qubit states. + +**Returns** + +The weight for the qubit states. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.XGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.XGate.md new file mode 100644 index 00000000000..525f90e33cb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.XGate.md @@ -0,0 +1,191 @@ +--- +title: XGate +description: API reference for qiskit.circuit.library.XGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.XGate +--- + +# XGate + + + +`qiskit.circuit.library.XGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/x.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The single-qubit Pauli-X gate ($\sigma_x$). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`x()`](qiskit.circuit.QuantumCircuit#x "qiskit.circuit.QuantumCircuit.x") method. + +**Matrix Representation:** + +$$ +X = \begin{pmatrix} + 0 & 1 \\ + 1 & 0 + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌───┐ +q_0: ┤ X ├ + └───┘ +``` + +Equivalent to a $\pi$ radian rotation about the X axis. + + + A global phase difference exists between the definitions of $RX(\pi)$ and $X$. + + $$ + RX(\pi) = \begin{pmatrix} + 0 & -i \\ + -i & 0 + \end{pmatrix} + = -i X + $$ + + +The gate is equivalent to a classical bit flip. + +$$ +|0\rangle \rightarrow |1\rangle \\ +|1\rangle \rightarrow |0\rangle +$$ + +Create new X gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.XGate.base_class "qiskit.circuit.library.XGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-X gate. + +One control returns a CX gate. Two controls returns a CCX gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted X gate (itself). + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.XOR.md b/docs/api/qiskit/0.46/qiskit.circuit.library.XOR.md new file mode 100644 index 00000000000..b562f42ad8f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.XOR.md @@ -0,0 +1,229 @@ +--- +title: XOR +description: API reference for qiskit.circuit.library.XOR +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.XOR +--- + +# XOR + + + +`qiskit.circuit.library.XOR(num_qubits, amount=None, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/boolean_logic/quantum_xor.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +An n\_qubit circuit for bitwise xor-ing the input with some integer `amount`. + +The `amount` is xor-ed in bitstring form with the input. + +This circuit can also represent addition by `amount` over the finite field GF(2). + +Return a circuit implementing bitwise xor. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the width of circuit. +* **amount** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – the xor amount in decimal form. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – random seed in case a random xor is requested. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – if the xor bitstring exceeds available qubits. + +**Reference Circuit:** + +![../\_images/qiskit-circuit-library-XOR-1.png](/images/api/qiskit/0.46/qiskit-circuit-library-XOR-1.png) + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 161` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.XXMinusYYGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.XXMinusYYGate.md new file mode 100644 index 00000000000..2d02a88ff8a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.XXMinusYYGate.md @@ -0,0 +1,193 @@ +--- +title: XXMinusYYGate +description: API reference for qiskit.circuit.library.XXMinusYYGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.XXMinusYYGate +--- + +# XXMinusYYGate + + + +`qiskit.circuit.library.XXMinusYYGate(theta, beta=0, label='(XX-YY)', *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/xx_minus_yy.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +XX-YY interaction gate. + +A 2-qubit parameterized XX-YY interaction. Its action is to induce a coherent rotation by some angle between $|00\rangle$ and $|11\rangle$. + +**Circuit Symbol:** + +```python + ┌───────────────┐ +q_0: ┤0 ├ + │ (XX-YY)(θ,β) │ +q_1: ┤1 ├ + └───────────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R_{XX-YY}(\theta, \beta) q_0, q_1 = + RZ_1(\beta) \cdot \exp\left(-i \frac{\theta}{2} \frac{XX-YY}{2}\right) \cdot RZ_1(-\beta) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & 0 & 0 & -i\sin\left(\rotationangle\right)e^{-i\beta} \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + -i\sin\left(\rotationangle\right)e^{i\beta} & 0 & 0 & \cos\left(\rotationangle\right) + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In the above example we apply the gate on (q\_0, q\_1) which results in adding the (optional) phase defined by $\beta$ on q\_1. Instead, if we apply it on (q\_1, q\_0), the phase is added on q\_0. If $\beta$ is set to its default value of $0$, the gate is equivalent in big and little endian. + + ```python + ┌───────────────┐ + q_0: ┤1 ├ + │ (XX-YY)(θ,β) │ + q_1: ┤0 ├ + └───────────────┘ + ``` + + $$ + \newcommand{\rotationangle}{\frac{\theta}{2}} + + R_{XX-YY}(\theta, \beta) q_1, q_0 = + RZ_0(\beta) \cdot \exp\left(-i \frac{\theta}{2} \frac{XX-YY}{2}\right) \cdot RZ_0(-\beta) = + \begin{pmatrix} + \cos\left(\rotationangle\right) & 0 & 0 & -i\sin\left(\rotationangle\right)e^{i\beta} \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + -i\sin\left(\rotationangle\right)e^{-i\beta} & 0 & 0 & \cos\left(\rotationangle\right) + \end{pmatrix} + $$ + + +Create new XX-YY gate. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The rotation angle. +* **beta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The phase angle. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The label of the gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.XXMinusYYGate.base_class "qiskit.circuit.library.XXMinusYYGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Inverse gate. + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.XXPlusYYGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.XXPlusYYGate.md new file mode 100644 index 00000000000..43752c4f975 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.XXPlusYYGate.md @@ -0,0 +1,193 @@ +--- +title: XXPlusYYGate +description: API reference for qiskit.circuit.library.XXPlusYYGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.XXPlusYYGate +--- + +# XXPlusYYGate + + + +`qiskit.circuit.library.XXPlusYYGate(theta, beta=0, label='(XX+YY)', *, duration=None, unit='dt')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/xx_plus_yy.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +XX+YY interaction gate. + +A 2-qubit parameterized XX+YY interaction, also known as an XY gate. Its action is to induce a coherent rotation by some angle between $|01\rangle$ and $|10\rangle$. + +**Circuit Symbol:** + +```python + ┌───────────────┐ +q_0: ┤0 ├ + │ (XX+YY)(θ,β) │ +q_1: ┤1 ├ + └───────────────┘ +``` + +**Matrix Representation:** + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R_{XX+YY}(\theta, \beta)\ q_0, q_1 = + RZ_0(-\beta) \cdot \exp\left(-i \frac{\theta}{2} \frac{XX+YY}{2}\right) \cdot RZ_0(\beta) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & \cos\left(\rotationangle\right) & -i\sin\left(\rotationangle\right)e^{-i\beta} & 0 \\ + 0 & -i\sin\left(\rotationangle\right)e^{i\beta} & \cos\left(\rotationangle\right) & 0 \\ + 0 & 0 & 0 & 1 + \end{pmatrix} +$$ + + + In Qiskit’s convention, higher qubit indices are more significant (little endian convention). In the above example we apply the gate on (q\_0, q\_1) which results in adding the (optional) phase defined by $\beta$ on q\_0. Instead, if we apply it on (q\_1, q\_0), the phase is added on q\_1. If $\beta$ is set to its default value of $0$, the gate is equivalent in big and little endian. + + ```python + ┌───────────────┐ + q_0: ┤1 ├ + │ (XX+YY)(θ,β) │ + q_1: ┤0 ├ + └───────────────┘ + ``` + + +$$ +\newcommand{\rotationangle}{\frac{\theta}{2}} + +R_{XX+YY}(\theta, \beta)\ q_0, q_1 = + RZ_1(-\beta) \cdot \exp\left(-i \frac{\theta}{2} \frac{XX+YY}{2}\right) \cdot RZ_1(\beta) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & \cos\left(\rotationangle\right) & -i\sin\left(\rotationangle\right)e^{i\beta} & 0 \\ + 0 & -i\sin\left(\rotationangle\right)e^{-i\beta} & \cos\left(\rotationangle\right) & 0 \\ + 0 & 0 & 0 & 1 + \end{pmatrix} +$$ + +Create new XX+YY gate. + +**Parameters** + +* **theta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The rotation angle. +* **beta** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The phase angle. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The label of the gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.XXPlusYYGate.base_class "qiskit.circuit.library.XXPlusYYGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### inverse + + + +`inverse()` + +Return inverse XX+YY gate (i.e. with the negative rotation angle and same phase angle). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.YGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.YGate.md new file mode 100644 index 00000000000..cc275fc50c0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.YGate.md @@ -0,0 +1,191 @@ +--- +title: YGate +description: API reference for qiskit.circuit.library.YGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.YGate +--- + +# YGate + + + +`qiskit.circuit.library.YGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/y.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The single-qubit Pauli-Y gate ($\sigma_y$). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`y()`](qiskit.circuit.QuantumCircuit#y "qiskit.circuit.QuantumCircuit.y") method. + +**Matrix Representation:** + +$$ +Y = \begin{pmatrix} + 0 & -i \\ + i & 0 + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌───┐ +q_0: ┤ Y ├ + └───┘ +``` + +Equivalent to a $\pi$ radian rotation about the Y axis. + + + A global phase difference exists between the definitions of $RY(\pi)$ and $Y$. + + $$ + RY(\pi) = \begin{pmatrix} + 0 & -1 \\ + 1 & 0 + \end{pmatrix} + = -i Y + $$ + + +The gate is equivalent to a bit and phase flip. + +$$ +|0\rangle \rightarrow i|1\rangle \\ +|1\rangle \rightarrow -i|0\rangle +$$ + +Create new Y gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.YGate.base_class "qiskit.circuit.library.YGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-Y gate. + +One control returns a CY gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted Y gate ($Y^{\dagger} = Y$) + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.ZFeatureMap.md b/docs/api/qiskit/0.46/qiskit.circuit.library.ZFeatureMap.md new file mode 100644 index 00000000000..c7ba5263343 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.ZFeatureMap.md @@ -0,0 +1,367 @@ +--- +title: ZFeatureMap +description: API reference for qiskit.circuit.library.ZFeatureMap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.ZFeatureMap +--- + +# ZFeatureMap + + + +`qiskit.circuit.library.ZFeatureMap(feature_dimension, reps=2, data_map_func=None, parameter_prefix='x', insert_barriers=False, name='ZFeatureMap')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/data_preparation/z_feature_map.py "view source code") + +Bases: [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.data_preparation.pauli_feature_map.PauliFeatureMap") + +The first order Pauli Z-evolution circuit. + +On 3 qubits and with 2 repetitions the circuit is represented by: + +```python +┌───┐┌──────────────┐┌───┐┌──────────────┐ +┤ H ├┤ U1(2.0*x[0]) ├┤ H ├┤ U1(2.0*x[0]) ├ +├───┤├──────────────┤├───┤├──────────────┤ +┤ H ├┤ U1(2.0*x[1]) ├┤ H ├┤ U1(2.0*x[1]) ├ +├───┤├──────────────┤├───┤├──────────────┤ +┤ H ├┤ U1(2.0*x[2]) ├┤ H ├┤ U1(2.0*x[2]) ├ +└───┘└──────────────┘└───┘└──────────────┘ +``` + +This is a sub-class of [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.PauliFeatureMap") where the Pauli strings are fixed as \[‘Z’]. As a result the first order expansion will be a circuit without entangling gates. + +**Examples** + +```python +>>> prep = ZFeatureMap(3, reps=3, insert_barriers=True) +>>> print(prep) + ┌───┐ ░ ┌──────────────┐ ░ ┌───┐ ░ ┌──────────────┐ ░ ┌───┐ ░ ┌──────────────┐ +q_0: ┤ H ├─░─┤ U1(2.0*x[0]) ├─░─┤ H ├─░─┤ U1(2.0*x[0]) ├─░─┤ H ├─░─┤ U1(2.0*x[0]) ├ + ├───┤ ░ ├──────────────┤ ░ ├───┤ ░ ├──────────────┤ ░ ├───┤ ░ ├──────────────┤ +q_1: ┤ H ├─░─┤ U1(2.0*x[1]) ├─░─┤ H ├─░─┤ U1(2.0*x[1]) ├─░─┤ H ├─░─┤ U1(2.0*x[1]) ├ + ├───┤ ░ ├──────────────┤ ░ ├───┤ ░ ├──────────────┤ ░ ├───┤ ░ ├──────────────┤ +q_2: ┤ H ├─░─┤ U1(2.0*x[2]) ├─░─┤ H ├─░─┤ U1(2.0*x[2]) ├─░─┤ H ├─░─┤ U1(2.0*x[2]) ├ + └───┘ ░ └──────────────┘ ░ └───┘ ░ └──────────────┘ ░ └───┘ ░ └──────────────┘ +``` + +```python +>>> data_map = lambda x: x[0]*x[0] + 1 # note: input is an array +>>> prep = ZFeatureMap(3, reps=1, data_map_func=data_map) +>>> print(prep) + ┌───┐┌───────────────────────┐ +q_0: ┤ H ├┤ U1(2.0*x[0]**2 + 2.0) ├ + ├───┤├───────────────────────┤ +q_1: ┤ H ├┤ U1(2.0*x[1]**2 + 2.0) ├ + ├───┤├───────────────────────┤ +q_2: ┤ H ├┤ U1(2.0*x[2]**2 + 2.0) ├ + └───┘└───────────────────────┘ +``` + +```python +>>> classifier = ZFeatureMap(3, reps=1) + RY(3, reps=1) +>>> print(classifier) + ┌───┐┌──────────────┐┌──────────┐ ┌──────────┐ +q_0: ┤ H ├┤ U1(2.0*x[0]) ├┤ RY(θ[0]) ├─■──■─┤ RY(θ[3]) ├──────────── + ├───┤├──────────────┤├──────────┤ │ │ └──────────┘┌──────────┐ +q_1: ┤ H ├┤ U1(2.0*x[1]) ├┤ RY(θ[1]) ├─■──┼──────■──────┤ RY(θ[4]) ├ + ├───┤├──────────────┤├──────────┤ │ │ ├──────────┤ +q_2: ┤ H ├┤ U1(2.0*x[2]) ├┤ RY(θ[2]) ├────■──────■──────┤ RY(θ[5]) ├ + └───┘└──────────────┘└──────────┘ └──────────┘ +``` + +Create a new first-order Pauli-Z expansion circuit. + +**Parameters** + +* **feature\_dimension** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of features +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of repeated circuits. Defaults to 2, has a minimum value of 1. +* **data\_map\_func** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A mapping function for data x which can be supplied to override the default mapping from `self_product()`. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The prefix used if default parameters are generated. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, barriers are inserted in between the evolution instructions and hadamard layers. + +## Attributes + + + +### alpha + +The Pauli rotation factor (alpha). + +**Returns** + +The Pauli rotation factor. + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### feature\_dimension + +Returns the feature dimension (which is equal to the number of qubits). + +**Returns** + +The feature dimension of this feature map. + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 163` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of distinct parameters. + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If `None` is returned, problem is fully unbounded. + + + +### parameters + + + +### paulis + +The Pauli strings used in the entanglement of the qubits. + +**Returns** + +The Pauli strings as list. + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.ZGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.ZGate.md new file mode 100644 index 00000000000..fa9f5ea4899 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.ZGate.md @@ -0,0 +1,199 @@ +--- +title: ZGate +description: API reference for qiskit.circuit.library.ZGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.ZGate +--- + +# ZGate + + + +`qiskit.circuit.library.ZGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/z.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +The single-qubit Pauli-Z gate ($\sigma_z$). + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`z()`](qiskit.circuit.QuantumCircuit#z "qiskit.circuit.QuantumCircuit.z") method. + +**Matrix Representation:** + +$$ +Z = \begin{pmatrix} + 1 & 0 \\ + 0 & -1 + \end{pmatrix} +$$ + +**Circuit symbol:** + +```python + ┌───┐ +q_0: ┤ Z ├ + └───┘ +``` + +Equivalent to a $\pi$ radian rotation about the Z axis. + + + A global phase difference exists between the definitions of $RZ(\pi)$ and $Z$. + + $$ + RZ(\pi) = \begin{pmatrix} + -i & 0 \\ + 0 & i + \end{pmatrix} + = -i Z + $$ + + +The gate is equivalent to a phase flip. + +$$ +|0\rangle \rightarrow |0\rangle \\ +|1\rangle \rightarrow -|1\rangle +$$ + +Create new Z gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.ZGate.base_class "qiskit.circuit.library.ZGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return a (multi-)controlled-Z gate. + +One control returns a CZ gate. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of control qubits. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – An optional label for the gate \[Default: None] +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or None*) – control state expressed as integer, string (e.g. ‘110’), or None. If None, use all 1s. + +**Returns** + +controlled version of this gate. + +**Return type** + +[ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +### inverse + + + +`inverse()` + +Return inverted Z gate (itself). + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.ZZFeatureMap.md b/docs/api/qiskit/0.46/qiskit.circuit.library.ZZFeatureMap.md new file mode 100644 index 00000000000..ab8b04d733d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.ZZFeatureMap.md @@ -0,0 +1,372 @@ +--- +title: ZZFeatureMap +description: API reference for qiskit.circuit.library.ZZFeatureMap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.ZZFeatureMap +--- + +# ZZFeatureMap + + + +`qiskit.circuit.library.ZZFeatureMap(feature_dimension, reps=2, entanglement='full', data_map_func=None, parameter_prefix='x', insert_barriers=False, name='ZZFeatureMap')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/data_preparation/zz_feature_map.py "view source code") + +Bases: [`PauliFeatureMap`](qiskit.circuit.library.PauliFeatureMap "qiskit.circuit.library.data_preparation.pauli_feature_map.PauliFeatureMap") + +Second-order Pauli-Z evolution circuit. + +For 3 qubits and 1 repetition and linear entanglement the circuit is represented by: + +```python +┌───┐┌─────────────────┐ +┤ H ├┤ U1(2.0*φ(x[0])) ├──■────────────────────────────■──────────────────────────────────── +├───┤├─────────────────┤┌─┴─┐┌──────────────────────┐┌─┴─┐ +┤ H ├┤ U1(2.0*φ(x[1])) ├┤ X ├┤ U1(2.0*φ(x[0],x[1])) ├┤ X ├──■────────────────────────────■── +├───┤├─────────────────┤└───┘└──────────────────────┘└───┘┌─┴─┐┌──────────────────────┐┌─┴─┐ +┤ H ├┤ U1(2.0*φ(x[2])) ├──────────────────────────────────┤ X ├┤ U1(2.0*φ(x[1],x[2])) ├┤ X ├ +└───┘└─────────────────┘ └───┘└──────────────────────┘└───┘ +``` + +where $\varphi$ is a classical non-linear function, which defaults to $\varphi(x) = x$ if and $\varphi(x,y) = (\pi - x)(\pi - y)$. + +**Examples** + +```python +>>> from qiskit.circuit.library import ZZFeatureMap +>>> prep = ZZFeatureMap(2, reps=1) +>>> print(prep) + ┌───┐┌──────────────┐ +q_0: ┤ H ├┤ U1(2.0*x[0]) ├──■───────────────────────────────────────■── + ├───┤├──────────────┤┌─┴─┐┌─────────────────────────────────┐┌─┴─┐ +q_1: ┤ H ├┤ U1(2.0*x[1]) ├┤ X ├┤ U1(2.0*(pi - x[0])*(pi - x[1])) ├┤ X ├ + └───┘└──────────────┘└───┘└─────────────────────────────────┘└───┘ +``` + +```python +>>> from qiskit.circuit.library import EfficientSU2 +>>> classifier = ZZFeatureMap(3) + EfficientSU2(3) +>>> classifier.num_parameters +15 +>>> classifier.parameters # 'x' for the data preparation, 'θ' for the SU2 parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(θ[0]), + ParameterVectorElement(θ[1]), ParameterVectorElement(θ[2]), + ParameterVectorElement(θ[3]), ParameterVectorElement(θ[4]), + ParameterVectorElement(θ[5]), ParameterVectorElement(θ[6]), + ParameterVectorElement(θ[7]), ParameterVectorElement(θ[8]), + ParameterVectorElement(θ[9]), ParameterVectorElement(θ[10]), + ParameterVectorElement(θ[11]), ParameterVectorElement(θ[12]), + ParameterVectorElement(θ[13]), ParameterVectorElement(θ[14]), + ParameterVectorElement(θ[15]), ParameterVectorElement(θ[16]), + ParameterVectorElement(θ[17]), ParameterVectorElement(θ[18]), + ParameterVectorElement(θ[19]), ParameterVectorElement(θ[20]), + ParameterVectorElement(θ[21]), ParameterVectorElement(θ[22]), + ParameterVectorElement(θ[23]) +]) +>>> classifier.count_ops() +OrderedDict([('ZZFeatureMap', 1), ('EfficientSU2', 1)]) +``` + +Create a new second-order Pauli-Z expansion. + +**Parameters** + +* **feature\_dimension** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of features. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of repeated circuits, has a min. value of 1. +* **entanglement** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] |* [*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – Specifies the entanglement structure. Refer to [`NLocal`](qiskit.circuit.library.NLocal "qiskit.circuit.library.NLocal") for detail. +* **data\_map\_func** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*],* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A mapping function for data x. +* **parameter\_prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The prefix used if default parameters are generated. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, barriers are inserted in between the evolution instructions and hadamard layers. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the feature dimension is smaller than 2. + +## Attributes + + + +### alpha + +The Pauli rotation factor (alpha). + +**Returns** + +The Pauli rotation factor. + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + + + +### entanglement + +Get the entanglement strategy. + +**Returns** + +The entanglement strategy, see `get_entangler_map()` for more detail on how the format is interpreted. + + + +### entanglement\_blocks + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### feature\_dimension + +Returns the feature dimension (which is equal to the number of qubits). + +**Returns** + +The feature dimension of this feature map. + + + +### flatten + +Returns whether the circuit is wrapped in nested gates/instructions or flattened. + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### initial\_state + +Return the initial state that is added in front of the n-local circuit. + +**Returns** + +The initial state. + + + +### insert\_barriers + +If barriers are inserted in between the layers or not. + +**Returns** + +`True`, if barriers are inserted in between the layers, `False` if not. + + + +### instances + +`= 163` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_layers + +Return the number of layers in the n-local circuit. + +**Returns** + +The number of layers in the circuit. + + + +### num\_parameters + + + +### num\_parameters\_settable + +The number of distinct parameters. + + + +### num\_qubits + +Returns the number of qubits in this circuit. + +**Returns** + +The number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### ordered\_parameters + +The parameters used in the underlying circuit. + +This includes float values and duplicates. + +**Examples** + +```python +>>> # prepare circuit ... +>>> print(nlocal) + ┌───────┐┌──────────┐┌──────────┐┌──────────┐ +q_0: ┤ Ry(1) ├┤ Ry(θ[1]) ├┤ Ry(θ[1]) ├┤ Ry(θ[3]) ├ + └───────┘└──────────┘└──────────┘└──────────┘ +>>> nlocal.parameters +{Parameter(θ[1]), Parameter(θ[3])} +>>> nlocal.ordered_parameters +[1, Parameter(θ[1]), Parameter(θ[1]), Parameter(θ[3])] +``` + +**Returns** + +The parameters objects used in the circuit. + + + +### parameter\_bounds + +The parameter bounds for the unbound parameters in the circuit. + +**Returns** + +A list of pairs indicating the bounds, as (lower, upper). None indicates an unbounded parameter in the corresponding direction. If `None` is returned, problem is fully unbounded. + + + +### parameters + + + +### paulis + +The Pauli strings used in the entanglement of the qubits. + +**Returns** + +The Pauli strings as list. + + + +### preferred\_init\_points + +The initial points for the parameters. Can be stored as initial guess in optimization. + +**Returns** + +The initial values for the parameters, or None, if none have been set. + + + +### prefix + +`= 'circuit'` + + + +### qregs + +`list[QuantumRegister]` + +A list of the quantum registers associated with the circuit. + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### reps + +The number of times rotation and entanglement block are repeated. + +**Returns** + +The number of repetitions. + + + +### rotation\_blocks + +The blocks in the rotation layers. + +**Returns** + +The blocks in the rotation layers. + diff --git a/docs/api/qiskit/0.46/qiskit.circuit.library.iSwapGate.md b/docs/api/qiskit/0.46/qiskit.circuit.library.iSwapGate.md new file mode 100644 index 00000000000..877beaf25b4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.circuit.library.iSwapGate.md @@ -0,0 +1,180 @@ +--- +title: iSwapGate +description: API reference for qiskit.circuit.library.iSwapGate +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.circuit.library.iSwapGate +--- + +# iSwapGate + + + +`qiskit.circuit.library.iSwapGate(*args, _force_mutable=False, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/circuit/library/standard_gates/iswap.py "view source code") + +Bases: [`SingletonGate`](circuit_singleton#qiskit.circuit.singleton.SingletonGate "qiskit.circuit.singleton.SingletonGate") + +iSWAP gate. + +A 2-qubit XX+YY interaction. This is a Clifford and symmetric gate. Its action is to swap two qubit states and phase the $|01\rangle$ and $|10\rangle$ amplitudes by i. + +Can be applied to a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") with the [`iswap()`](qiskit.circuit.QuantumCircuit#iswap "qiskit.circuit.QuantumCircuit.iswap") method. + +**Circuit Symbol:** + +```python +q_0: ─⨂─ + │ +q_1: ─⨂─ +``` + +**Reference Implementation:** + +```python + ┌───┐┌───┐ ┌───┐ +q_0: ┤ S ├┤ H ├──■──┤ X ├───── + ├───┤└───┘┌─┴─┐└─┬─┘┌───┐ +q_1: ┤ S ├─────┤ X ├──■──┤ H ├ + └───┘ └───┘ └───┘ +``` + +**Matrix Representation:** + +$$ +iSWAP = R_{XX+YY}\left(-\frac{\pi}{2}\right) + = \exp\left(i \frac{\pi}{4} \left(X{\otimes}X+Y{\otimes}Y\right)\right) = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 0 & i & 0 \\ + 0 & i & 0 & 0 \\ + 0 & 0 & 0 & 1 + \end{pmatrix} +$$ + +This gate is equivalent to a SWAP up to a diagonal. + +$$ +iSWAP = + \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & 0 & 1 & 0 \\ + 0 & 1 & 0 & 0 \\ + 0 & 0 & 0 & 1 + \end{pmatrix} +. \begin{pmatrix} + 1 & 0 & 0 & 0 \\ + 0 & i & 0 & 0 \\ + 0 & 0 & i & 0 \\ + 0 & 0 & 0 & 1 + \end{pmatrix} +$$ + +Create new iSwap gate. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.circuit.library.iSwapGate.base_class "qiskit.circuit.library.iSwapGate.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### power + + + +`power(exponent)` + +Raise gate to a power. + diff --git a/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGCircuit.md b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGCircuit.md new file mode 100644 index 00000000000..19f6d1074ea --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGCircuit.md @@ -0,0 +1,1026 @@ +--- +title: DAGCircuit +description: API reference for qiskit.dagcircuit.DAGCircuit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.dagcircuit.DAGCircuit +--- + +# DAGCircuit + + + +`qiskit.dagcircuit.DAGCircuit`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/dagcircuit.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Quantum circuit as a directed acyclic graph. + +There are 3 types of nodes in the graph: inputs, outputs, and operations. The nodes are connected by directed edges that correspond to qubits and bits. + +Create an empty circuit. + +## Attributes + + + +### calibrations + +Return calibration dictionary. + +**The custom pulse definition of a given gate is of the form** + +\{‘gate\_name’: \{(qubits, params): schedule}} + + + +### global\_phase + +Return the global phase of the circuit. + + + +### node\_counter + +Returns the number of nodes in the dag. + + + +### wires + +Return a list of the wires in order. + +## Methods + +### add\_calibration + + + +`add_calibration(gate, qubits, schedule, params=None)` + +Register a low-level, custom pulse definition for the given gate. + +**Parameters** + +* **gate** (*Union\[*[*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")*,* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Gate information. +* **qubits** (*Union\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, Tuple\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – List of qubits to be measured. +* **schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule")) – Schedule information. +* **params** (*Optional\[List\[Union\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*]]]*) – A list of parameters. + +**Raises** + +[**Exception**](https://docs.python.org/3/library/exceptions.html#Exception "(in Python v3.12)") – if the gate is of type string and params is None. + +### add\_clbits + + + +`add_clbits(clbits)` + +Add individual clbit wires. + +### add\_creg + + + +`add_creg(creg)` + +Add all wires in a classical register. + +### add\_qreg + + + +`add_qreg(qreg)` + +Add all wires in a quantum register. + +### add\_qubits + + + +`add_qubits(qubits)` + +Add individual qubit wires. + +### ancestors + + + +`ancestors(node)` + +Returns set of the ancestors of a node as DAGOpNodes and DAGInNodes. + +### apply\_operation\_back + + + +`apply_operation_back(op, qargs=(), cargs=(), *, check=True)` + +Apply an operation to the output of the circuit. + +**Parameters** + +* **op** ([*qiskit.circuit.Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation")) – the operation associated with the DAG node +* **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – qubits that op will be applied to +* **cargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – cbits that op will be applied to +* **check** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` (default), this function will enforce that the [`DAGCircuit`](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") data-structure invariants are maintained (all `qargs` are [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit")s, all are in the DAG, etc). If `False`, the caller *must* uphold these invariants itself, but the cost of several checks will be skipped. This is most useful when building a new DAG from a source of known-good nodes. + +**Returns** + +the node for the op that was added to the dag + +**Return type** + +[DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if a leaf node is connected to multiple outputs + +### apply\_operation\_front + + + +`apply_operation_front(op, qargs=(), cargs=(), *, check=True)` + +Apply an operation to the input of the circuit. + +**Parameters** + +* **op** ([*qiskit.circuit.Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation")) – the operation associated with the DAG node +* **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – qubits that op will be applied to +* **cargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – cbits that op will be applied to +* **check** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` (default), this function will enforce that the [`DAGCircuit`](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") data-structure invariants are maintained (all `qargs` are [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit")s, all are in the DAG, etc). If `False`, the caller *must* uphold these invariants itself, but the cost of several checks will be skipped. This is most useful when building a new DAG from a source of known-good nodes. + +**Returns** + +the node for the op that was added to the dag + +**Return type** + +[DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if initial nodes connected to multiple out edges + +### bfs\_successors + + + +`bfs_successors(node)` + +Returns an iterator of tuples of (DAGNode, \[DAGNodes]) where the DAGNode is the current node and \[DAGNode] is its successors in BFS order. + +### classical\_predecessors + + + +`classical_predecessors(node)` + +Returns iterator of the predecessors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. + +### classical\_successors + + + +`classical_successors(node)` + +Returns iterator of the successors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes. + +### collect\_1q\_runs + + + +`collect_1q_runs()` + +Return a set of non-conditional runs of 1q “op” nodes. + +### collect\_2q\_runs + + + +`collect_2q_runs()` + +Return a set of non-conditional runs of 2q “op” nodes. + +### collect\_runs + + + +`collect_runs(namelist)` + +Return a set of non-conditional runs of “op” nodes with the given names. + +For example, “… h q\[0]; cx q\[0],q\[1]; cx q\[0],q\[1]; h q\[1]; ..” would produce the tuple of cx nodes as an element of the set returned from a call to collect\_runs(\[“cx”]). If instead the cx nodes were “cx q\[0],q\[1]; cx q\[1],q\[0];”, the method would still return the pair in a tuple. The namelist can contain names that are not in the circuit’s basis. + +Nodes must have only one successor to continue the run. + +### compose + + + +`compose(other, qubits=None, clbits=None, front=False, inplace=True)` + +Compose the `other` circuit onto the output of this circuit. + +A subset of input wires of `other` are mapped to a subset of output wires of this circuit. + +`other` can be narrower or of equal width to `self`. + +**Parameters** + +* **other** ([*DAGCircuit*](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – circuit to compose with self +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – qubits of self to compose onto. +* **clbits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – clbits of self to compose onto. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, front composition will be performed (not implemented yet) +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, modify the object. Otherwise return composed circuit. + +**Returns** + +the composed dag (returns None if inplace==True). + +**Return type** + +[DAGCircuit](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if `other` is wider or there are duplicate edge mappings. + +### copy\_empty\_like + + + +`copy_empty_like()` + +Return a copy of self with the same structure but empty. + +**That structure includes:** + +* name and other metadata +* global phase +* duration +* all the qubits and clbits, including the registers. + +**Returns** + +An empty copy of self. + +**Return type** + +[DAGCircuit](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### count\_ops + + + +`count_ops(*, recurse=True)` + +Count the occurrences of operation names. + +**Parameters** + +**recurse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` (default), then recurse into control-flow operations. In all cases, this counts only the number of times the operation appears in any possible block; both branches of if-elses are counted, and for- and while-loop blocks are only counted once. + +**Returns** + +a mapping of operation names to the number of times it appears. + +**Return type** + +Mapping\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + +### count\_ops\_longest\_path + + + +`count_ops_longest_path()` + +Count the occurrences of operation names on the longest path. + +Returns a dictionary of counts keyed on the operation name. + +### depth + + + +`depth(*, recurse=False)` + +Return the circuit depth. If there is control flow present, this count may only be an estimate, as the complete control-flow path cannot be statically known. + +**Parameters** + +**recurse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True`, then recurse into control-flow operations. For loops with known-length iterators are counted as if the loop had been manually unrolled (*i.e.* with each iteration of the loop body written out explicitly). If-else blocks take the longer case of the two branches. While loops are counted as if the loop body runs once only. Defaults to `False` and raises [`DAGCircuitError`](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") if any control flow is present, to avoid silently returning a nonsensical number. + +**Returns** + +the circuit depth + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +**Raises** + +* [**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if not a directed acyclic graph +* [**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if unknown control flow is present in a recursive call, or any control flow is present in a non-recursive call. + +### descendants + + + +`descendants(node)` + +Returns set of the descendants of a node as DAGOpNodes and DAGOutNodes. + +### draw + + + +`draw(scale=0.7, filename=None, style='color')` + +Draws the dag circuit. + +This function needs [Graphviz](https://www.graphviz.org/) to be installed. Graphviz is not a python package and can’t be pip installed (the `graphviz` package on PyPI is a Python interface library for Graphviz and does not actually install Graphviz). You can refer to [the Graphviz documentation](https://www.graphviz.org/download/) on how to install it. + +**Parameters** + +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – scaling factor +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to (format inferred from name) +* **style** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – ‘plain’: B\&W graph; ‘color’ (default): color input/output/op nodes + +**Returns** + +if in Jupyter notebook and not saving to file, otherwise None. + +**Return type** + +Ipython.display.Image + +### edges + + + +`edges(nodes=None)` + +Iterator for edge values and source and dest node + +This works by returning the output edges from the specified nodes. If no nodes are specified all edges from the graph are returned. + +**Parameters** + +**nodes** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*, or* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")*|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*, or* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – Either a list of nodes or a single input node. If none is specified, all edges are returned from the graph. + +**Yields** + +*edge* – + +**the edge in the same format as out\_edges the tuple** + +(source node, destination node, edge data) + +### find\_bit + + + +`find_bit(bit)` + +Finds locations in the circuit, by mapping the Qubit and Clbit to positional index BitLocations is defined as: BitLocations = namedtuple(“BitLocations”, (“index”, “registers”)) + +**Parameters** + +**bit** ([*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")) – The bit to locate. + +**Returns** + +**A 2-tuple. The first element (`index`)** + +contains the index at which the `Bit` can be found (in either `qubits`, `clbits`, depending on its type). The second element (`registers`) is a list of `(register, index)` pairs with an entry for each `Register` in the circuit which contains the `Bit` (and the index in the `Register` at which it can be found). + +**Return type** + +namedtuple(int, List\[Tuple(Register, int)]) + +**Raises:** + +DAGCircuitError: If the supplied `Bit` was of an unknown type. DAGCircuitError: If the supplied `Bit` could not be found on the circuit. + +### front\_layer + + + +`front_layer()` + +Return a list of op nodes in the first layer of this dag. + +### gate\_nodes + + + +`gate_nodes()` + +Get the list of gate nodes in the dag. + +**Returns** + +the list of DAGOpNodes that represent gates. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")] + +### has\_calibration\_for + + + +`has_calibration_for(node)` + +Return True if the dag has a calibration defined for the node operation. In this case, the operation does not need to be translated to the device basis. + +### idle\_wires + + + +`idle_wires(ignore=None)` + +Return idle wires. + +**Parameters** + +**ignore** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*)*) – List of node names to ignore. Default: \[] + +**Yields** + +*Bit* – Bit in idle wire. + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – If the DAG is invalid + +### is\_predecessor + + + +`is_predecessor(node, node_pred)` + +Checks if a second node is in the predecessors of node. + +### is\_successor + + + +`is_successor(node, node_succ)` + +Checks if a second node is in the successors of node. + +### layers + + + +`layers()` + +Yield a shallow view on a layer of this DAGCircuit for all d layers of this circuit. + +A layer is a circuit whose gates act on disjoint qubits, i.e., a layer has depth 1. The total number of layers equals the circuit depth d. The layers are indexed from 0 to d-1 with the earliest layer at index 0. The layers are constructed using a greedy algorithm. Each returned layer is a dict containing \{“graph”: circuit graph, “partition”: list of qubit lists}. + +The returned layer contains new (but semantically equivalent) DAGOpNodes, DAGInNodes, and DAGOutNodes. These are not the same as nodes of the original dag, but are equivalent via DAGNode.semantic\_eq(node1, node2). + +TODO: Gates that use the same cbits will end up in different layers as this is currently implemented. This may not be the desired behavior. + +### longest\_path + + + +`longest_path()` + +Returns the longest path in the dag as a list of DAGOpNodes, DAGInNodes, and DAGOutNodes. + +### multi\_qubit\_ops + + + +`multi_qubit_ops()` + +Get list of 3+ qubit operations. Ignore directives like snapshot and barrier. + +### multigraph\_layers + + + +`multigraph_layers()` + +Yield layers of the multigraph. + +### named\_nodes + + + +`named_nodes(*names)` + +Get the set of “op” nodes with the given name. + +### node + + + +`node(node_id)` + +Get the node in the dag. + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Node identifier. + +**Returns** + +the node. + +**Return type** + +node + +### nodes + + + +`nodes()` + +Iterator for node values. + +**Yields** + +*node* – the node. + +### nodes\_on\_wire + + + +`nodes_on_wire(wire, only_ops=False)` + +Iterator for nodes that affect a given wire. + +**Parameters** + +* **wire** ([*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")) – the wire to be looked at. +* **only\_ops** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if only the ops nodes are wanted; otherwise, all nodes are returned. + +**Yields** + +*Iterator* – the successive nodes on the given wire + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if the given wire doesn’t exist in the DAG + +### num\_clbits + + + +`num_clbits()` + +Return the total number of classical bits used by the circuit. + +### num\_qubits + + + +`num_qubits()` + +Return the total number of qubits used by the circuit. num\_qubits() replaces former use of width(). DAGCircuit.width() now returns qubits + clbits for consistency with Circuit.width() \[qiskit-terra #2564]. + +### num\_tensor\_factors + + + +`num_tensor_factors()` + +Compute how many components the circuit can decompose into. + +### op\_nodes + + + +`op_nodes(op=None, include_directives=True)` + +Get the list of “op” nodes in the dag. + +**Parameters** + +* **op** ([*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")) – [`qiskit.circuit.Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") subclass op nodes to return. If None, return all op nodes. +* **include\_directives** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – include barrier, snapshot etc. + +**Returns** + +the list of node ids containing the given op. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")] + +### predecessors + + + +`predecessors(node)` + +Returns iterator of the predecessors of a node as DAGOpNodes and DAGInNodes. + +### properties + + + +`properties()` + +Return a dictionary of circuit properties. + +### quantum\_causal\_cone + + + +`quantum_causal_cone(qubit)` + +Returns causal cone of a qubit. + +A qubit’s causal cone is the set of qubits that can influence the output of that qubit through interactions, whether through multi-qubit gates or operations. Knowing the causal cone of a qubit can be useful when debugging faulty circuits, as it can help identify which wire(s) may be causing the problem. + +This method does not consider any classical data dependency in the `DAGCircuit`, classical bit wires are ignored for the purposes of building the causal cone. + +**Parameters** + +**qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – The output qubit for which we want to find the causal cone. + +**Returns** + +The set of qubits whose interactions affect `qubit`. + +**Return type** + +Set\[[Qubit](qiskit.circuit.Qubit "qiskit.circuit.Qubit")] + +### quantum\_predecessors + + + +`quantum_predecessors(node)` + +Returns iterator of the predecessors of a node that are connected by a quantum edge as DAGOpNodes and DAGInNodes. + +### quantum\_successors + + + +`quantum_successors(node)` + +Returns iterator of the successors of a node that are connected by a quantum edge as Opnodes and DAGOutNodes. + +### remove\_all\_ops\_named + + + +`remove_all_ops_named(opname)` + +Remove all operation nodes with the given name. + +### remove\_ancestors\_of + + + +`remove_ancestors_of(node)` + +Remove all of the ancestor operation nodes of node. + +### remove\_clbits + + + +`remove_clbits(*clbits)` + +Remove classical bits from the circuit. All bits MUST be idle. Any registers with references to at least one of the specified bits will also be removed. + +**Parameters** + +**clbits** (*List\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – The bits to remove. + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – a clbit is not a [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit"), is not in the circuit, or is not idle. + +### remove\_cregs + + + +`remove_cregs(*cregs)` + +Remove classical registers from the circuit, leaving underlying bits in place. + +**Raises** + +* [**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – a creg is not a ClassicalRegister, or is not in +* **the circuit.** – + +### remove\_descendants\_of + + + +`remove_descendants_of(node)` + +Remove all of the descendant operation nodes of node. + +### remove\_nonancestors\_of + + + +`remove_nonancestors_of(node)` + +Remove all of the non-ancestors operation nodes of node. + +### remove\_nondescendants\_of + + + +`remove_nondescendants_of(node)` + +Remove all of the non-descendants operation nodes of node. + +### remove\_op\_node + + + +`remove_op_node(node)` + +Remove an operation node n. + +Add edges from predecessors to successors. + +### remove\_qregs + + + +`remove_qregs(*qregs)` + +Remove classical registers from the circuit, leaving underlying bits in place. + +**Raises** + +* [**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – a qreg is not a QuantumRegister, or is not in +* **the circuit.** – + +### remove\_qubits + + + +`remove_qubits(*qubits)` + +Remove quantum bits from the circuit. All bits MUST be idle. Any registers with references to at least one of the specified bits will also be removed. + +**Parameters** + +**qubits** (*List\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – The bits to remove. + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – a qubit is not a [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit"), is not in the circuit, or is not idle. + +### replace\_block\_with\_op + + + +`replace_block_with_op(node_block, op, wire_pos_map, cycle_check=True)` + +Replace a block of nodes with a single node. + +This is used to consolidate a block of DAGOpNodes into a single operation. A typical example is a block of gates being consolidated into a single `UnitaryGate` representing the unitary matrix of the block. + +**Parameters** + +* **node\_block** (*List\[*[*DAGNode*](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.DAGNode")*]*) – A list of dag nodes that represents the node block to be replaced +* **op** ([*qiskit.circuit.Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation")) – The operation to replace the block with +* **wire\_pos\_map** (*Dict\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The dictionary mapping the bits to their positions in the output `qargs` or `cargs`. This is necessary to reconstruct the arg order over multiple gates in the combined single op node. If a [`Bit`](qiskit.circuit.Bit "qiskit.circuit.Bit") is not in the dictionary, it will not be added to the args; this can be useful when dealing with control-flow operations that have inherent bits in their `condition` or `target` fields. +* **cycle\_check** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set to True this method will check that replacing the provided `node_block` with a single node would introduce a cycle (which would invalidate the `DAGCircuit`) and will raise a `DAGCircuitError` if a cycle would be introduced. This checking comes with a run time penalty. If you can guarantee that your input `node_block` is a contiguous block and won’t introduce a cycle when it’s contracted to a single node, this can be set to `False` to improve the runtime performance of this method. + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if `cycle_check` is set to `True` and replacing the specified block introduces a cycle or if `node_block` is empty. + +**Returns** + +The op node that replaces the block. + +**Return type** + +[DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") + +### reverse\_ops + + + +`reverse_ops()` + +Reverse the operations in the `self` circuit. + +**Returns** + +the reversed dag. + +**Return type** + +[DAGCircuit](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### separable\_circuits + + + +`separable_circuits(remove_idle_qubits=False)` + +Decompose the circuit into sets of qubits with no gates connecting them. + +**Parameters** + +**remove\_idle\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Flag denoting whether to remove idle qubits from the separated circuits. If `False`, each output circuit will contain the same number of qubits as `self`. + +**Returns** + +**The circuits resulting from separating `self` into sets** + +of disconnected qubits + +**Return type** + +List\[[DAGCircuit](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")] + +Each [`DAGCircuit`](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") instance returned by this method will contain the same number of clbits as `self`. The global phase information in `self` will not be maintained in the subcircuits returned by this method. + +### serial\_layers + + + +`serial_layers()` + +Yield a layer for all gates of this circuit. + +A serial layer is a circuit with one gate. The layers have the same structure as in layers(). + +### size + + + +`size(*, recurse=False)` + +Return the number of operations. If there is control flow present, this count may only be an estimate, as the complete control-flow path cannot be statically known. + +**Parameters** + +**recurse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True`, then recurse into control-flow operations. For loops with known-length iterators are counted unrolled. If-else blocks sum both of the two branches. While loops are counted as if the loop body runs once only. Defaults to `False` and raises [`DAGCircuitError`](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") if any control flow is present, to avoid silently returning a mostly meaningless number. + +**Returns** + +the circuit size + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if an unknown [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp") is present in a call with `recurse=True`, or any control flow is present in a non-recursive call. + +### substitute\_node + + + +`substitute_node(node, op, inplace=False, propagate_condition=True)` + +Replace an DAGOpNode with a single operation. qargs, cargs and conditions for the new operation will be inferred from the node to be replaced. The new operation will be checked to match the shape of the replaced operation. + +**Parameters** + +* **node** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")) – Node to be replaced +* **op** ([*qiskit.circuit.Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation")) – The [`qiskit.circuit.Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") instance to be added to the DAG +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional, default False. If True, existing DAG node will be modified to include op. Otherwise, a new DAG node will be used. +* **propagate\_condition** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional, default True. If True, a condition on the `node` to be replaced will be applied to the new `op`. This is the legacy behaviour. If either node is a control-flow operation, this will be ignored. If the `op` already has a condition, [`DAGCircuitError`](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") is raised. + +**Returns** + +the new node containing the added operation. + +**Return type** + +[DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode") + +**Raises** + +* [**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – If replacement operation was incompatible with +* **location**\*\* of \*\***target node.** – + +### substitute\_node\_with\_dag + + + +`substitute_node_with_dag(node, input_dag, wires=None, propagate_condition=True)` + +Replace one node with dag. + +**Parameters** + +* **node** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")) – node to substitute +* **input\_dag** ([*DAGCircuit*](#qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – circuit that will substitute the node +* **wires** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*] | Dict\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*,* [*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – gives an order for (qu)bits in the input circuit. If a list, then the bits refer to those in the `input_dag`, and the order gets matched to the node wires by qargs first, then cargs, then conditions. If a dictionary, then a mapping of bits in the `input_dag` to those that the `node` acts on. +* **propagate\_condition** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` (default), then any `condition` attribute on the operation within `node` is propagated to each node in the `input_dag`. If `False`, then the `input_dag` is assumed to faithfully implement suitable conditional logic already. This is ignored for [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp")s (i.e. treated as if it is `False`); replacements of those must already fulfil the same conditional logic or this function would be close to useless for them. + +**Returns** + +maps node IDs from input\_dag to their new node incarnations in self. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if met with unexpected predecessor/successors + +### successors + + + +`successors(node)` + +Returns iterator of the successors of a node as DAGOpNodes and DAGOutNodes. + +### swap\_nodes + + + +`swap_nodes(node1, node2)` + +Swap connected nodes e.g. due to commutation. + +**Parameters** + +* **node1** (*OpNode*) – predecessor node +* **node2** (*OpNode*) – successor node + +**Raises** + +[**DAGCircuitError**](dagcircuit#qiskit.dagcircuit.DAGCircuitError "qiskit.dagcircuit.DAGCircuitError") – if either node is not an OpNode or nodes are not connected + +### topological\_nodes + + + +`topological_nodes(key=None)` + +Yield nodes in topological order. + +**Parameters** + +**key** (*Callable*) – A callable which will take a DAGNode object and return a string sort key. If not specified the `sort_key` attribute will be used as the sort key for each node. + +**Returns** + +node in topological order + +**Return type** + +generator([DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode"), [DAGInNode](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode"), or [DAGOutNode](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) + +### topological\_op\_nodes + + + +`topological_op_nodes(key=None)` + +Yield op nodes in topological order. + +Allowed to pass in specific key to break ties in top order + +**Parameters** + +**key** (*Callable*) – A callable which will take a DAGNode object and return a string sort key. If not specified the `sort_key` attribute will be used as the sort key for each node. + +**Returns** + +op node in topological order + +**Return type** + +generator([DAGOpNode](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")) + +### two\_qubit\_ops + + + +`two_qubit_ops()` + +Get list of 2 qubit operations. Ignore directives like snapshot and barrier. + +### width + + + +`width()` + +Return the total number of qubits + clbits used by the circuit. This function formerly returned the number of qubits by the calculation return len(self.\_wires) - self.num\_clbits() but was changed by issue #2564 to return number of qubits + clbits with the new function DAGCircuit.num\_qubits replacing the former semantic of DAGCircuit.width(). + diff --git a/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDepNode.md b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDepNode.md new file mode 100644 index 00000000000..de783da0179 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDepNode.md @@ -0,0 +1,117 @@ +--- +title: DAGDepNode +description: API reference for qiskit.dagcircuit.DAGDepNode +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.dagcircuit.DAGDepNode +--- + +# DAGDepNode + + + +`qiskit.dagcircuit.DAGDepNode(type=None, op=None, name=None, qargs=(), cargs=(), successors=None, predecessors=None, reachable=None, matchedwith=None, successorstovisit=None, isblocked=None, qindices=None, cindices=None, nid=-1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/dagdepnode.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Object to represent the information at a node in the DAGDependency(). + +It is used as the return value from \*\_nodes() functions and can be supplied to functions that take a node. + +## Attributes + + + +### type + + + +### name + + + +### cargs + + + +### sort\_key + + + +### node\_id + + + +### successors + + + +### predecessors + + + +### reachable + + + +### matchedwith + + + +### isblocked + + + +### successorstovisit + + + +### qindices + + + +### cindices + + + +### op + +Returns the Instruction object corresponding to the op for the node, else None + + + +### qargs + +Returns list of Qubit, else an empty list. + +## Methods + +### copy + + + +`copy()` + +Function to copy a DAGDepNode object. :returns: a copy of a DAGDepNode object. :rtype: DAGDepNode + +### semantic\_eq + + + +`static semantic_eq(node1, node2)` + +Check if DAG nodes are considered equivalent, e.g., as a node\_match for nx.is\_isomorphic. + +**Parameters** + +* **node1** ([*DAGDepNode*](#qiskit.dagcircuit.DAGDepNode "qiskit.dagcircuit.DAGDepNode")) – A node to compare. +* **node2** ([*DAGDepNode*](#qiskit.dagcircuit.DAGDepNode "qiskit.dagcircuit.DAGDepNode")) – The other node to compare. + +**Returns** + +If node1 == node2 + +**Return type** + +[Bool](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool") + diff --git a/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDependency.md b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDependency.md new file mode 100644 index 00000000000..dfa87146fa4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGDependency.md @@ -0,0 +1,390 @@ +--- +title: DAGDependency +description: API reference for qiskit.dagcircuit.DAGDependency +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.dagcircuit.DAGDependency +--- + +# DAGDependency + + + +`qiskit.dagcircuit.DAGDependency`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/dagdependency.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Object to represent a quantum circuit as a Directed Acyclic Graph (DAG) via operation dependencies (i.e. lack of commutation). + +The nodes in the graph are operations represented by quantum gates. The edges correspond to non-commutation between two operations (i.e. a dependency). A directed edge from node A to node B means that operation A does not commute with operation B. The object’s methods allow circuits to be constructed. + +The nodes in the graph have the following attributes: ‘operation’, ‘successors’, ‘predecessors’. + +**Example:** + +Bell circuit with no measurement. + +```python + ┌───┐ +qr_0: ┤ H ├──■── + └───┘┌─┴─┐ +qr_1: ─────┤ X ├ + └───┘ +``` + +The dependency DAG for the above circuit is represented by two nodes. The first one corresponds to Hadamard gate, the second one to the CNOT gate as the gates do not commute there is an edge between the two nodes. + +**Reference:** + +\[1] Iten, R., Moyard, R., Metger, T., Sutter, D. and Woerner, S., 2020. Exact and practical pattern matching for quantum circuit optimization. [arXiv:1909.05270](https://arxiv.org/abs/1909.05270) + +Create an empty DAGDependency. + +## Attributes + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}`. + + + +### global\_phase + +Return the global phase of the circuit. + +## Methods + +### add\_clbits + + + +`add_clbits(clbits)` + +Add individual clbit wires. + +### add\_creg + + + +`add_creg(creg)` + +Add clbits in a classical register. + +### add\_op\_node + + + +`add_op_node(operation, qargs, cargs)` + +Add a DAGDepNode to the graph and update the edges. + +**Parameters** + +* **operation** ([*qiskit.circuit.Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation")) – operation as a quantum gate +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*]*) – list of qubits on which the operation acts +* **cargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Clbit*](qiskit.circuit.Clbit "qiskit.circuit.Clbit")*]*) – list of classical wires to attach to + +### add\_qreg + + + +`add_qreg(qreg)` + +Add qubits in a quantum register. + +### add\_qubits + + + +`add_qubits(qubits)` + +Add individual qubit wires. + +### copy + + + +`copy()` + +Function to copy a DAGDependency object. :returns: a copy of a DAGDependency object. :rtype: DAGDependency + +### depth + + + +`depth()` + +Return the circuit depth. :returns: the circuit depth :rtype: int + +### direct\_predecessors + + + +`direct_predecessors(node_id)` + +Direct predecessors id of a given node as sorted list. + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. + +**Returns** + +direct predecessors id as a sorted list + +**Return type** + +List + +### direct\_successors + + + +`direct_successors(node_id)` + +Direct successors id of a given node as sorted list. + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. + +**Returns** + +direct successors id as a sorted list + +**Return type** + +List + +### draw + + + +`draw(scale=0.7, filename=None, style='color')` + +Draws the DAGDependency graph. + +This function needs pydot \<[https://github.com/erocarrera/pydot](https://github.com/erocarrera/pydot)>, which in turn needs Graphviz \<[https://www.graphviz.org/](https://www.graphviz.org/)>\` to be installed. + +**Parameters** + +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – scaling factor +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to (format inferred from name) +* **style** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – ‘plain’: B\&W graph ‘color’ (default): color input/output/op nodes + +**Returns** + +if in Jupyter notebook and not saving to file, otherwise None. + +**Return type** + +Ipython.display.Image + +### get\_all\_edges + + + +`get_all_edges()` + +Enumeration of all edges. + +**Returns** + +corresponding to the label. + +**Return type** + +List + +### get\_edges + + + +`get_edges(src_id, dest_id)` + +Edge enumeration between two nodes through method get\_all\_edge\_data. + +**Parameters** + +* **src\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of the first node. +* **dest\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of the second node. + +**Returns** + +corresponding to all edges between the two nodes. + +**Return type** + +List + +### get\_in\_edges + + + +`get_in_edges(node_id)` + +Enumeration of all incoming edges for a given node. + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. + +**Returns** + +corresponding incoming edges data. + +**Return type** + +List + +### get\_node + + + +`get_node(node_id)` + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. + +**Returns** + +corresponding to the label. + +**Return type** + +node + +### get\_nodes + + + +`get_nodes()` + +**Returns** + +iterator over all the nodes. + +**Return type** + +generator([dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) + +### get\_out\_edges + + + +`get_out_edges(node_id)` + +Enumeration of all outgoing edges for a given node. + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. + +**Returns** + +corresponding outgoing edges data. + +**Return type** + +List + +### predecessors + + + +`predecessors(node_id)` + +Predecessors id of a given node as sorted list. + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. + +**Returns** + +all predecessors id as a sorted list + +**Return type** + +List + +### replace\_block\_with\_op + + + +`replace_block_with_op(node_block, op, wire_pos_map, cycle_check=True)` + +Replace a block of nodes with a single node. + +This is used to consolidate a block of DAGDepNodes into a single operation. A typical example is a block of CX and SWAP gates consolidated into a LinearFunction. This function is an adaptation of a similar function from DAGCircuit. + +It is important that such consolidation preserves commutativity assumptions present in DAGDependency. As an example, suppose that every node in a block \[A, B, C, D] commutes with another node E. Let F be the consolidated node, F = A o B o C o D. Then F also commutes with E, and thus the result of replacing \[A, B, C, D] by F results in a valid DAGDependency. That is, any deduction about commutativity in consolidated DAGDependency is correct. On the other hand, suppose that at least one of the nodes, say B, does not commute with E. Then the consolidated DAGDependency would imply that F does not commute with E. Even though F and E may actually commute, it is still safe to assume that they do not. That is, the current implementation of consolidation may lead to suboptimal but not to incorrect results. + +**Parameters** + +* **node\_block** (*List\[*[*DAGDepNode*](qiskit.dagcircuit.DAGDepNode "qiskit.dagcircuit.DAGDepNode")*]*) – A list of dag nodes that represents the node block to be replaced +* **op** ([*qiskit.circuit.Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation")) – The operation to replace the block with +* **wire\_pos\_map** (*Dict\[*[*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The dictionary mapping the qarg to the position. This is necessary to reconstruct the qarg order over multiple gates in the combined single op node. +* **cycle\_check** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set to True this method will check that replacing the provided `node_block` with a single node would introduce a cycle (which would invalidate the `DAGDependency`) and will raise a `DAGDependencyError` if a cycle would be introduced. This checking comes with a run time penalty. If you can guarantee that your input `node_block` is a contiguous block and won’t introduce a cycle when it’s contracted to a single node, this can be set to `False` to improve the runtime performance of this method. + +**Raises** + +[**DAGDependencyError**](dagcircuit#qiskit.dagcircuit.DAGDependencyError "qiskit.dagcircuit.DAGDependencyError") – if `cycle_check` is set to `True` and replacing the specified block introduces a cycle or if `node_block` is empty. + +### size + + + +`size()` + +Returns the number of gates in the circuit + +### successors + + + +`successors(node_id)` + +Successors id of a given node as sorted list. + +**Parameters** + +**node\_id** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – label of considered node. + +**Returns** + +all successors id as a sorted list + +**Return type** + +List + +### to\_retworkx + + + +`to_retworkx()` + +Returns the DAGDependency in retworkx format. + +### topological\_nodes + + + +`topological_nodes()` + +Yield nodes in topological order. + +**Returns** + +node in topological order. + +**Return type** + +generator([DAGNode](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.DAGNode")) + diff --git a/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGInNode.md b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGInNode.md new file mode 100644 index 00000000000..b8d32d60992 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGInNode.md @@ -0,0 +1,55 @@ +--- +title: DAGInNode +description: API reference for qiskit.dagcircuit.DAGInNode +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.dagcircuit.DAGInNode +--- + +# DAGInNode + + + +`qiskit.dagcircuit.DAGInNode(wire)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/dagnode.py "view source code") + +Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") + +Object to represent an incoming wire node in the DAGCircuit. + +Create an incoming node + +## Attributes + + + +### wire + + + +### sort\_key + +## Methods + +### semantic\_eq + + + +`static semantic_eq(node1, node2, bit_indices1, bit_indices2)` + +Check if DAG nodes are considered equivalent, e.g., as a node\_match for [`rustworkx.is_isomorphic_node_match()`](https://www.rustworkx.org/apiref/rustworkx.is_isomorphic_node_match.html#rustworkx.is_isomorphic_node_match "(in rustworkx v0.14.0)"). + +**Parameters** + +* **node1** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](#qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – A node to compare. +* **node2** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](#qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – The other node to compare. +* **bit\_indices1** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node1 +* **bit\_indices2** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node2 + +**Returns** + +If node1 == node2 + +**Return type** + +[Bool](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool") + diff --git a/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGNode.md b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGNode.md new file mode 100644 index 00000000000..5f8679d3a11 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGNode.md @@ -0,0 +1,45 @@ +--- +title: DAGNode +description: API reference for qiskit.dagcircuit.DAGNode +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.dagcircuit.DAGNode +--- + +# DAGNode + + + +`qiskit.dagcircuit.DAGNode(nid=-1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/dagnode.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Parent class for DAGOpNode, DAGInNode, and DAGOutNode. + +Create a node + +## Methods + +### semantic\_eq + + + +`static semantic_eq(node1, node2, bit_indices1, bit_indices2)` + +Check if DAG nodes are considered equivalent, e.g., as a node\_match for [`rustworkx.is_isomorphic_node_match()`](https://www.rustworkx.org/apiref/rustworkx.is_isomorphic_node_match.html#rustworkx.is_isomorphic_node_match "(in rustworkx v0.14.0)"). + +**Parameters** + +* **node1** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – A node to compare. +* **node2** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – The other node to compare. +* **bit\_indices1** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node1 +* **bit\_indices2** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node2 + +**Returns** + +If node1 == node2 + +**Return type** + +[Bool](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool") + diff --git a/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOpNode.md b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOpNode.md new file mode 100644 index 00000000000..bcef359289d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOpNode.md @@ -0,0 +1,69 @@ +--- +title: DAGOpNode +description: API reference for qiskit.dagcircuit.DAGOpNode +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.dagcircuit.DAGOpNode +--- + +# DAGOpNode + + + +`qiskit.dagcircuit.DAGOpNode(op, qargs=(), cargs=(), dag=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/dagnode.py "view source code") + +Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") + +Object to represent an Instruction at a node in the DAGCircuit. + +Create an Instruction node + +## Attributes + + + +### op + + + +### qargs + + + +### cargs + + + +### sort\_key + + + +### name + +Returns the Instruction name corresponding to the op for this node + +## Methods + +### semantic\_eq + + + +`static semantic_eq(node1, node2, bit_indices1, bit_indices2)` + +Check if DAG nodes are considered equivalent, e.g., as a node\_match for [`rustworkx.is_isomorphic_node_match()`](https://www.rustworkx.org/apiref/rustworkx.is_isomorphic_node_match.html#rustworkx.is_isomorphic_node_match "(in rustworkx v0.14.0)"). + +**Parameters** + +* **node1** ([*DAGOpNode*](#qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – A node to compare. +* **node2** ([*DAGOpNode*](#qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – The other node to compare. +* **bit\_indices1** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node1 +* **bit\_indices2** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node2 + +**Returns** + +If node1 == node2 + +**Return type** + +[Bool](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool") + diff --git a/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOutNode.md b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOutNode.md new file mode 100644 index 00000000000..e74b7d0f66a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.dagcircuit.DAGOutNode.md @@ -0,0 +1,55 @@ +--- +title: DAGOutNode +description: API reference for qiskit.dagcircuit.DAGOutNode +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.dagcircuit.DAGOutNode +--- + +# DAGOutNode + + + +`qiskit.dagcircuit.DAGOutNode(wire)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/dagcircuit/dagnode.py "view source code") + +Bases: [`DAGNode`](qiskit.dagcircuit.DAGNode "qiskit.dagcircuit.dagnode.DAGNode") + +Object to represent an outgoing wire node in the DAGCircuit. + +Create an outgoing node + +## Attributes + + + +### wire + + + +### sort\_key + +## Methods + +### semantic\_eq + + + +`static semantic_eq(node1, node2, bit_indices1, bit_indices2)` + +Check if DAG nodes are considered equivalent, e.g., as a node\_match for [`rustworkx.is_isomorphic_node_match()`](https://www.rustworkx.org/apiref/rustworkx.is_isomorphic_node_match.html#rustworkx.is_isomorphic_node_match "(in rustworkx v0.14.0)"). + +**Parameters** + +* **node1** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](#qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – A node to compare. +* **node2** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")*,* [*DAGInNode*](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")*,* [*DAGOutNode*](#qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")) – The other node to compare. +* **bit\_indices1** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node1 +* **bit\_indices2** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Dictionary mapping Bit instances to their index within the circuit containing node2 + +**Returns** + +If node1 == node2 + +**Return type** + +[Bool](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool") + diff --git a/docs/api/qiskit/0.46/qiskit.extensions.SingleQubitUnitary.md b/docs/api/qiskit/0.46/qiskit.extensions.SingleQubitUnitary.md new file mode 100644 index 00000000000..618f334a443 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.extensions.SingleQubitUnitary.md @@ -0,0 +1,424 @@ +--- +title: SingleQubitUnitary +description: API reference for qiskit.extensions.SingleQubitUnitary +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.extensions.SingleQubitUnitary +--- + +# SingleQubitUnitary + + + +`qiskit.extensions.SingleQubitUnitary(unitary_matrix, mode='ZYZ', up_to_diagonal=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/extensions/quantum_initializer/squ.py "view source code") + +Bases: [`Gate`](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +Single-qubit unitary. + +**Parameters** + +* **unitary\_matrix** – $2 imes 2$ unitary (given as a (complex) `numpy.ndarray`). +* **mode** – determines the used decomposition by providing the rotation axes. +* **up\_to\_diagonal** – the single-qubit unitary is decomposed up to a diagonal matrix, i.e. a unitary $U'$ is implemented such that there exists a diagonal matrix $D$ with $U = D U'$. + +Create a new single qubit gate based on the unitary `u`. + + + The class `qiskit.extensions.quantum_initializer.squ.SingleQubitUnitary` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0 release. Instead, you can use qiskit.circuit.library.UnitaryGate. + + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.extensions.SingleQubitUnitary.base_class "qiskit.extensions.SingleQubitUnitary.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### diag + +Returns the diagonal gate D up to which the single-qubit unitary u is implemented. + +I.e. u=D.u’, where u’ is the unitary implemented by the found circuit. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation and handling of the arguments and its relationship. + +For example, `cx([q[0],q[1]], q[2])` means `cx(q[0], q[2]); cx(q[1], q[2])`. This method yields the arguments in the right grouping. In the given example: + +```python +in: [[q[0],q[1]], q[2]],[] +outs: [q[0], q[2]], [] + [q[1], q[2]], [] +``` + +The general broadcasting rules are: + +> * If len(qargs) == 1: +> +> ```python +> [q[0], q[1]] -> [q[0]],[q[1]] +> ``` +> +> * If len(qargs) == 2: +> +> ```python +> [[q[0], q[1]], [r[0], r[1]]] -> [q[0], r[0]], [q[1], r[1]] +> [[q[0]], [r[0], r[1]]] -> [q[0], r[0]], [q[0], r[1]] +> [[q[0], q[1]], [r[0]]] -> [q[0], r[0]], [q[1], r[0]] +> ``` +> +> * If len(qargs) >= 3: +> +> ```python +> [q[0], q[1]], [r[0], r[1]], ...] -> [q[0], r[0], ...], [q[1], r[1], ...] +> ``` + +**Parameters** + +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of quantum bit arguments. +* **cargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of classical bit arguments. + +**Returns** + +A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +**Return type** + +[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")\[[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")]] + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### control + + + +`control(num_ctrl_qubits=1, label=None, ctrl_state=None)` + +Return controlled version of gate. See [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") for usage. + +**Parameters** + +* **num\_ctrl\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of controls to add to gate (default: `1`) +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – optional gate label +* **ctrl\_state** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The control state in decimal or as a bitstring (e.g. `'111'`). If `None`, use `2**num_ctrl_qubits-1`. + +**Returns** + +Controlled version of gate. This default algorithm uses `num_ctrl_qubits-1` ancilla qubits so returns a gate of size `num_qubits + 2*num_ctrl_qubits - 1`. + +**Return type** + +[qiskit.circuit.ControlledGate](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – unrecognized mode or invalid ctrl\_state + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Return the inverse. + +Note that the resulting gate has an empty `params` property. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### power + + + +`power(exponent)` + +Creates a unitary gate as gate^exponent. + +**Parameters** + +**exponent** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Gate^exponent + +**Returns** + +To which to\_matrix is self.to\_matrix^exponent. + +**Return type** + +.library.UnitaryGate + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If Gate is not unitary + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_matrix + + + +`to_matrix()` + +Return a Numpy.array for the gate unitary matrix. + +**Returns** + +if the Gate subclass has a matrix definition. + +**Return type** + +np.ndarray + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If a Gate subclass does not implement this method an exception will be raised when this base class method is called. + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Single-qubit unitary gate parameter has to be an ndarray. + diff --git a/docs/api/qiskit/0.46/qiskit.extensions.Snapshot.md b/docs/api/qiskit/0.46/qiskit.extensions.Snapshot.md new file mode 100644 index 00000000000..6aa4e04a085 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.extensions.Snapshot.md @@ -0,0 +1,322 @@ +--- +title: Snapshot +description: API reference for qiskit.extensions.Snapshot +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.extensions.Snapshot +--- + +# Snapshot + + + +`qiskit.extensions.Snapshot(label, snapshot_type='statevector', num_qubits=0, num_clbits=0, params=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/extensions/simulator/snapshot.py "view source code") + +Bases: [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +Simulator snapshot instruction. + +Create new snapshot instruction. + + + The class `qiskit.extensions.simulator.snapshot.Snapshot` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0 release. The Snapshot instruction has been superseded by Qiskit Aer’s save instructions, see [https://qiskit.org/ecosystem/aer/apidocs/aer\_library.html#saving-simulator-data](https://qiskit.org/ecosystem/aer/apidocs/aer_library.html#saving-simulator-data). + + +**Parameters** + +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the snapshot label for result data. +* **snapshot\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the type of the snapshot. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits for the snapshot type \[Default: 0]. +* **num\_clbits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of classical bits for the snapshot type \[Default: 0]. +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – the parameters for snapshot\_type \[Default: None]. + +**Raises** + +[**ExtensionError**](extensions#qiskit.extensions.ExtensionError "qiskit.extensions.ExtensionError") – if snapshot label is invalid. + +## Attributes + + + +### base\_class + +Get the base class of this instruction. This is guaranteed to be in the inheritance tree of `self`. + +The “base class” of an instruction is the lowest class in its inheritance tree that the object should be considered entirely compatible with for \_all\_ circuit applications. This typically means that the subclass is defined purely to offer some sort of programmer convenience over the base class, and the base class is the “true” class for a behavioural perspective. In particular, you should *not* override [`base_class`](#qiskit.extensions.Snapshot.base_class "qiskit.extensions.Snapshot.base_class") if you are defining a custom version of an instruction that will be implemented differently by hardware, such as an alternative measurement strategy, or a version of a parametrised gate with a particular set of parameters for the purposes of distinguishing it in a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") from the full parametrised gate. + +This is often exactly equivalent to `type(obj)`, except in the case of singleton instances of standard-library instructions. These singleton instances are special subclasses of their base class, and this property will return that base. For example: + +```python +>>> isinstance(XGate(), XGate) +True +>>> type(XGate()) is XGate +False +>>> XGate().base_class is XGate +True +``` + +In general, you should not rely on the precise class of an instruction; within a given circuit, it is expected that `Instruction.name` should be a more suitable discriminator in most situations. + + + +### condition + +The classical condition on the instruction. + + + +### condition\_bits + +Get Clbits in condition. + + + +### decompositions + +Get the decompositions of the instruction from the SessionEquivalenceLibrary. + + + +### definition + +Return definition in terms of other basic gates. + + + +### duration + +Get the duration. + + + +### label + +Return instruction label + + + +### mutable + +Is this instance is a mutable unique instance or not. + +If this attribute is `False` the gate instance is a shared singleton and is not mutable. + + + +### name + +Return the name. + + + +### num\_clbits + +Return the number of clbits. + + + +### num\_qubits + +Return the number of qubits. + + + +### params + +return instruction params. + + + +### snapshot\_type + +Return snapshot type + + + +### unit + +Get the time unit of duration. + +## Methods + +### add\_decomposition + + + +`add_decomposition(decomposition)` + +Add a decomposition of the instruction to the SessionEquivalenceLibrary. + +### assemble + + + +`assemble()` + +Assemble a QasmQobjInstruction + +### broadcast\_arguments + + + +`broadcast_arguments(qargs, cargs)` + +Validation of the arguments. + +**Parameters** + +* **qargs** (*List*) – List of quantum bit arguments. +* **cargs** (*List*) – List of classical bit arguments. + +**Yields** + +*Tuple(List, List)* – A tuple with single arguments. + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If the input is not valid. For example, the number of arguments does not match the gate expectation. + +### c\_if + + + +`c_if(classical, val)` + +Set a classical equality condition on this instruction between the register or cbit `classical` and value `val`. + + + This is a setter method, not an additive one. Calling this multiple times will silently override any previously set condition; it does not stack. + + +### copy + + + +`copy(name=None)` + +Copy of the instruction. + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name to be given to the copied circuit, if `None` then the name stays the same. + +**Returns** + +a copy of the current instruction, with the name updated if it was provided + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### inverse + + + +`inverse()` + +Special case. Return self. + +### is\_parameterized + + + +`is_parameterized()` + +Return True .IFF. instruction is parameterized else False + +### qasm + + + +`qasm()` + +Return a default OpenQASM string for the instruction. + +Derived instructions may override this to print in a different format (e.g. `measure q[0] -> c[0];`). + + + The method `qiskit.circuit.instruction.Instruction.qasm()` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Correct exporting to OpenQASM 2 is the responsibility of a larger exporter; it cannot safely be done on an object-by-object basis without context. No replacement will be provided, because the premise is wrong. + + +### repeat + + + +`repeat(n)` + +Creates an instruction with gate repeated n amount of times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of times to repeat the instruction + +**Returns** + +Containing the definition. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**CircuitError**](circuit#qiskit.circuit.CircuitError "qiskit.circuit.CircuitError") – If n \< 1. + +### reverse\_ops + + + +`reverse_ops()` + +For a composite instruction, reverse the order of sub-instructions. + +This is done by recursively reversing all sub-instructions. It does not invert any gate. + +**Returns** + +**a new instruction with** + +sub-instructions reversed. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### soft\_compare + + + +`soft_compare(other)` + +Soft comparison between gates. Their names, number of qubits, and classical bit numbers must match. The number of parameters must match. Each parameter is compared. If one is a ParameterExpression then it is not taken into account. + +**Parameters** + +**other** (*instruction*) – other instruction. + +**Returns** + +are self and other equal up to parameter expressions. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### to\_mutable + + + +`to_mutable()` + +Return a mutable copy of this gate. + +This method will return a new mutable copy of this gate instance. If a singleton instance is being used this will be a new unique instance that can be mutated. If the instance is already mutable it will be a deepcopy of that instance. + +### validate\_parameter + + + +`validate_parameter(parameter)` + +Instruction parameters has no validation or normalization. + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.OperatorBase.md b/docs/api/qiskit/0.46/qiskit.opflow.OperatorBase.md new file mode 100644 index 00000000000..9cb5f188870 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.OperatorBase.md @@ -0,0 +1,420 @@ +--- +title: OperatorBase +description: API reference for qiskit.opflow.OperatorBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.OperatorBase +--- + +# OperatorBase + + + +`qiskit.opflow.OperatorBase`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/operator_base.py "view source code") + +Bases: `StarAlgebraMixin`, `TensorMixin`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Deprecated: A base class for all Operators: PrimitiveOps, StateFns, ListOps, etc. Operators are defined as functions which take one complex binary function to another. These complex binary functions are represented by StateFns, which are themselves a special class of Operators taking only the `Zero` StateFn to the complex binary function they represent. + +Operators can be used to construct complicated functions and computation, and serve as the building blocks for algorithms. + + + The class `qiskit.opflow.operator_base.OperatorBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + +The number of qubits over which the Operator is defined. If `op.num_qubits == 5`, then `op.eval('1' * 5)` will be valid, but `op.eval('11')` will not. + +**Returns** + +The number of qubits accepted by the Operator’s underlying function. + + + +### parameters + +Return a set of Parameter objects contained in the Operator. + + + +### settings + +Return settings of this object in a dictionary. + +You can, for example, use this `settings` dictionary to serialize the object in JSON format, if the JSON encoder you use supports all types in the dictionary. + +**Returns** + +Object settings in a dictionary. + +## Methods + +### add + + + +`abstract add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`abstract adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### assign\_parameters + + + +`abstract assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]]*) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### bind\_parameters + + + +`bind_parameters(param_dict)` + +Same as assign\_parameters, but maintained for consistency with QuantumCircuit in Terra (which has both assign\_parameters and bind\_parameters). + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### compose + + + +`abstract compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### copy + + + +`copy()` + +Return a deep copy of the Operator. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`abstract equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`abstract eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### is\_hermitian + + + +`is_hermitian()` + +Return True if the operator is hermitian. + +Returns: Boolean value + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### mul + + + +`abstract mul(scalar)` + +Returns the scalar multiplication of the Operator, overloaded by `*`, including support for Terra’s `Parameters`, which can be bound to values later (via `bind_parameters`). + +**Parameters** + +**scalar** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The real or complex scalar by which to multiply the Operator, or the `ParameterExpression` to serve as a placeholder for a scalar factor. + +**Returns** + +An `OperatorBase` equivalent to product of self and scalar. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### neg + + + +`neg()` + +Return the Operator’s negation, effectively just multiplying by -1.0, overloaded by `-`. + +**Returns** + +An `OperatorBase` equivalent to the negation of self. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### permute + + + +`abstract permute(permutation)` + +Permutes the qubits of the operator. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j should be permuted to position permutation\[j]. + +**Returns** + +A new OperatorBase containing the permuted operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if indices do not define a new index for each qubit. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### primitive\_strings + + + +`abstract primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`abstract reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +### tensor + + + +`abstract tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensorpower + + + +`abstract tensorpower(other)` + +Return tensor product with self multiple times, overloaded by `^`. + +**Parameters** + +**other** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The int number of times to tensor product self with itself via `tensorpower`. + +**Returns** + +An `OperatorBase` equivalent to the tensorpower of self by other. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### to\_circuit\_op + + + +`abstract to_circuit_op()` + +Returns a `CircuitOp` equivalent to this Operator. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_matrix + + + +`abstract to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`abstract to_matrix_op(massive=False)` + +Returns a `MatrixOp` equivalent to this Operator. + +**Return type** + +[*OperatorBase*](#qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_spmatrix + + + +`to_spmatrix()` + +Return SciPy sparse matrix representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. + +**Returns** + +The SciPy `spmatrix` equivalent to this Operator. + +**Return type** + +*spmatrix* + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.converters.AbelianGrouper.md b/docs/api/qiskit/0.46/qiskit.opflow.converters.AbelianGrouper.md new file mode 100644 index 00000000000..2061204b164 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.converters.AbelianGrouper.md @@ -0,0 +1,74 @@ +--- +title: AbelianGrouper +description: API reference for qiskit.opflow.converters.AbelianGrouper +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.converters.AbelianGrouper +--- + +# AbelianGrouper + + + +`qiskit.opflow.converters.AbelianGrouper(traverse=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/converters/abelian_grouper.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: The AbelianGrouper converts SummedOps into a sum of Abelian sums. + +Meaning, it will traverse the Operator, and when it finds a SummedOp, it will evaluate which of the summed sub-Operators commute with one another. It will then convert each of the groups of commuting Operators into their own SummedOps, and return the sum-of-commuting-SummedOps. This is particularly useful for cases where mutually commuting groups can be handled similarly, as in the case of Pauli Expectations, where commuting Paulis have the same diagonalizing circuit rotation, or Pauli Evolutions, where commuting Paulis can be diagonalized together. + + + The class `qiskit.opflow.converters.abelian_grouper.AbelianGrouper` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +**traverse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to convert only the Operator passed to `convert`, or traverse down that Operator. + +## Methods + +### convert + + + +`convert(operator)` + +Check if operator is a SummedOp, in which case covert it into a sum of mutually commuting sums, or if the Operator contains sub-Operators and `traverse` is True, attempt to convert any sub-Operators. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to attempt to convert. + +**Returns** + +The converted Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### group\_subops + + + +`classmethod group_subops(list_op)` + +Given a ListOp, attempt to group into Abelian ListOps of the same type. + +**Parameters** + +**list\_op** ([*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") *|*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp")) – The Operator to group into Abelian groups + +**Returns** + +The grouped Operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – If any of list\_op’s sub-ops is not `PauliOp`. + +**Return type** + +[*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.converters.CircuitSampler.md b/docs/api/qiskit/0.46/qiskit.opflow.converters.CircuitSampler.md new file mode 100644 index 00000000000..0c2cdb7cccd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.converters.CircuitSampler.md @@ -0,0 +1,108 @@ +--- +title: CircuitSampler +description: API reference for qiskit.opflow.converters.CircuitSampler +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.converters.CircuitSampler +--- + +# CircuitSampler + + + +`qiskit.opflow.converters.CircuitSampler(backend, statevector=None, param_qobj=False, attach_results=False, caching='last')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/converters/circuit_sampler.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: The CircuitSampler traverses an Operator and converts any CircuitStateFns into approximations of the state function by a DictStateFn or VectorStateFn using a quantum backend. Note that in order to approximate the value of the CircuitStateFn, it must 1) send state function through a depolarizing channel, which will destroy all phase information and 2) replace the sampled frequencies with **square roots** of the frequency, rather than the raw probability of sampling (which would be the equivalent of sampling the **square** of the state function, per the Born rule. + +The CircuitSampler aggressively caches transpiled circuits to handle re-parameterization of the same circuit efficiently. If you are converting multiple different Operators, you are better off using a different CircuitSampler for each Operator to avoid cache thrashing. + + + The class `qiskit.opflow.converters.circuit_sampler.CircuitSampler` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *|*[*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.quantum_instance.QuantumInstance")) – The quantum backend or QuantumInstance to use to sample the circuits. +* **statevector** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If backend is a statevector backend, whether to replace the CircuitStateFns with DictStateFns (from the counts) or VectorStateFns (from the statevector). `None` will set this argument automatically based on the backend. +* **attach\_results** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to attach the data from the backend `Results` object for a given `` CircuitStateFn` `` to an `execution_results` field added the converted `DictStateFn` or `VectorStateFn`. +* **param\_qobj** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to use Aer’s parameterized Qobj capability to avoid re-assembling the circuits. +* **caching** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The caching strategy. Can be ‘last’ (default) to store the last operator that was converted, set to ‘all’ to cache all processed operators. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Set statevector or param\_qobj True when not supported by backend. + +## Attributes + + + +### quantum\_instance + +Returns the quantum instance. + +**Returns** + +The QuantumInstance used by the CircuitSampler + +## Methods + +### clear\_cache + + + +`clear_cache()` + +Clear the cache of sampled operator expressions. + +### convert + + + +`convert(operator, params=None)` + +Converts the Operator to one in which the CircuitStateFns are replaced by DictStateFns or VectorStateFns. Extracts the CircuitStateFns out of the Operator, caches them, calls `sample_circuits` below to get their converted replacements, and replaces the CircuitStateFns in operator with the replacement StateFns. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to convert +* **params** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]] | None*) – A dictionary mapping parameters to either single binding values or lists of binding values. + +**Returns** + +The converted Operator with CircuitStateFns replaced by DictStateFns or VectorStateFns. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if extracted circuits are empty. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### sample\_circuits + + + +`sample_circuits(circuit_sfns=None, param_bindings=None)` + +Samples the CircuitStateFns and returns a dict associating their `id()` values to their replacement DictStateFn or VectorStateFn. If param\_bindings is provided, the CircuitStateFns are broken into their parameterizations, and a list of StateFns is returned in the dict for each circuit `id()`. Note that param\_bindings is provided here in a different format than in `convert`, and lists of parameters within the dict is not supported, and only binding dicts which are valid to be passed into Terra can be included in this list. + +**Parameters** + +* **circuit\_sfns** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*CircuitStateFn*](qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn")*] | None*) – The list of CircuitStateFns to sample. +* **param\_bindings** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – The parameterizations to bind to each CircuitStateFn. + +**Returns** + +The dictionary mapping ids of the CircuitStateFns to their replacement StateFns. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if extracted circuits are empty. + +**Return type** + +[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"), [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*StateFn*](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn")]] + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.converters.ConverterBase.md b/docs/api/qiskit/0.46/qiskit.opflow.converters.ConverterBase.md new file mode 100644 index 00000000000..018e0dd800f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.converters.ConverterBase.md @@ -0,0 +1,44 @@ +--- +title: ConverterBase +description: API reference for qiskit.opflow.converters.ConverterBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.converters.ConverterBase +--- + +# ConverterBase + + + +`qiskit.opflow.converters.ConverterBase`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/converters/converter_base.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Deprecated: Converters take an Operator and return a new Operator, generally isomorphic in some way with the first, but with certain desired properties. For example, a converter may accept `CircuitOp` and return a `SummedOp` of `PauliOps` representing the circuit unitary. Converters may not have polynomial space or time scaling in their operations. On the contrary, many converters, such as a `MatrixExpectation` or `MatrixEvolution`, which convert `PauliOps` to `MatrixOps` internally, will require time or space exponential in the number of qubits unless a clever trick is known (such as the use of sparse matrices). + + + The class `qiskit.opflow.converters.converter_base.ConverterBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### convert + + + +`abstract convert(operator)` + +Accept the Operator and return the converted Operator + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to convert. + +**Returns** + +The converted Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.converters.DictToCircuitSum.md b/docs/api/qiskit/0.46/qiskit.opflow.converters.DictToCircuitSum.md new file mode 100644 index 00000000000..2ee3d728f50 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.converters.DictToCircuitSum.md @@ -0,0 +1,50 @@ +--- +title: DictToCircuitSum +description: API reference for qiskit.opflow.converters.DictToCircuitSum +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.converters.DictToCircuitSum +--- + +# DictToCircuitSum + + + +`qiskit.opflow.converters.DictToCircuitSum(traverse=True, convert_dicts=True, convert_vectors=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/converters/dict_to_circuit_sum.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: Converts `DictStateFns` or `VectorStateFns` to equivalent `CircuitStateFns` or sums thereof. The behavior of this class can be mostly replicated by calling `to_circuit_op` on an Operator, but with the added control of choosing whether to convert only `DictStateFns` or `VectorStateFns`, rather than both. + + + The class `qiskit.opflow.converters.dict_to_circuit_sum.DictToCircuitSum` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **traverse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to recurse down into Operators with internal sub-operators for conversion. +* **convert\_dicts** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to convert VectorStateFn. +* **convert\_vectors** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to convert DictStateFns. + +## Methods + +### convert + + + +`convert(operator)` + +Convert the Operator to `CircuitStateFns`, recursively if `traverse` is True. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to convert + +**Returns** + +The converted Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.converters.PauliBasisChange.md b/docs/api/qiskit/0.46/qiskit.opflow.converters.PauliBasisChange.md new file mode 100644 index 00000000000..be2c8656853 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.converters.PauliBasisChange.md @@ -0,0 +1,268 @@ +--- +title: PauliBasisChange +description: API reference for qiskit.opflow.converters.PauliBasisChange +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.converters.PauliBasisChange +--- + +# PauliBasisChange + + + +`qiskit.opflow.converters.PauliBasisChange(destination_basis=None, traverse=True, replacement_fn=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/converters/pauli_basis_change.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: Converter for changing Paulis into other bases. By default, the diagonal basis composed only of Pauli \{Z, I}^n is used as the destination basis to which to convert. Meaning, if a Pauli containing X or Y terms is passed in, which cannot be sampled or evolved natively on some Quantum hardware, the Pauli can be replaced by a composition of a change of basis circuit and a Pauli composed of only Z and I terms (diagonal), which can be evolved or sampled natively on the Quantum hardware. + +The replacement function determines how the `PauliOps` should be replaced by their computed change-of-basis `CircuitOps` and destination `PauliOps`. Several convenient out-of-the-box replacement functions have been added as static methods, such as `measurement_replacement_fn`. + +This class uses the typical basis change method found in most Quantum Computing textbooks (such as on page 210 of Nielsen and Chuang’s, “Quantum Computation and Quantum Information”, ISBN: 978-1-107-00217-3), which involves diagonalizing the single-qubit Paulis with H and S† gates, mapping the eigenvectors of the diagonalized origin Pauli to the diagonalized destination Pauli using CNOTS, and then de-diagonalizing any single qubit Paulis to their non-diagonal destination values. Many other methods are possible, as well as variations on this method, such as the placement of the CNOT chains. + + + The class `qiskit.opflow.converters.pauli_basis_change.PauliBasisChange` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **destination\_basis** ([*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") *| None*) – The Pauli into the basis of which the operators will be converted. If None is specified, the destination basis will be the diagonal (\{I, Z}^n) basis requiring only single qubit rotations. + +* **traverse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If true and the operator passed into convert contains sub-Operators, such as ListOp, traverse the Operator and apply the conversion to every applicable sub-operator within it. + +* **replacement\_fn** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – + + A function specifying what to do with the basis-change `CircuitOp` and destination `PauliOp` when converting an Operator and replacing converted values. By default, this will be + + > 1. For StateFns (or Measurements): replacing the StateFn with ComposedOp(StateFn(d), c) where c is the conversion circuit and d is the destination Pauli, so the overall beginning and ending operators are equivalent. + > 2. For non-StateFn Operators: replacing the origin p with c·d·c†, where c is the conversion circuit and d is the destination, so the overall beginning and ending operators are equivalent. + +## Attributes + + + +### destination + +The destination `PauliOp`, or `None` if using the default destination, the diagonal basis. + +## Methods + +### construct\_cnot\_chain + + + +`construct_cnot_chain(diag_pauli_op1, diag_pauli_op2)` + +Construct a `CircuitOp` (or `PauliOp` if equal to the identity) which takes the eigenvectors of `diag_pauli_op1` to the eigenvectors of `diag_pauli_op2`, assuming both are diagonal (or performing this operation on their diagonalized Paulis implicitly if not). This works by the insight that the eigenvalue of a diagonal Pauli’s eigenvector is equal to or -1 if the parity is 1 and 1 if the parity is 0, or 1 - (2 \* parity). Therefore, using CNOTs, we can write the parity of diag\_pauli\_op1’s significant bits onto some qubit, and then write out that parity onto diag\_pauli\_op2’s significant bits. + +**Parameters** + +* **diag\_pauli\_op1** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – The origin `PauliOp`. +* **diag\_pauli\_op2** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – The destination `PauliOp`. + +**Returns** + +The `PrimitiveOp` performs the mapping. + +**Return type** + +[*PrimitiveOp*](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + +### convert + + + +`convert(operator)` + +Given a `PauliOp`, or an Operator containing `PauliOps` if `_traverse` is True, converts each Pauli into the basis specified by self.\_destination and a basis-change-circuit, calls `replacement_fn` with these two Operators, and replaces the `PauliOps` with the output of `replacement_fn`. For example, for the built-in `operator_replacement_fn` below, each PauliOp p will be replaced by the composition of the basis-change Clifford `CircuitOp` c with the destination PauliOp d and c†, such that p = c·d·c†, up to global phase. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to convert. + +**Returns** + +The converted Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### get\_cob\_circuit + + + +`get_cob_circuit(origin)` + +Construct an Operator which maps the +1 and -1 eigenvectors of the origin Pauli to the +1 and -1 eigenvectors of the destination Pauli. It does so by + +1. converting any |i+⟩ or |i+⟩ eigenvector bits in the origin to |+⟩ and |-⟩ with S†s, then +2. converting any |+⟩ or |+⟩ eigenvector bits in the converted origin to |0⟩ and |1⟩ with Hs, then +3. writing the parity of the significant (Z-measured, rather than I) bits in the origin to a single “origin anchor bit,” using cnots, which will hold the parity of these bits, +4. swapping the parity of the pauli anchor bit into a destination anchor bit using a swap gate (only if they are different, if there are any bits which are significant in both origin and dest, we set both anchors to one of these bits to avoid a swap). +5. writing the parity of the destination anchor bit into the other significant bits of the destination, +6. converting the |0⟩ and |1⟩ significant eigenvector bits to |+⟩ and |-⟩ eigenvector bits in the destination where the destination demands it (e.g. pauli.x == true for a bit), using Hs 8) converting the |+⟩ and |-⟩ significant eigenvector bits to |i+⟩ and |i-⟩ eigenvector bits in the destination where the destination demands it (e.g. pauli.x == true and pauli.z == true for a bit), using Ss + +**Parameters** + +**origin** ([*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – The `Pauli` or `PauliOp` to map. + +**Returns** + +A tuple of a `PrimitiveOp` which equals the basis change mapping and a `PauliOp` which equals the destination basis. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Attempting to convert from non-Pauli origin. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Attempting to change a non-identity Pauli to an identity Pauli, or vice versa. + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*PrimitiveOp*](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp"), [*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")] + +### get\_diagonal\_pauli\_op + + + +`get_diagonal_pauli_op(pauli_op)` + +Get the diagonal `PualiOp` to which `pauli_op` could be rotated with only single-qubit operations. + +**Parameters** + +**pauli\_op** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – The `PauliOp` whose diagonal to compute. + +**Returns** + +The diagonal `PauliOp`. + +**Return type** + +[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") + +### get\_diagonalizing\_clifford + + + +`get_diagonalizing_clifford(pauli)` + +Construct a `CircuitOp` with only single-qubit gates which takes the eigenvectors of `pauli` to eigenvectors composed only of |0⟩ and |1⟩ tensor products. Equivalently, finds the basis-change circuit to take `pauli` to a diagonal `PauliOp` composed only of Z and I tensor products. + +Note, underlying Pauli bits are in Qiskit endianness, so we need to reverse before we begin composing with Operator flow. + +**Parameters** + +**pauli** ([*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – the `Pauli` or `PauliOp` to whose diagonalizing circuit to compute. + +**Returns** + +The diagonalizing `CircuitOp`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### get\_tpb\_pauli + + + +`get_tpb_pauli(list_op)` + +Gets the Pauli (not `PauliOp`!) whose diagonalizing single-qubit rotations is a superset of the diagonalizing single-qubit rotations for each of the Paulis in `list_op`. TPB stands for Tensor Product Basis. + +**Parameters** + +**list\_op** ([*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp")) – the `ListOp` whose TPB Pauli to return. + +**Returns** + +The TBP Pauli. + +**Return type** + +[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") + +### measurement\_replacement\_fn + + + +`static measurement_replacement_fn(cob_instr_op, dest_pauli_op)` + +A built-in convenience replacement function which produces measurements isomorphic to an `OperatorStateFn` measurement holding the origin `PauliOp`. + +**Parameters** + +* **cob\_instr\_op** ([*PrimitiveOp*](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp")) – The basis-change `CircuitOp`. +* **dest\_pauli\_op** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") *|*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") *|*[*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp")) – The destination Pauli type operator. + +**Returns** + +The `~StateFn @ CircuitOp` composition equivalent to a measurement by the original `PauliOp`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### operator\_replacement\_fn + + + +`static operator_replacement_fn(cob_instr_op, dest_pauli_op)` + +A built-in convenience replacement function which produces Operators isomorphic to the origin `PauliOp`. + +**Parameters** + +* **cob\_instr\_op** ([*PrimitiveOp*](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp")) – The basis-change `CircuitOp`. +* **dest\_pauli\_op** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") *|*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") *|*[*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp")) – The destination `PauliOp`. + +**Returns** + +The `~CircuitOp @ PauliOp @ CircuitOp` composition isomorphic to the original `PauliOp`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### pad\_paulis\_to\_equal\_length + + + +`pad_paulis_to_equal_length(pauli_op1, pauli_op2)` + +If `pauli_op1` and `pauli_op2` do not act over the same number of qubits, pad identities to the end of the shorter of the two so they are of equal length. Padding is applied to the end of the Paulis. Note that the Terra represents Paulis in big-endian order, so this will appear as padding to the beginning of the Pauli x and z bit arrays. + +**Parameters** + +* **pauli\_op1** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – A pauli\_op to possibly pad. +* **pauli\_op2** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – A pauli\_op to possibly pad. + +**Returns** + +A tuple containing the padded PauliOps. + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp"), [*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")] + +### statefn\_replacement\_fn + + + +`static statefn_replacement_fn(cob_instr_op, dest_pauli_op)` + +A built-in convenience replacement function which produces state functions isomorphic to an `OperatorStateFn` state function holding the origin `PauliOp`. + +**Parameters** + +* **cob\_instr\_op** ([*PrimitiveOp*](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp")) – The basis-change `CircuitOp`. +* **dest\_pauli\_op** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") *|*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") *|*[*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp")) – The destination Pauli type operator. + +**Returns** + +The `~CircuitOp @ StateFn` composition equivalent to a state function defined by the original `PauliOp`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.converters.TwoQubitReduction.md b/docs/api/qiskit/0.46/qiskit.opflow.converters.TwoQubitReduction.md new file mode 100644 index 00000000000..4fb8b3aebfa --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.converters.TwoQubitReduction.md @@ -0,0 +1,50 @@ +--- +title: TwoQubitReduction +description: API reference for qiskit.opflow.converters.TwoQubitReduction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.converters.TwoQubitReduction +--- + +# TwoQubitReduction + + + +`qiskit.opflow.converters.TwoQubitReduction(num_particles)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/converters/two_qubit_reduction.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: Two qubit reduction converter which eliminates the central and last qubit in a list of Pauli that has diagonal operators (Z,I) at those positions. + +Chemistry specific method: It can be used to taper two qubits in parity and binary-tree mapped fermionic Hamiltonians when the spin orbitals are ordered in two spin sectors, (block spin order) according to the number of particles in the system. + + + The class `qiskit.opflow.converters.two_qubit_reduction.TwoQubitReduction` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +**num\_particles** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – number of particles, if it is a list, the first number is alpha and the second number if beta. + +## Methods + +### convert + + + +`convert(operator)` + +Converts the Operator to tapered one by Z2 symmetries. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – the operator + +**Returns** + +A new operator whose qubit number is reduced by 2. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.converters.md b/docs/api/qiskit/0.46/qiskit.opflow.converters.md new file mode 100644 index 00000000000..1e134768011 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.converters.md @@ -0,0 +1,52 @@ +--- +title: converters +description: API reference for qiskit.opflow.converters +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow.converters +--- + + + + + +# qiskit.opflow\.converters + + + +## Converters + + + +`qiskit.opflow.converters` + + + The [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +Converters are objects which manipulate Operators, usually traversing an Operator to change certain sub-Operators into a desired representation. Often the converted Operator is isomorphic or approximate to the original Operator in some way, but not always. For example, a converter may accept [`CircuitOp`](qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.CircuitOp") and return a [`SummedOp`](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp") of [`PauliOp`](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.PauliOp")’s representing the circuit unitary. Converters may not have polynomial space or time scaling in their operations. On the contrary, many converters, such as a [`MatrixExpectation`](qiskit.opflow.expectations.MatrixExpectation "qiskit.opflow.expectations.MatrixExpectation") or [`MatrixEvolution`](qiskit.opflow.evolutions.MatrixEvolution "qiskit.opflow.evolutions.MatrixEvolution"), which convert [`PauliOp`](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.PauliOp")’s to [`MatrixOp`](qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.MatrixOp")’s internally, will require time or space exponential in the number of qubits unless a clever trick is known (such as the use of sparse matrices). + + + Not all converters are in this module, as [`expectations`](qiskit.opflow.expectations#module-qiskit.opflow.expectations "qiskit.opflow.expectations") and [`evolutions`](qiskit.opflow.evolutions#module-qiskit.opflow.evolutions "qiskit.opflow.evolutions") are also converters. + + +### Converter Base Class + +The converter base class simply enforces the presence of a [`convert()`](qiskit.opflow.converters.ConverterBase#convert "qiskit.opflow.converters.ConverterBase.convert") method. + +| | | +| ---------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.ConverterBase")() | Deprecated: Converters take an Operator and return a new Operator, generally isomorphic in some way with the first, but with certain desired properties. | + +### Converters + +In addition to the base class, directory holds a few miscellaneous converters which are used frequently around the Operator flow. + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| [`CircuitSampler`](qiskit.opflow.converters.CircuitSampler "qiskit.opflow.converters.CircuitSampler")(backend\[, statevector, ...]) | Deprecated: The CircuitSampler traverses an Operator and converts any CircuitStateFns into approximations of the state function by a DictStateFn or VectorStateFn using a quantum backend. | +| [`AbelianGrouper`](qiskit.opflow.converters.AbelianGrouper "qiskit.opflow.converters.AbelianGrouper")(\[traverse]) | Deprecated: The AbelianGrouper converts SummedOps into a sum of Abelian sums. | +| [`DictToCircuitSum`](qiskit.opflow.converters.DictToCircuitSum "qiskit.opflow.converters.DictToCircuitSum")(\[traverse, convert\_dicts, ...]) | Deprecated: Converts `DictStateFns` or `VectorStateFns` to equivalent `CircuitStateFns` or sums thereof. | +| [`PauliBasisChange`](qiskit.opflow.converters.PauliBasisChange "qiskit.opflow.converters.PauliBasisChange")(\[destination\_basis, ...]) | Deprecated: Converter for changing Paulis into other bases. | +| [`TwoQubitReduction`](qiskit.opflow.converters.TwoQubitReduction "qiskit.opflow.converters.TwoQubitReduction")(num\_particles) | Deprecated: Two qubit reduction converter which eliminates the central and last qubit in a list of Pauli that has diagonal operators (Z,I) at those positions. | + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionBase.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionBase.md new file mode 100644 index 00000000000..d1acbdd63fd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionBase.md @@ -0,0 +1,44 @@ +--- +title: EvolutionBase +description: API reference for qiskit.opflow.evolutions.EvolutionBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.EvolutionBase +--- + +# EvolutionBase + + + +`qiskit.opflow.evolutions.EvolutionBase`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/evolution_base.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Deprecated: A base for Evolution converters. Evolutions are converters which traverse an Operator tree, replacing any `EvolvedOp` e with a Schrodinger equation-style evolution `CircuitOp` equalling or approximating the matrix exponential of -i \* the Operator contained inside (e.primitive). The Evolutions are essentially implementations of Hamiltonian Simulation algorithms, including various methods for Trotterization. + + + The class `qiskit.opflow.evolutions.evolution_base.EvolutionBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### convert + + + +`abstract convert(operator)` + +Traverse the operator, replacing any `EvolutionOps` with their equivalent evolution `CircuitOps`. + +> **Args:** +> +> operator: The Operator to convert. + +**Returns** + +The converted Operator, with `EvolutionOps` replaced by `CircuitOps`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionFactory.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionFactory.md new file mode 100644 index 00000000000..5893c606076 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolutionFactory.md @@ -0,0 +1,48 @@ +--- +title: EvolutionFactory +description: API reference for qiskit.opflow.evolutions.EvolutionFactory +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.EvolutionFactory +--- + +# EvolutionFactory + + + +`qiskit.opflow.evolutions.EvolutionFactory`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/evolution_factory.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: A factory class for convenient automatic selection of an Evolution algorithm based on the Operator to be converted. + +## Methods + +### build + + + +`static build(operator=None)` + +A factory method for convenient automatic selection of an Evolution algorithm based on the Operator to be converted. + + + The method `qiskit.opflow.evolutions.evolution_factory.EvolutionFactory.build()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – the Operator being evolved + +**Returns** + +the `EvolutionBase` best suited to evolve operator. + +**Return type** + +[EvolutionBase](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.EvolutionBase") + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If operator is not of a composition for which we know the best Evolution method. + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolvedOp.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolvedOp.md new file mode 100644 index 00000000000..991107e42e4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.EvolvedOp.md @@ -0,0 +1,337 @@ +--- +title: EvolvedOp +description: API reference for qiskit.opflow.evolutions.EvolvedOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.EvolvedOp +--- + +# EvolvedOp + + + +`qiskit.opflow.evolutions.EvolvedOp(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/evolved_op.py "view source code") + +Bases: [`PrimitiveOp`](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + +Deprecated: Class for wrapping Operator Evolutions for compilation (`convert`) by an EvolutionBase method later, essentially acting as a placeholder. Note that EvolvedOp is a weird case of PrimitiveOp. It happens to be that it fits into the PrimitiveOp interface nearly perfectly, and it essentially represents a placeholder for a PrimitiveOp later, even though it doesn’t actually hold a primitive object. We could have chosen for it to be an OperatorBase, but would have ended up copying and pasting a lot of code from PrimitiveOp. + + + The class `qiskit.opflow.evolutions.evolved_op.EvolvedOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The operator being wrapped to signify evolution later. +* **coeff** – A coefficient multiplying the operator + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`PrimitiveOp` + +The primitive defining the underlying function of the Operator. + +**Returns** + +The primitive object. + + + +### settings + +Return operator settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*EvolvedOp*](#qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.evolved_op.EvolvedOp") | [*SummedOp*](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*EvolvedOp*](#qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.evolved_op.EvolvedOp") + +### assign\_parameters + + + +`assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*EvolvedOp*](#qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.evolved_op.EvolvedOp") | [*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### log\_i + + + +`log_i(massive=False)` + +Return a `MatrixOp` equivalent to log(H)/-i for this operator H. This function is the effective inverse of exp\_i, equivalent to finding the Hermitian Operator which produces self when exponentiated. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### permute + + + +`permute(permutation)` + +Permutes the qubits of the operator. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j should be permuted to position permutation\[j]. + +**Returns** + +A new OperatorBase containing the permuted operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if indices do not define a new index for each qubit. + +**Return type** + +[*EvolvedOp*](#qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.evolved_op.EvolvedOp") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*EvolvedOp*](#qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.evolved_op.EvolvedOp") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*TensoredOp*](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.tensored_op.TensoredOp") + +### to\_instruction + + + +`to_instruction(massive=False)` + +Returns an `Instruction` equivalent to this Operator. + +**Return type** + +[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Returns a `MatrixOp` equivalent to this Operator. + +**Return type** + +[*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") | [*MatrixOp*](qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.matrix_op.MatrixOp") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.MatrixEvolution.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.MatrixEvolution.md new file mode 100644 index 00000000000..2314e9f47a2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.MatrixEvolution.md @@ -0,0 +1,44 @@ +--- +title: MatrixEvolution +description: API reference for qiskit.opflow.evolutions.MatrixEvolution +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.MatrixEvolution +--- + +# MatrixEvolution + + + +`qiskit.opflow.evolutions.MatrixEvolution`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/matrix_evolution.py "view source code") + +Bases: [`EvolutionBase`](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.evolution_base.EvolutionBase") + +Deprecated: Performs Evolution by classical matrix exponentiation, constructing a circuit with `UnitaryGates` or `HamiltonianGates` containing the exponentiation of the Operator. + + + The class `qiskit.opflow.evolutions.matrix_evolution.MatrixEvolution` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### convert + + + +`convert(operator)` + +Traverse the operator, replacing `EvolvedOps` with `CircuitOps` containing `UnitaryGates` or `HamiltonianGates` (if self.coeff is a `ParameterExpression`) equalling the exponentiation of -i \* operator. This is done by converting the `EvolvedOp.primitive` to a `MatrixOp` and simply calling `.exp_i()` on that. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to convert. + +**Returns** + +The converted operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.PauliTrotterEvolution.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.PauliTrotterEvolution.md new file mode 100644 index 00000000000..789f15d0a5e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.PauliTrotterEvolution.md @@ -0,0 +1,96 @@ +--- +title: PauliTrotterEvolution +description: API reference for qiskit.opflow.evolutions.PauliTrotterEvolution +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.PauliTrotterEvolution +--- + +# PauliTrotterEvolution + + + +`qiskit.opflow.evolutions.PauliTrotterEvolution(trotter_mode='trotter', reps=1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/pauli_trotter_evolution.py "view source code") + +Bases: [`EvolutionBase`](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.evolution_base.EvolutionBase") + +Deprecated: An Evolution algorithm replacing exponentiated sums of Paulis by changing them each to the Z basis, rotating with an rZ, changing back, and Trotterizing. + +More specifically, we compute basis change circuits for each Pauli into a single-qubit Z, evolve the Z by the desired evolution time with an rZ gate, and change the basis back using the adjoint of the original basis change circuit. For sums of Paulis, the individual Pauli evolution circuits are composed together by Trotterization scheme. + + + The class `qiskit.opflow.evolutions.pauli_trotter_evolution.PauliTrotterEvolution` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **trotter\_mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*TrotterizationBase*](qiskit.opflow.evolutions.TrotterizationBase "qiskit.opflow.evolutions.trotterizations.trotterization_base.TrotterizationBase") *| None*) – A string (‘trotter’, ‘suzuki’, or ‘qdrift’) to pass to the TrotterizationFactory, or a TrotterizationBase, indicating how to combine individual Pauli evolution circuits to equal the exponentiation of the Pauli sum. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – How many Trotterization repetitions to make, to improve the approximation accuracy. +* **evolution.** (*# TODO uncomment when we implement Abelian grouped*) – +* **group\_paulis** (*#*) – Whether to group Pauli sums into Abelian +* **sub-groups** (*#*) – +* **group** (*so a single diagonalization circuit can be used for each*) – +* **Pauli.** (*# rather than each*) – + +## Attributes + + + +### trotter + +TrotterizationBase used to evolve SummedOps. + +## Methods + +### convert + + + +`convert(operator)` + +Traverse the operator, replacing `EvolvedOps` with `CircuitOps` containing Trotterized evolutions equalling the exponentiation of -i \* operator. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to convert. + +**Returns** + +The converted operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### evolution\_for\_abelian\_paulisum + + + +`evolution_for_abelian_paulisum(op_sum)` + +Evolution for abelian pauli sum + +**Return type** + +[*PrimitiveOp*](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + +### evolution\_for\_pauli + + + +`evolution_for_pauli(pauli_op)` + +Compute evolution Operator for a single Pauli using a `PauliBasisChange`. + +**Parameters** + +**pauli\_op** ([*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp")) – The `PauliOp` to evolve. + +**Returns** + +A `PrimitiveOp`, either the evolution `CircuitOp` or a `PauliOp` equal to the identity if pauli\_op is the identity. + +**Return type** + +[*PrimitiveOp*](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.QDrift.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.QDrift.md new file mode 100644 index 00000000000..efb089f3120 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.QDrift.md @@ -0,0 +1,60 @@ +--- +title: QDrift +description: API reference for qiskit.opflow.evolutions.QDrift +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.QDrift +--- + +# QDrift + + + +`qiskit.opflow.evolutions.QDrift(reps=1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/trotterizations/qdrift.py "view source code") + +Bases: [`TrotterizationBase`](qiskit.opflow.evolutions.TrotterizationBase "qiskit.opflow.evolutions.trotterizations.trotterization_base.TrotterizationBase") + +Deprecated: The QDrift Trotterization method, which selects each each term in the Trotterization randomly, with a probability proportional to its weight. Based on the work of Earl Campbell in [https://arxiv.org/abs/1811.08017](https://arxiv.org/abs/1811.08017). + + + The class `qiskit.opflow.evolutions.trotterizations.qdrift.QDrift` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +**reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of times to repeat the Trotterization circuit. + +## Attributes + + + +### reps + +The number of repetitions to use in the Trotterization, improving the approximation accuracy. + +## Methods + +### convert + + + +`convert(operator)` + +Convert a `SummedOp` into a `ComposedOp` or `CircuitOp` representing an approximation of e^-i\*\`\`op\_sum\`\`. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `SummedOp` to evolve. + +**Returns** + +The Operator approximating op\_sum’s evolution. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – A non-SummedOps Operator is passed into `convert`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.Suzuki.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.Suzuki.md new file mode 100644 index 00000000000..4b73ffa457f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.Suzuki.md @@ -0,0 +1,69 @@ +--- +title: Suzuki +description: API reference for qiskit.opflow.evolutions.Suzuki +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.Suzuki +--- + +# Suzuki + + + +`qiskit.opflow.evolutions.Suzuki(reps=1, order=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/trotterizations/suzuki.py "view source code") + +Bases: [`TrotterizationBase`](qiskit.opflow.evolutions.TrotterizationBase "qiskit.opflow.evolutions.trotterizations.trotterization_base.TrotterizationBase") + +Deprecated: Suzuki Trotter expansion, composing the evolution circuits of each Operator in the sum together by a recursive “bookends” strategy, repeating the whole composed circuit `reps` times. + +Detailed in [https://arxiv.org/pdf/quant-ph/0508139.pdf](https://arxiv.org/pdf/quant-ph/0508139.pdf). + + + The class `qiskit.opflow.evolutions.trotterizations.suzuki.Suzuki` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of times to repeat the expansion circuit. +* **order** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The order of the expansion to perform. + +## Attributes + + + +### order + +returns order + + + +### reps + +The number of repetitions to use in the Trotterization, improving the approximation accuracy. + +## Methods + +### convert + + + +`convert(operator)` + +Convert a `SummedOp` into a `ComposedOp` or `CircuitOp` representing an approximation of e^-i\*\`\`op\_sum\`\`. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `SummedOp` to evolve. + +**Returns** + +The Operator approximating op\_sum’s evolution. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – A non-SummedOps Operator is passed into `convert`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.Trotter.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.Trotter.md new file mode 100644 index 00000000000..54c4cd95666 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.Trotter.md @@ -0,0 +1,40 @@ +--- +title: Trotter +description: API reference for qiskit.opflow.evolutions.Trotter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.Trotter +--- + +# Trotter + + + +`qiskit.opflow.evolutions.Trotter(reps=1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/trotterizations/trotter.py "view source code") + +Bases: [`Suzuki`](qiskit.opflow.evolutions.Suzuki "qiskit.opflow.evolutions.trotterizations.suzuki.Suzuki") + +Deprecated: Simple Trotter expansion, composing the evolution circuits of each Operator in the sum together `reps` times and dividing the evolution time of each by `reps`. + + + The class `qiskit.opflow.evolutions.trotterizations.trotter.Trotter` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +**reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of times to repeat the Trotterization circuit. + +## Attributes + + + +### order + +returns order + + + +### reps + +The number of repetitions to use in the Trotterization, improving the approximation accuracy. + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationBase.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationBase.md new file mode 100644 index 00000000000..df4299e6e1a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationBase.md @@ -0,0 +1,56 @@ +--- +title: TrotterizationBase +description: API reference for qiskit.opflow.evolutions.TrotterizationBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.TrotterizationBase +--- + +# TrotterizationBase + + + +`qiskit.opflow.evolutions.TrotterizationBase(reps=1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/trotterizations/trotterization_base.py "view source code") + +Bases: [`EvolutionBase`](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.evolution_base.EvolutionBase") + +Deprecated: A base for Trotterization methods, algorithms for approximating exponentiations of operator sums by compositions of exponentiations. + + + The class `qiskit.opflow.evolutions.trotterizations.trotterization_base.TrotterizationBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Attributes + + + +### reps + +The number of repetitions to use in the Trotterization, improving the approximation accuracy. + +## Methods + +### convert + + + +`abstract convert(operator)` + +Convert a `SummedOp` into a `ComposedOp` or `CircuitOp` representing an approximation of e^-i\*\`\`op\_sum\`\`. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `SummedOp` to evolve. + +**Returns** + +The Operator approximating op\_sum’s evolution. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – A non-SummedOps Operator is passed into `convert`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationFactory.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationFactory.md new file mode 100644 index 00000000000..34f6052a78b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.TrotterizationFactory.md @@ -0,0 +1,49 @@ +--- +title: TrotterizationFactory +description: API reference for qiskit.opflow.evolutions.TrotterizationFactory +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.evolutions.TrotterizationFactory +--- + +# TrotterizationFactory + + + +`qiskit.opflow.evolutions.TrotterizationFactory`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/evolutions/trotterizations/trotterization_factory.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: A factory for conveniently creating TrotterizationBase instances. + +## Methods + +### build + + + +`static build(mode='trotter', reps=1)` + +A factory for conveniently creating TrotterizationBase instances. + + + The method `qiskit.opflow.evolutions.trotterizations.trotterization_factory.TrotterizationFactory.build()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **mode** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – One of ‘trotter’, ‘suzuki’, ‘qdrift’ +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of times to repeat the Trotterization circuit. + +**Returns** + +The desired TrotterizationBase instance. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – A string not in \[‘trotter’, ‘suzuki’, ‘qdrift’] is given for mode. + +**Return type** + +[*TrotterizationBase*](qiskit.opflow.evolutions.TrotterizationBase "qiskit.opflow.evolutions.trotterizations.trotterization_base.TrotterizationBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.evolutions.md b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.md new file mode 100644 index 00000000000..1e9dc9e774c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.evolutions.md @@ -0,0 +1,61 @@ +--- +title: evolutions +description: API reference for qiskit.opflow.evolutions +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow.evolutions +--- + + + + + +# qiskit.opflow\.evolutions + + + +## Operator Evolutions + + + +`qiskit.opflow.evolutions` + + + The [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +Evolutions are converters which traverse an Operator tree, replacing any [`EvolvedOp`](qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.EvolvedOp") e with a Schrodinger equation-style evolution [`CircuitOp`](qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.CircuitOp") equalling or approximating the matrix exponential of -i \* the Operator contained inside (e.primitive). The Evolutions are essentially implementations of Hamiltonian Simulation algorithms, including various methods for Trotterization. + +The [`EvolvedOp`](qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.EvolvedOp") is simply a placeholder signifying that the Operator inside it should be converted to its exponential by the Evolution converter. All Operators (not [`state_fns`](qiskit.opflow.state_fns#module-qiskit.opflow.state_fns "qiskit.opflow.state_fns")) have `.exp_i()` methods which either return the exponential of the Operator directly, or an [`EvolvedOp`](qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.EvolvedOp") containing the Operator. + + + Evolutions work with parameterized Operator coefficients, so `my_expectation.convert((t * H).exp_i())`, where t is a scalar or Terra Parameter and H is an Operator, will produce a [`CircuitOp`](qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.CircuitOp") equivalent to e^iHt. + + +### Evolution Base Class + +The EvolutionBase class gives an interface for algorithms to ask for Evolutions as execution settings. For example, if an algorithm contains an Operator evolution step within it, such as [`QAOA`](qiskit.algorithms.QAOA "qiskit.algorithms.QAOA"), the algorithm can give the opportunity for the user to pass an EvolutionBase of their choice to be used in that evolution step. + +| | | +| ---------------------------------------------------------------------------------------------------- | -------------------------------------------- | +| [`EvolutionBase`](qiskit.opflow.evolutions.EvolutionBase "qiskit.opflow.evolutions.EvolutionBase")() | Deprecated: A base for Evolution converters. | + +### Evolutions + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`EvolutionFactory`](qiskit.opflow.evolutions.EvolutionFactory "qiskit.opflow.evolutions.EvolutionFactory")() | Deprecated: A factory class for convenient automatic selection of an Evolution algorithm based on the Operator to be converted. | +| [`EvolvedOp`](qiskit.opflow.evolutions.EvolvedOp "qiskit.opflow.evolutions.EvolvedOp")(\*args, \*\*kwargs) | Deprecated: Class for wrapping Operator Evolutions for compilation (`convert`) by an EvolutionBase method later, essentially acting as a placeholder. | +| [`MatrixEvolution`](qiskit.opflow.evolutions.MatrixEvolution "qiskit.opflow.evolutions.MatrixEvolution")() | Deprecated: Performs Evolution by classical matrix exponentiation, constructing a circuit with `UnitaryGates` or `HamiltonianGates` containing the exponentiation of the Operator. | +| [`PauliTrotterEvolution`](qiskit.opflow.evolutions.PauliTrotterEvolution "qiskit.opflow.evolutions.PauliTrotterEvolution")(\[trotter\_mode, reps]) | Deprecated: An Evolution algorithm replacing exponentiated sums of Paulis by changing them each to the Z basis, rotating with an rZ, changing back, and Trotterizing. | + +### Trotterizations + +| | | +| ---------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`TrotterizationBase`](qiskit.opflow.evolutions.TrotterizationBase "qiskit.opflow.evolutions.TrotterizationBase")(\[reps]) | Deprecated: A base for Trotterization methods, algorithms for approximating exponentiations of operator sums by compositions of exponentiations. | +| [`TrotterizationFactory`](qiskit.opflow.evolutions.TrotterizationFactory "qiskit.opflow.evolutions.TrotterizationFactory")() | Deprecated: A factory for conveniently creating TrotterizationBase instances. | +| [`Trotter`](qiskit.opflow.evolutions.Trotter "qiskit.opflow.evolutions.Trotter")(\[reps]) | Deprecated: Simple Trotter expansion, composing the evolution circuits of each Operator in the sum together `reps` times and dividing the evolution time of each by `reps`. | +| [`Suzuki`](qiskit.opflow.evolutions.Suzuki "qiskit.opflow.evolutions.Suzuki")(\[reps, order]) | Deprecated: Suzuki Trotter expansion, composing the evolution circuits of each Operator in the sum together by a recursive "bookends" strategy, repeating the whole composed circuit `reps` times. | +| [`QDrift`](qiskit.opflow.evolutions.QDrift "qiskit.opflow.evolutions.QDrift")(\[reps]) | Deprecated: The QDrift Trotterization method, which selects each each term in the Trotterization randomly, with a probability proportional to its weight. | + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.expectations.AerPauliExpectation.md b/docs/api/qiskit/0.46/qiskit.opflow.expectations.AerPauliExpectation.md new file mode 100644 index 00000000000..c953da7ecdd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.expectations.AerPauliExpectation.md @@ -0,0 +1,64 @@ +--- +title: AerPauliExpectation +description: API reference for qiskit.opflow.expectations.AerPauliExpectation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.expectations.AerPauliExpectation +--- + +# AerPauliExpectation + + + +`qiskit.opflow.expectations.AerPauliExpectation`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/expectations/aer_pauli_expectation.py "view source code") + +Bases: [`ExpectationBase`](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.expectation_base.ExpectationBase") + +An Expectation converter for using Aer’s operator snapshot to take expectations of quantum state circuits over Pauli observables. + + + The class `qiskit.opflow.expectations.aer_pauli_expectation.AerPauliExpectation` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### compute\_variance + + + +`compute_variance(exp_op)` + +Compute the variance of the expectation estimator. Because Aer takes this expectation with matrix multiplication, the estimation is exact and the variance is always 0, but we need to return those values in a way which matches the Operator’s structure. + +**Parameters** + +**exp\_op** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The full expectation value Operator after sampling. + +**Returns** + +The variances or lists thereof (if exp\_op contains ListOps) of the expectation value estimation, equal to 0. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") | [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### convert + + + +`convert(operator)` + +Accept an Operator and return a new Operator with the Pauli measurements replaced by AerSnapshot-based expectation circuits. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator to convert. If it contains non-hermitian terms, the operator is decomposed into hermitian and anti-hermitian parts. + +**Returns** + +The converted operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.expectations.CVaRExpectation.md b/docs/api/qiskit/0.46/qiskit.opflow.expectations.CVaRExpectation.md new file mode 100644 index 00000000000..5df1539ef46 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.expectations.CVaRExpectation.md @@ -0,0 +1,89 @@ +--- +title: CVaRExpectation +description: API reference for qiskit.opflow.expectations.CVaRExpectation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.expectations.CVaRExpectation +--- + +# CVaRExpectation + + + +`qiskit.opflow.expectations.CVaRExpectation(alpha, expectation=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/expectations/cvar_expectation.py "view source code") + +Bases: [`ExpectationBase`](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.expectation_base.ExpectationBase") + +Deprecated: Compute the Conditional Value at Risk (CVaR) expectation value. + +The standard approach to calculating the expectation value of a Hamiltonian w\.r.t. a state is to take the sample mean of the measurement outcomes. This corresponds to an estimator of the energy. However in several problem settings with a diagonal Hamiltonian, e.g. in combinatorial optimization where the Hamiltonian encodes a cost function, we are not interested in calculating the energy but in the lowest possible value we can find. + +To this end, we might consider using the best observed sample as a cost function during variational optimization. The issue here, is that this can result in a non-smooth optimization surface. To resolve this issue, we can smooth the optimization surface by using not just the best observed sample, but instead average over some fraction of best observed samples. This is exactly what the CVaR estimator accomplishes \[1]. + +It is empirically shown, that this can lead to faster convergence for combinatorial optimization problems. + +Let $\alpha$ be a real number in $[0,1]$ which specifies the fraction of best observed samples which are used to compute the objective function. Observe that if $\alpha = 1$, CVaR is equivalent to a standard expectation value. Similarly, if $\alpha = 0$, then CVaR corresponds to using the best observed sample. Intermediate values of $\alpha$ interpolate between these two objective functions. + +**References** + +**\[1]: Barkoutsos, P. K., Nannicini, G., Robert, A., Tavernelli, I., and Woerner, S.,** + +“Improving Variational Quantum Optimization using CVaR” [arXiv:1907.04769](https://arxiv.org/abs/1907.04769) + + + The class `qiskit.opflow.expectations.cvar_expectation.CVaRExpectation` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The alpha value describing the quantile considered in the expectation value. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.expectation_base.ExpectationBase") *| None*) – An expectation object to compute the expectation value. Defaults to the PauliExpectation calculation. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If the `expectation` is an AerPauliExpecation. + +## Methods + +### compute\_variance + + + +`compute_variance(exp_op)` + +Returns the variance of the CVaR calculation + +**Parameters** + +**exp\_op** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator whose evaluation yields an expectation of some StateFn against a diagonal observable. + +**Returns** + +**The variance of the CVaR estimate corresponding to the converted** + +exp\_op. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the exp\_op does not correspond to an expectation value. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") | [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### convert + + + +`convert(operator)` + +Return an expression that computes the CVaR expectation upon calling `eval`. :param operator: The operator to convert. + +**Returns** + +The converted operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationBase.md b/docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationBase.md new file mode 100644 index 00000000000..d5ddd286108 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationBase.md @@ -0,0 +1,64 @@ +--- +title: ExpectationBase +description: API reference for qiskit.opflow.expectations.ExpectationBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.expectations.ExpectationBase +--- + +# ExpectationBase + + + +`qiskit.opflow.expectations.ExpectationBase`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/expectations/expectation_base.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: A base for Expectation value converters. Expectations are converters which enable the computation of the expectation value of an Observable with respect to some state function. They traverse an Operator tree, replacing OperatorStateFn measurements with equivalent measurements which are more amenable to computation on quantum or classical hardware. For example, if one would like to measure the expectation value of an Operator `o` expressed as a sum of Paulis with respect to some state function, but only has access to diagonal measurements on Quantum hardware, we can create a measurement \~StateFn(o), use a `PauliExpectation` to convert it to a diagonal measurement and circuit pre-rotations to a append to the state, and sample this circuit on Quantum hardware with a CircuitSampler. All in all, this would be: `my_sampler.convert(my_expect.convert(~StateFn(o)) @ my_state).eval()`. + + + The class `qiskit.opflow.expectations.expectation_base.ExpectationBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### compute\_variance + + + +`abstract compute_variance(exp_op)` + +Compute the variance of the expectation estimator. + +**Parameters** + +**exp\_op** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The full expectation value Operator after sampling. + +**Returns** + +The variances or lists thereof (if exp\_op contains ListOps) of the expectation value estimation. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") | [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### convert + + + +`abstract convert(operator)` + +Accept an Operator and return a new Operator with the measurements replaced by alternate methods to compute the expectation value. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator to convert. + +**Returns** + +The converted operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationFactory.md b/docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationFactory.md new file mode 100644 index 00000000000..4f2df062d28 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.expectations.ExpectationFactory.md @@ -0,0 +1,50 @@ +--- +title: ExpectationFactory +description: API reference for qiskit.opflow.expectations.ExpectationFactory +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.expectations.ExpectationFactory +--- + +# ExpectationFactory + + + +`qiskit.opflow.expectations.ExpectationFactory`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/expectations/expectation_factory.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: factory class for convenient automatic selection of an Expectation based on the Operator to be converted and backend used to sample the expectation value. + +## Methods + +### build + + + +`static build(operator, backend=None, include_custom=True)` + +A factory method for convenient automatic selection of an Expectation based on the Operator to be converted and backend used to sample the expectation value. + + + The method `qiskit.opflow.expectations.expectation_factory.ExpectationFactory.build()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator whose expectation value will be taken. +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *|*[*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.quantum_instance.QuantumInstance") *| None*) – The backend which will be used to sample the expectation value. +* **include\_custom** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the factory will include the (Aer) specific custom expectations if their behavior against the backend might not be as expected. For instance when using Aer qasm\_simulator with paulis the Aer snapshot can be used but the outcome lacks shot noise and hence does not intuitively behave overall as people might expect when choosing a qasm\_simulator. It is however fast as long as the more state vector like behavior is acceptable. + +**Returns** + +The expectation algorithm which best fits the Operator and backend. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If operator is not of a composition for which we know the best Expectation method. + +**Return type** + +[*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.expectation_base.ExpectationBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.expectations.MatrixExpectation.md b/docs/api/qiskit/0.46/qiskit.opflow.expectations.MatrixExpectation.md new file mode 100644 index 00000000000..a2d9345e208 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.expectations.MatrixExpectation.md @@ -0,0 +1,64 @@ +--- +title: MatrixExpectation +description: API reference for qiskit.opflow.expectations.MatrixExpectation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.expectations.MatrixExpectation +--- + +# MatrixExpectation + + + +`qiskit.opflow.expectations.MatrixExpectation`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/expectations/matrix_expectation.py "view source code") + +Bases: [`ExpectationBase`](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.expectation_base.ExpectationBase") + +An Expectation converter which converts Operator measurements to be matrix-based so they can be evaluated by matrix multiplication. + + + The class `qiskit.opflow.expectations.matrix_expectation.MatrixExpectation` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### compute\_variance + + + +`compute_variance(exp_op)` + +Compute the variance of the expectation estimator. Because this expectation works by matrix multiplication, the estimation is exact and the variance is always 0, but we need to return those values in a way which matches the Operator’s structure. + +**Parameters** + +**exp\_op** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The full expectation value Operator. + +**Returns** + +The variances or lists thereof (if exp\_op contains ListOps) of the expectation value estimation, equal to 0. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") | [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### convert + + + +`convert(operator)` + +Accept an Operator and return a new Operator with the Pauli measurements replaced by Matrix based measurements. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator to convert. + +**Returns** + +The converted operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.expectations.PauliExpectation.md b/docs/api/qiskit/0.46/qiskit.opflow.expectations.PauliExpectation.md new file mode 100644 index 00000000000..b1aee536e3b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.expectations.PauliExpectation.md @@ -0,0 +1,68 @@ +--- +title: PauliExpectation +description: API reference for qiskit.opflow.expectations.PauliExpectation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.expectations.PauliExpectation +--- + +# PauliExpectation + + + +`qiskit.opflow.expectations.PauliExpectation(group_paulis=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/expectations/pauli_expectation.py "view source code") + +Bases: [`ExpectationBase`](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.expectation_base.ExpectationBase") + +An Expectation converter for Pauli-basis observables by changing Pauli measurements to a diagonal (\{Z, I}^n) basis and appending circuit post-rotations to the measured state function. Optionally groups the Paulis with the same post-rotations (those that commute with one another, or form Abelian groups) into single measurements to reduce circuit execution overhead. + + + The class `qiskit.opflow.expectations.pauli_expectation.PauliExpectation` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +**group\_paulis** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to group the Pauli measurements into commuting sums, which all have the same diagonalizing circuit. + +## Methods + +### compute\_variance + + + +`compute_variance(exp_op)` + +Compute the variance of the expectation estimator. + +**Parameters** + +**exp\_op** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The full expectation value Operator after sampling. + +**Returns** + +The variances or lists thereof (if exp\_op contains ListOps) of the expectation value estimation. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") | [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### convert + + + +`convert(operator)` + +Accepts an Operator and returns a new Operator with the Pauli measurements replaced by diagonal Pauli post-rotation based measurements so they can be evaluated by sampling and averaging. + +**Parameters** + +**operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator to convert. + +**Returns** + +The converted operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.expectations.md b/docs/api/qiskit/0.46/qiskit.opflow.expectations.md new file mode 100644 index 00000000000..50b011bb433 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.expectations.md @@ -0,0 +1,46 @@ +--- +title: expectations +description: API reference for qiskit.opflow.expectations +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow.expectations +--- + + + + + +# qiskit.opflow\.expectations + + + +## Expectations + + + +`qiskit.opflow.expectations` + + + The [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +Expectations are converters which enable the computation of the expectation value of an Observable with respect to some state function. They traverse an Operator tree, replacing [`OperatorStateFn`](qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.OperatorStateFn") measurements with equivalent measurements which are more amenable to computation on quantum or classical hardware. For example, if one would like to measure the expectation value of an Operator `o` expressed as a sum of Paulis with respect to some state function, but only has access to diagonal measurements on Quantum hardware, we can create a measurement \~StateFn(o), use a [`PauliExpectation`](qiskit.opflow.expectations.PauliExpectation "qiskit.opflow.expectations.PauliExpectation") to convert it to a diagonal measurement and circuit pre-rotations to append to the state, and sample this circuit on Quantum hardware with a [`CircuitSampler`](qiskit.opflow.converters.CircuitSampler "qiskit.opflow.converters.CircuitSampler"). All in all, this would be: `my_sampler.convert(my_expect.convert(~StateFn(o)) @ my_state).eval()`. + +### Expectation Base Class + +The ExpectationBase class gives an interface for algorithms to ask for Expectations as execution settings. For example, if an algorithm contains an expectation value step within it, such as [`VQE`](qiskit.algorithms.VQE "qiskit.algorithms.VQE"), the algorithm can give the opportunity for the user to pass an ExpectationBase of their choice to be used in that expectation value step. + +| | | +| -------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------- | +| [`ExpectationBase`](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.ExpectationBase")() | Deprecated: A base for Expectation value converters. | + +### Expectations + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`ExpectationFactory`](qiskit.opflow.expectations.ExpectationFactory "qiskit.opflow.expectations.ExpectationFactory")() | Deprecated: factory class for convenient automatic selection of an Expectation based on the Operator to be converted and backend used to sample the expectation value. | +| [`AerPauliExpectation`](qiskit.opflow.expectations.AerPauliExpectation "qiskit.opflow.expectations.AerPauliExpectation")() | An Expectation converter for using Aer's operator snapshot to take expectations of quantum state circuits over Pauli observables. | +| [`MatrixExpectation`](qiskit.opflow.expectations.MatrixExpectation "qiskit.opflow.expectations.MatrixExpectation")() | An Expectation converter which converts Operator measurements to be matrix-based so they can be evaluated by matrix multiplication. | +| [`PauliExpectation`](qiskit.opflow.expectations.PauliExpectation "qiskit.opflow.expectations.PauliExpectation")(\[group\_paulis]) | An Expectation converter for Pauli-basis observables by changing Pauli measurements to a diagonal (\{Z, I}^n) basis and appending circuit post-rotations to the measured state function. | +| [`CVaRExpectation`](qiskit.opflow.expectations.CVaRExpectation "qiskit.opflow.expectations.CVaRExpectation")(alpha\[, expectation]) | Deprecated: Compute the Conditional Value at Risk (CVaR) expectation value. | + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitGradient.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitGradient.md new file mode 100644 index 00000000000..65d2d429cec --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitGradient.md @@ -0,0 +1,53 @@ +--- +title: CircuitGradient +description: API reference for qiskit.opflow.gradients.CircuitGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.CircuitGradient +--- + +# CircuitGradient + + + +`qiskit.opflow.gradients.CircuitGradient`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/circuit_gradients/circuit_gradient.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: Circuit to gradient operator converter. + +Converter for changing parameterized circuits into operators whose evaluation yields the gradient with respect to the circuit parameters. + +This is distinct from DerivativeBase converters which take gradients of composite operators and handle things like differentiating combo\_fn’s and enforcing product rules when operator coefficients are parameterized. + +CircuitGradient - uses quantum techniques to get derivatives of circuits DerivativeBase - uses classical techniques to differentiate operator flow data structures + + + The class `qiskit.opflow.gradients.circuit_gradients.circuit_gradient.CircuitGradient` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### convert + + + +`abstract convert(operator, params=None)` + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator we are taking the gradient of +* **params** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]] | None*) – The parameters we are taking the gradient wrt: ω If a ParameterExpression, ParameterVector or List\[ParameterExpression] is given, then the 1st order derivative of the operator is calculated. If a Tuple\[ParameterExpression, ParameterExpression] or List\[Tuple\[ParameterExpression, ParameterExpression]] is given, then the 2nd order derivative of the operator is calculated. + +**Returns** + +An operator whose evaluation yields the Gradient. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `params` contains a parameter not present in `operator`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitQFI.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitQFI.md new file mode 100644 index 00000000000..faf06323354 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.CircuitQFI.md @@ -0,0 +1,53 @@ +--- +title: CircuitQFI +description: API reference for qiskit.opflow.gradients.CircuitQFI +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.CircuitQFI +--- + +# CircuitQFI + + + +`qiskit.opflow.gradients.CircuitQFI`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/circuit_qfis/circuit_qfi.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: Circuit to Quantum Fisher Information operator converter. + +Converter for changing parameterized circuits into operators whose evaluation yields Quantum Fisher Information metric tensor with respect to the given circuit parameters + +This is distinct from DerivativeBase converters which take gradients of composite operators and handle things like differentiating combo\_fn’s and enforcing product rules when operator coefficients are parameterized. + +CircuitQFI - uses quantum techniques to get the QFI of circuits DerivativeBase - uses classical techniques to differentiate opflow data structures + + + The class `qiskit.opflow.gradients.circuit_qfis.circuit_qfi.CircuitQFI` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### convert + + + +`abstract convert(operator, params)` + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator corresponding to the quantum state $|\psi(\omega)\rangle$ for which we compute the QFI. +* **params** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]*) – The parameters $\omega$ with respect to which we are computing the QFI. + +**Returns** + +An operator whose evaluation yields the QFI metric tensor. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `params` contains a parameter not present in `operator`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.DerivativeBase.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.DerivativeBase.md new file mode 100644 index 00000000000..b8d8c50415c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.DerivativeBase.md @@ -0,0 +1,102 @@ +--- +title: DerivativeBase +description: API reference for qiskit.opflow.gradients.DerivativeBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.DerivativeBase +--- + +# DerivativeBase + + + +`qiskit.opflow.gradients.DerivativeBase`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/derivative_base.py "view source code") + +Bases: [`ConverterBase`](qiskit.opflow.converters.ConverterBase "qiskit.opflow.converters.converter_base.ConverterBase") + +Deprecated: Base class for differentiating opflow objects. + +Converter for differentiating opflow objects and handling things like properly differentiating combo\_fn’s and enforcing product rules when operator coefficients are parameterized. + +This is distinct from CircuitGradient converters which use quantum techniques such as parameter shifts and linear combination of unitaries to compute derivatives of circuits. + +CircuitGradient - uses quantum techniques to get derivatives of circuits DerivativeBase - uses classical techniques to differentiate opflow data structures + + + The class `qiskit.opflow.gradients.derivative_base.DerivativeBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Methods + +### convert + + + +`abstract convert(operator, params=None)` + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator we are taking the gradient, Hessian or QFI of +* **params** ([*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] | None*) – The parameters we are taking the gradient, Hessian or QFI with respect to. + +**Returns** + +An operator whose evaluation yields the gradient, Hessian or QFI. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `params` contains a parameter not present in `operator`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### gradient\_wrapper + + + +`gradient_wrapper(operator, bind_params, grad_params=None, backend=None, expectation=None)` + +Get a callable function which provides the respective gradient, Hessian or QFI for given parameter values. This callable can be used as gradient function for optimizers. + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator for which we want to get the gradient, Hessian or QFI. +* **bind\_params** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]*) – The operator parameters to which the parameter values are assigned. +* **grad\_params** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]] | None*) – The parameters with respect to which we are taking the gradient, Hessian or QFI. If grad\_params = None, then grad\_params = bind\_params +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *|*[*QuantumInstance*](qiskit.utils.QuantumInstance "qiskit.utils.quantum_instance.QuantumInstance") *| None*) – The quantum backend or QuantumInstance to use to evaluate the gradient, Hessian or QFI. +* **expectation** ([*ExpectationBase*](qiskit.opflow.expectations.ExpectationBase "qiskit.opflow.expectations.expectation_base.ExpectationBase") *| None*) – The expectation converter to be used. If none is set then PauliExpectation() is used. + +**Returns** + +Function to compute a gradient, Hessian or QFI. The function takes an iterable as argument which holds the parameter values. + +**Return type** + +[*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")\[\[[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")], [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")] + +### parameter\_expression\_grad + + + +`static parameter_expression_grad(param_expr, param)` + +Get the derivative of a parameter expression w\.r.t. the given parameter. + + + The method `qiskit.opflow.gradients.derivative_base.DerivativeBase.parameter_expression_grad()` is deprecated as of qiskit-terra 0.18.0. It will be removed in the Qiskit 1.0 release. Instead, use the ParameterExpression.gradient method. + + +**Parameters** + +* **param\_expr** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The Parameter Expression for which we compute the derivative +* **param** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Parameter w\.r.t. which we want to take the derivative + +**Returns** + +ParameterExpression representing the gradient of param\_expr w\.r.t. param + +**Return type** + +[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") | [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.Gradient.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.Gradient.md new file mode 100644 index 00000000000..885c06ef981 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.Gradient.md @@ -0,0 +1,90 @@ +--- +title: Gradient +description: API reference for qiskit.opflow.gradients.Gradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.Gradient +--- + +# Gradient + + + +`qiskit.opflow.gradients.Gradient(grad_method='param_shift', **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/gradient.py "view source code") + +Bases: [`GradientBase`](qiskit.opflow.gradients.GradientBase "qiskit.opflow.gradients.gradient_base.GradientBase") + +Deprecated: Convert an operator expression to the first-order gradient. + + + The class `qiskit.opflow.gradients.gradient.Gradient` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Attributes + + + +### grad\_method + +Returns `CircuitGradient`. + +**Returns** + +`CircuitGradient`. + +## Methods + +### convert + + + +`convert(operator, params=None)` + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator we are taking the gradient of. +* **params** ([*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] | None*) – The parameters we are taking the gradient with respect to. If not explicitly passed, they are inferred from the operator and sorted by name. + +**Returns** + +An operator whose evaluation yields the Gradient. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `params` contains a parameter not present in `operator`. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `operator` is not parameterized. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### get\_gradient + + + +`get_gradient(operator, params)` + +Get the gradient for the given operator w\.r.t. the given parameters + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator w\.r.t. which we take the gradient. +* **params** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]*) – Parameters w\.r.t. which we compute the gradient. + +**Returns** + +Operator which represents the gradient w\.r.t. the given params. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `params` contains a parameter not present in `operator`. +* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – If the coefficient of the operator could not be reduced to 1. +* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – If the differentiation of a combo\_fn requires JAX but the package is not installed. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the operator does not include a StateFn given by a quantum circuit +* [**Exception**](https://docs.python.org/3/library/exceptions.html#Exception "(in Python v3.12)") – Unintended code is reached +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – jax not installed + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.GradientBase.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.GradientBase.md new file mode 100644 index 00000000000..ca5fac01841 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.GradientBase.md @@ -0,0 +1,45 @@ +--- +title: GradientBase +description: API reference for qiskit.opflow.gradients.GradientBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.GradientBase +--- + +# GradientBase + + + +`qiskit.opflow.gradients.GradientBase(grad_method='param_shift', **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/gradient_base.py "view source code") + +Bases: [`DerivativeBase`](qiskit.opflow.gradients.DerivativeBase "qiskit.opflow.gradients.derivative_base.DerivativeBase") + +Deprecated: Base class for first-order operator gradient. + +Convert an operator expression to the first-order gradient. + + + The class `qiskit.opflow.gradients.gradient_base.GradientBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **grad\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*CircuitGradient*](qiskit.opflow.gradients.CircuitGradient "qiskit.opflow.gradients.circuit_gradients.circuit_gradient.CircuitGradient")) – The method used to compute the state/probability gradient. Can be either `'param_shift'` or `'lin_comb'` or `'fin_diff'`. Ignored for gradients w\.r.t observable parameters. +* **kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Optional parameters for a CircuitGradient + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If method != `fin_diff` and `epsilon` is not None. + +## Attributes + + + +### grad\_method + +Returns `CircuitGradient`. + +**Returns** + +`CircuitGradient`. + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.Hessian.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.Hessian.md new file mode 100644 index 00000000000..7ec267a1205 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.Hessian.md @@ -0,0 +1,87 @@ +--- +title: Hessian +description: API reference for qiskit.opflow.gradients.Hessian +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.Hessian +--- + +# Hessian + + + +`qiskit.opflow.gradients.Hessian(hess_method='param_shift', **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/hessian.py "view source code") + +Bases: [`HessianBase`](qiskit.opflow.gradients.HessianBase "qiskit.opflow.gradients.hessian_base.HessianBase") + +Deprecated: Compute the Hessian of an expected value. + + + The class `qiskit.opflow.gradients.hessian.Hessian` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Attributes + + + +### hess\_method + +Returns `CircuitGradient`. + +**Returns** + +`CircuitGradient`. + +## Methods + +### convert + + + +`convert(operator, params=None)` + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator for which we compute the Hessian +* **params** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *| None*) – The parameters we are computing the Hessian with respect to Either give directly the tuples/list of tuples for which the second order derivative is to be computed or give a list of parameters to build the full Hessian for those parameters. If not explicitly passed, the full Hessian is constructed. The parameters are then inferred from the operator and sorted by name. + +**Returns** + +An operator whose evaluation yields the Hessian + +**Return type** + +[OperatorBase](qiskit.opflow.OperatorBase "qiskit.opflow.OperatorBase") + +### get\_hessian + + + +`get_hessian(operator, params=None)` + +Get the Hessian for the given operator w\.r.t. the given parameters + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – Operator w\.r.t. which we take the Hessian. +* **params** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]] |* [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] |* [*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *| None*) – Parameters w\.r.t. which we compute the Hessian. If not explicitly passed, the full Hessian is constructed. The parameters are then inferred from the operator and sorted by name. + +**Returns** + +Operator which represents the gradient w\.r.t. the given params. + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `params` contains a parameter not present in `operator`. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `operator` is not parameterized. +* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – If the coefficient of the operator could not be reduced to 1. +* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – If the differentiation of a combo\_fn requires JAX but the package is not installed. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the operator does not include a StateFn given by a quantum circuit +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the parameters were given in an unsupported format. +* [**Exception**](https://docs.python.org/3/library/exceptions.html#Exception "(in Python v3.12)") – Unintended code is reached +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – jax not installed + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.HessianBase.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.HessianBase.md new file mode 100644 index 00000000000..5b748e0e0fe --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.HessianBase.md @@ -0,0 +1,43 @@ +--- +title: HessianBase +description: API reference for qiskit.opflow.gradients.HessianBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.HessianBase +--- + +# HessianBase + + + +`qiskit.opflow.gradients.HessianBase(hess_method='param_shift', **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/hessian_base.py "view source code") + +Bases: [`DerivativeBase`](qiskit.opflow.gradients.DerivativeBase "qiskit.opflow.gradients.derivative_base.DerivativeBase") + +Deprecated: Base class for the Hessian of an expected value. + + + The class `qiskit.opflow.gradients.hessian_base.HessianBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **hess\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*CircuitGradient*](qiskit.opflow.gradients.CircuitGradient "qiskit.opflow.gradients.circuit_gradients.circuit_gradient.CircuitGradient")) – The method used to compute the state/probability gradient. Can be either `'param_shift'` or `'lin_comb'` or `'fin_diff'`. Ignored for gradients w\.r.t observable parameters. +* **kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Optional parameters for a CircuitGradient + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If method != `fin_diff` and `epsilon` is not None. + +## Attributes + + + +### hess\_method + +Returns `CircuitGradient`. + +**Returns** + +`CircuitGradient`. + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.NaturalGradient.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.NaturalGradient.md new file mode 100644 index 00000000000..d894df8caba --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.NaturalGradient.md @@ -0,0 +1,119 @@ +--- +title: NaturalGradient +description: API reference for qiskit.opflow.gradients.NaturalGradient +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.NaturalGradient +--- + +# NaturalGradient + + + +`qiskit.opflow.gradients.NaturalGradient(grad_method='lin_comb', qfi_method='lin_comb_full', regularization=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/natural_gradient.py "view source code") + +Bases: [`GradientBase`](qiskit.opflow.gradients.GradientBase "qiskit.opflow.gradients.gradient_base.GradientBase") + +Deprecated: Convert an operator expression to the first-order gradient. + +Given an ill-posed inverse problem + +> x = arg min\{||Ax-C||^2} (1) + +one can use regularization schemes can be used to stabilize the system and find a numerical solution + +> x\_lambda = arg min\{||Ax-C||^2 + lambda\*R(x)} (2) + +where R(x) represents the penalization term. + + + The class `qiskit.opflow.gradients.natural_gradient.NaturalGradient` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **grad\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*CircuitGradient*](qiskit.opflow.gradients.CircuitGradient "qiskit.opflow.gradients.circuit_gradients.circuit_gradient.CircuitGradient")) – The method used to compute the state gradient. Can be either `'param_shift'` or `'lin_comb'` or `'fin_diff'`. +* **qfi\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*CircuitQFI*](qiskit.opflow.gradients.CircuitQFI "qiskit.opflow.gradients.circuit_qfis.circuit_qfi.CircuitQFI")) – The method used to compute the QFI. Can be either `'lin_comb_full'` or `'overlap_block_diag'` or `'overlap_diag'`. +* **regularization** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Use the following regularization with a least square method to solve the underlying system of linear equations Can be either None or `'ridge'` or `'lasso'` or `'perturb_diag'` `'ridge'` and `'lasso'` use an automatic optimal parameter search If regularization is None but the metric is ill-conditioned or singular then a least square solver is used without regularization +* **kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Optional parameters for a CircuitGradient + +## Attributes + + + +### grad\_method + +Returns `CircuitGradient`. + +**Returns** + +`CircuitGradient`. + + + +### qfi\_method + +Returns `CircuitQFI`. + +Returns: `CircuitQFI`. + + + +### regularization + +Returns the regularization option. + +Returns: the regularization option. + +## Methods + +### convert + + + +`convert(operator, params=None)` + +**Parameters** + +* **operator** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The operator we are taking the gradient of. +* **params** ([*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] | None*) – The parameters we are taking the gradient with respect to. If not explicitly passed, they are inferred from the operator and sorted by name. + +**Returns** + +An operator whose evaluation yields the NaturalGradient. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `operator` does not represent an expectation value or the quantum state is not `CircuitStateFn`. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `params` contains a parameter not present in `operator`. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `operator` is not parameterized. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### nat\_grad\_combo\_fn + + + +`static nat_grad_combo_fn(x, regularization=None)` + +Natural Gradient Function Implementation. + +**Parameters** + +* **x** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Iterable consisting of Gradient, Quantum Fisher Information. +* **regularization** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Regularization method. + +**Returns** + +Natural Gradient. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the gradient has imaginary components that are non-negligible. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.QFI.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.QFI.md new file mode 100644 index 00000000000..eab7417bdc2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.QFI.md @@ -0,0 +1,66 @@ +--- +title: QFI +description: API reference for qiskit.opflow.gradients.QFI +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.QFI +--- + +# QFI + + + +`qiskit.opflow.gradients.QFI(qfi_method='lin_comb_full')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/qfi.py "view source code") + +Bases: [`QFIBase`](qiskit.opflow.gradients.QFIBase "qiskit.opflow.gradients.qfi_base.QFIBase") + +Deprecated: Compute the Quantum Fisher Information (QFI). + +Computes the QFI given a pure, parameterized quantum state, where QFI is: + +$$ +\mathrm{QFI}_{kl}= 4 \mathrm{Re}[\langle \partial_k \psi | \partial_l \psi \rangle + − \langle\partial_k \psi | \psi \rangle \langle\psi | \partial_l \psi \rangle]. +$$ + + + The class `qiskit.opflow.gradients.qfi.QFI` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +## Attributes + + + +### qfi\_method + +Returns `CircuitQFI`. + +**Returns** + +`CircuitQFI`. + +## Methods + +### convert + + + +`convert(operator, params=None)` + +**Parameters** + +* **operator** ([*CircuitStateFn*](qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn")) – The operator corresponding to the quantum state |ψ(ω)〉for which we compute the QFI +* **params** ([*ParameterVector*](qiskit.circuit.ParameterVector "qiskit.circuit.parametervector.ParameterVector") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*] | None*) – The parameters we are computing the QFI wrt: ω If not explicitly passed, they are inferred from the operator and sorted by name. + +**Returns** + +ListOp\[ListOp] where the operator at position k,l corresponds to QFI\_kl + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If operator is not parameterized. + +**Return type** + +[*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.QFIBase.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.QFIBase.md new file mode 100644 index 00000000000..552b5165d0f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.QFIBase.md @@ -0,0 +1,48 @@ +--- +title: QFIBase +description: API reference for qiskit.opflow.gradients.QFIBase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.gradients.QFIBase +--- + +# QFIBase + + + +`qiskit.opflow.gradients.QFIBase(qfi_method='lin_comb_full')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/gradients/qfi_base.py "view source code") + +Bases: [`DerivativeBase`](qiskit.opflow.gradients.DerivativeBase "qiskit.opflow.gradients.derivative_base.DerivativeBase") + +Deprecated: Base class for Quantum Fisher Information (QFI). + +Compute the Quantum Fisher Information (QFI) given a pure, parameterized quantum state. + +The QFI is: + +> \[QFI]kl= Re\[〈∂kψ|∂lψ〉−〈∂kψ|ψ〉〈ψ|∂lψ〉] \* 4. + + + The class `qiskit.opflow.gradients.qfi_base.QFIBase` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +**qfi\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*CircuitQFI*](qiskit.opflow.gradients.CircuitQFI "qiskit.opflow.gradients.circuit_qfis.circuit_qfi.CircuitQFI")) – The method used to compute the state/probability gradient. Can be either a [`CircuitQFI`](qiskit.opflow.gradients.CircuitQFI "qiskit.opflow.gradients.CircuitQFI") instance or one of the following pre-defined strings `'lin_comb_full'`, `` 'overlap_diag'` `` or `` 'overlap_block_diag'` ``. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if `qfi_method` is neither a `CircuitQFI` object nor one of the predefined strings. + +## Attributes + + + +### qfi\_method + +Returns `CircuitQFI`. + +**Returns** + +`CircuitQFI`. + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.gradients.md b/docs/api/qiskit/0.46/qiskit.opflow.gradients.md new file mode 100644 index 00000000000..982d7fe6c5a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.gradients.md @@ -0,0 +1,132 @@ +--- +title: gradients +description: API reference for qiskit.opflow.gradients +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow.gradients +--- + + + + + +# qiskit.opflow\.gradients + + + +## Gradients + + + +`qiskit.opflow.gradients` + + + The [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +Given an operator that represents either a quantum state resp. an expectation value, the gradient framework enables the evaluation of gradients, natural gradients, Hessians, as well as the Quantum Fisher Information. + +Suppose a parameterized quantum state |ψ(θ)〉 = V(θ)|ψ〉 with input state |ψ〉 and parameterized Ansatz V(θ), and an Operator O(ω). + +**Gradients** + +We want to compute one of: \* $d⟨ψ(θ)|O(ω)|ψ(θ)〉/ dω$ \* $d⟨ψ(θ)|O(ω)|ψ(θ)〉/ dθ$ \* $d⟨ψ(θ)|i〉⟨i|ψ(θ)〉/ dθ$ + +The last case corresponds to the gradient w\.r.t. the sampling probabilities of |ψ(θ). These gradients can be computed with different methods, i.e. a parameter shift, a linear combination of unitaries and a finite difference method. + +**Examples** + +```python +x = Parameter('x') +ham = x * X +a = Parameter('a') + +q = QuantumRegister(1) +qc = QuantumCircuit(q) +qc.h(q) +qc.p(params[0], q[0]) +op = ~StateFn(ham) @ CircuitStateFn(primitive=qc, coeff=1.) + +value_dict = {x: 0.1, a: np.pi / 4} + +ham_grad = Gradient(grad_method='param_shift').convert(operator=op, params=[x]) +ham_grad.assign_parameters(value_dict).eval() + +state_grad = Gradient(grad_method='lin_comb').convert(operator=op, params=[a]) +state_grad.assign_parameters(value_dict).eval() + +prob_grad = Gradient(grad_method='fin_diff').convert( + operator=CircuitStateFn(primitive=qc, coeff=1.), params=[a] +) +prob_grad.assign_parameters(value_dict).eval() +``` + +**Hessians** + +We want to compute one of: \* $d^2⟨ψ(θ)|O(ω)|ψ(θ)〉/ dω^2$ \* $d^2⟨ψ(θ)|O(ω)|ψ(θ)〉/ dθ^2$ \* $d^2⟨ψ(θ)|O(ω)|ψ(θ)〉/ dθ dω$ \* $d^2⟨ψ(θ)|i〉⟨i|ψ(θ)〉/ dθ^2$ + +The last case corresponds to the Hessian w\.r.t. the sampling probabilities of |ψ(θ)〉. Just as the first order gradients, the Hessians can be evaluated with different methods, i.e. a parameter shift, a linear combination of unitaries and a finite difference method. Given a tuple of parameters `Hessian().convert(op, param_tuple)` returns the value for the second order derivative. If a list of parameters is given `Hessian().convert(op, param_list)` returns the full Hessian for all the given parameters according to the given parameter order. + +**QFI** + +The Quantum Fisher Information QFI is a metric tensor which is representative for the representation capacity of a parameterized quantum state |ψ(θ)〉 = V(θ)|ψ〉 generated by an input state |ψ〉 and a parameterized Ansatz V(θ). The entries of the QFI for a pure state read $\mathrm{QFI}_{kl} = 4 \mathrm{Re}[〈∂kψ|∂lψ〉−〈∂kψ|ψ〉〈ψ|∂lψ〉]$. + +Just as for the previous derivative types, the QFI can be computed using different methods: a full representation based on a linear combination of unitaries implementation, a block-diagonal and a diagonal representation based on an overlap method. + +**Examples** + +```python +q = QuantumRegister(1) +qc = QuantumCircuit(q) +qc.h(q) +qc.p(params[0], q[0]) +op = ~StateFn(ham) @ CircuitStateFn(primitive=qc, coeff=1.) + +value_dict = {x: 0.1, a: np.pi / 4} + +qfi = QFI('lin_comb_full').convert( + operator=CircuitStateFn(primitive=qc, coeff=1.), params=[a] +) +qfi.assign_parameters(value_dict).eval() +``` + +**NaturalGradients** + +The natural gradient is a special gradient method which re-scales a gradient w\.r.t. a state parameter with the inverse of the corresponding Quantum Fisher Information (QFI) $\mathrm{QFI}^{-1} d⟨ψ(θ)|O(ω)|ψ(θ)〉/ dθ$. Hereby, we can choose a gradient as well as a QFI method and a regularization method which is used together with a least square solver instead of exact inversion of the QFI: + +**Examples** + +```python +op = ~StateFn(ham) @ CircuitStateFn(primitive=qc, coeff=1.) +nat_grad = NaturalGradient(grad_method='lin_comb, + qfi_method='lin_comb_full', + regularization='ridge').convert(operator=op, params=params) +``` + +The derivative classes come with a gradient\_wrapper() function which returns the corresponding callable and are thus compatible with the optimizers. + +### Base Classes + +| | | +| -------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------ | +| [`DerivativeBase`](qiskit.opflow.gradients.DerivativeBase "qiskit.opflow.gradients.DerivativeBase")() | Deprecated: Base class for differentiating opflow objects. | +| [`GradientBase`](qiskit.opflow.gradients.GradientBase "qiskit.opflow.gradients.GradientBase")(\[grad\_method]) | Deprecated: Base class for first-order operator gradient. | +| [`HessianBase`](qiskit.opflow.gradients.HessianBase "qiskit.opflow.gradients.HessianBase")(\[hess\_method]) | Deprecated: Base class for the Hessian of an expected value. | +| [`QFIBase`](qiskit.opflow.gradients.QFIBase "qiskit.opflow.gradients.QFIBase")(\[qfi\_method]) | Deprecated: Base class for Quantum Fisher Information (QFI). | + +### Converters + +| | | +| -------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------- | +| [`CircuitGradient`](qiskit.opflow.gradients.CircuitGradient "qiskit.opflow.gradients.CircuitGradient")() | Deprecated: Circuit to gradient operator converter. | +| [`CircuitQFI`](qiskit.opflow.gradients.CircuitQFI "qiskit.opflow.gradients.CircuitQFI")() | Deprecated: Circuit to Quantum Fisher Information operator converter. | + +### Derivatives + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------- | +| [`Gradient`](qiskit.opflow.gradients.Gradient "qiskit.opflow.gradients.Gradient")(\[grad\_method]) | Deprecated: Convert an operator expression to the first-order gradient. | +| [`Hessian`](qiskit.opflow.gradients.Hessian "qiskit.opflow.gradients.Hessian")(\[hess\_method]) | Deprecated: Compute the Hessian of an expected value. | +| [`NaturalGradient`](qiskit.opflow.gradients.NaturalGradient "qiskit.opflow.gradients.NaturalGradient")(\[grad\_method, qfi\_method, ...]) | Deprecated: Convert an operator expression to the first-order gradient. | +| [`QFI`](qiskit.opflow.gradients.QFI "qiskit.opflow.gradients.QFI")(\[qfi\_method]) | Deprecated: Compute the Quantum Fisher Information (QFI). | + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.list_ops.ComposedOp.md b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.ComposedOp.md new file mode 100644 index 00000000000..19c3f912911 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.ComposedOp.md @@ -0,0 +1,254 @@ +--- +title: ComposedOp +description: API reference for qiskit.opflow.list_ops.ComposedOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.list_ops.ComposedOp +--- + +# ComposedOp + + + +`qiskit.opflow.list_ops.ComposedOp(oplist, coeff=1.0, abelian=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/list_ops/composed_op.py "view source code") + +Bases: [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +Deprecated: A class for lazily representing compositions of Operators. Often Operators cannot be efficiently composed with one another, but may be manipulated further so that they can be composed later. This class holds logic to indicate that the Operators in `oplist` are meant to be composed, and therefore if they reach a point in which they can be, such as after conversion to QuantumCircuits or matrices, they can be reduced by composition. + + + The class `qiskit.opflow.list_ops.composed_op.ComposedOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **oplist** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")*]*) – The Operators being composed. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A coefficient multiplying the operator +* **abelian** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Indicates whether the Operators in `oplist` are known to mutually commute. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### abelian + +Whether the Operators in `oplist` are known to commute with one another. + +**Returns** + +A bool indicating whether the `oplist` is Abelian. + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### coeffs + +Return a list of the coefficients of the operators listed. Raises exception for nested Listops. + + + +### combo\_fn + +The function defining how to combine `oplist` (or Numbers, or NumPy arrays) to produce the Operator’s underlying function. For example, SummedOp’s combination function is to add all of the Operators in `oplist`. + +**Returns** + +The combination function. + + + +### distributive + + + +### grad\_combo\_fn + +The gradient of `combo_fn`. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### oplist + +The list of `OperatorBases` defining the underlying function of this Operator. + +**Returns** + +The Operators defining the ListOp + + + +### parameters + + + +### settings + +Return settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*ComposedOp*](#qiskit.opflow.list_ops.ComposedOp "qiskit.opflow.list_ops.composed_op.ComposedOp") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +ListOp’s eval recursively evaluates each Operator in `oplist`, and combines the results using the recombination function `combo_fn`. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function. + +**Returns** + +The output of the `oplist` Operators’ evaluation function, combined with the `combo_fn`. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Raises** + +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – Raised if called for a subclass which is not distributive. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Operators with mixed hierarchies, such as a ListOp containing both PrimitiveOps and ListOps, are not supported. +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – Attempting to call ListOp’s eval from a non-distributive subclass. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### non\_distributive\_reduce + + + +`non_distributive_reduce()` + +Reduce without attempting to expand all distributive compositions. + +**Returns** + +The reduced Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_circuit + + + +`to_circuit()` + +Returns the quantum circuit, representing the composed operator. + +**Returns** + +The circuit representation of the composed operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – for operators where a single underlying circuit can not be obtained. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.list_ops.ListOp.md b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.ListOp.md new file mode 100644 index 00000000000..be84b38a21d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.ListOp.md @@ -0,0 +1,518 @@ +--- +title: ListOp +description: API reference for qiskit.opflow.list_ops.ListOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.list_ops.ListOp +--- + +# ListOp + + + +`qiskit.opflow.list_ops.ListOp(oplist, combo_fn=None, coeff=1.0, abelian=False, grad_combo_fn=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/list_ops/list_op.py "view source code") + +Bases: [`OperatorBase`](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +Deprecated: A Class for manipulating List Operators, and parent class to `SummedOp`, `ComposedOp` and `TensoredOp`. + +List Operators are classes for storing and manipulating lists of Operators, State functions, or Measurements, and include some rule or `combo_fn` defining how the Operator functions of the list constituents should be combined to form to cumulative Operator function of the `ListOp`. For example, a `SummedOp` has an addition-based `combo_fn`, so once the Operators in its list are evaluated against some bitstring to produce a list of results, we know to add up those results to produce the final result of the `SummedOp`’s evaluation. In theory, this `combo_fn` can be any function over classical complex values, but for convenience we’ve chosen for them to be defined over NumPy arrays and values. This way, large numbers of evaluations, such as after calling `to_matrix` on the list constituents, can be efficiently combined. While the combination function is defined over classical values, it should be understood as the operation by which each Operators’ underlying function is combined to form the underlying Operator function of the `ListOp`. In this way, the `ListOps` are the basis for constructing large and sophisticated Operators, State Functions, and Measurements. + +The base `ListOp` class is particularly interesting, as its `combo_fn` is “the identity list Operation”. Meaning, if we understand the `combo_fn` as a function from a list of complex values to some output, one such function is returning the list as-is. This is powerful for constructing compact hierarchical Operators which return many measurements in multiple dimensional lists. + + + The class `qiskit.opflow.list_ops.list_op.ListOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **oplist** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")*]*) – The list of `OperatorBases` defining this Operator’s underlying function. +* **combo\_fn** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – The recombination function to combine classical results of the `oplist` Operators’ eval functions (e.g. sum). Default is lambda x: x. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A coefficient multiplying the operator +* **abelian** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Indicates whether the Operators in `oplist` are known to mutually commute. +* **grad\_combo\_fn** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – The gradient of recombination function. If None, the gradient will be computed automatically. +* **the** (*Note that the default "recombination function" lambda above is essentially*) – +* **values** (*identity - it accepts the list of*) – +* **list.** (*and returns them in a*) – + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### abelian + +Whether the Operators in `oplist` are known to commute with one another. + +**Returns** + +A bool indicating whether the `oplist` is Abelian. + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### coeffs + +Return a list of the coefficients of the operators listed. Raises exception for nested Listops. + + + +### combo\_fn + +The function defining how to combine `oplist` (or Numbers, or NumPy arrays) to produce the Operator’s underlying function. For example, SummedOp’s combination function is to add all of the Operators in `oplist`. + +**Returns** + +The combination function. + + + +### distributive + +Indicates whether the ListOp or subclass is distributive under composition. ListOp and SummedOp are, meaning that (opv @ op) = (opv\[0] @ op + opv\[1] @ op) (using plus for SummedOp, list for ListOp, etc.), while ComposedOp and TensoredOp do not behave this way. + +**Returns** + +A bool indicating whether the ListOp is distributive under composition. + + + +### grad\_combo\_fn + +The gradient of `combo_fn`. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### oplist + +The list of `OperatorBases` defining the underlying function of this Operator. + +**Returns** + +The Operators defining the ListOp + + + +### parameters + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*ListOp*](#qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*ListOp*](#qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +### assign\_parameters + + + +`assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### default\_combo\_fn + + + +`static default_combo_fn(x)` + +ListOp default combo function i.e. lambda x: x + +**Return type** + +[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +ListOp’s eval recursively evaluates each Operator in `oplist`, and combines the results using the recombination function `combo_fn`. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function. + +**Returns** + +The output of the `oplist` Operators’ evaluation function, combined with the `combo_fn`. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Raises** + +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – Raised if called for a subclass which is not distributive. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Operators with mixed hierarchies, such as a ListOp containing both PrimitiveOps and ListOps, are not supported. +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – Attempting to call ListOp’s eval from a non-distributive subclass. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### exp\_i + + + +`exp_i()` + +Return an `OperatorBase` equivalent to an exponentiation of self \* -i, e^(-i\*op). + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### log\_i + + + +`log_i(massive=False)` + +Return a `MatrixOp` equivalent to log(H)/-i for this operator H. This function is the effective inverse of exp\_i, equivalent to finding the Hermitian Operator which produces self when exponentiated. For proper ListOps, applies `log_i` to all ops in oplist. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### mul + + + +`mul(scalar)` + +Returns the scalar multiplication of the Operator, overloaded by `*`, including support for Terra’s `Parameters`, which can be bound to values later (via `bind_parameters`). + +**Parameters** + +**scalar** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The real or complex scalar by which to multiply the Operator, or the `ParameterExpression` to serve as a placeholder for a scalar factor. + +**Returns** + +An `OperatorBase` equivalent to product of self and scalar. + +**Return type** + +[*ListOp*](#qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +### permute + + + +`permute(permutation)` + +Permute the qubits of the operator. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j should be permuted to position permutation\[j]. + +**Returns** + +A new ListOp representing the permuted operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if indices do not define a new index for each qubit. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### power + + + +`power(exponent)` + +Return Operator composed with self multiple times, overloaded by `**`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensorpower + + + +`tensorpower(other)` + +Return tensor product with self multiple times, overloaded by `^`. + +**Parameters** + +**other** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The int number of times to tensor product self with itself via `tensorpower`. + +**Returns** + +An `OperatorBase` equivalent to the tensorpower of self by other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Returns an equivalent Operator composed of only QuantumCircuit-based primitives, such as `CircuitOp` and `CircuitStateFn`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Returns an equivalent Operator composed of only NumPy-based primitives, such as `MatrixOp` and `VectorStateFn`. + +**Return type** + +[*ListOp*](#qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +### to\_pauli\_op + + + +`to_pauli_op(massive=False)` + +Returns an equivalent Operator composed of only Pauli-based primitives, such as `PauliOp`. + +**Return type** + +[*ListOp*](#qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +### to\_spmatrix + + + +`to_spmatrix()` + +Returns SciPy sparse matrix representation of the Operator. + +**Returns** + +CSR sparse matrix representation of the Operator, or List thereof. + +**Return type** + +*spmatrix* | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[*spmatrix*] + +### traverse + + + +`traverse(convert_fn, coeff=None)` + +Apply the convert\_fn to each node in the oplist. + +**Parameters** + +* **convert\_fn** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")) – The function to apply to the internal OperatorBase. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *| None*) – A coefficient to multiply by after applying convert\_fn. If it is None, self.coeff is used instead. + +**Returns** + +The converted ListOp. + +**Return type** + +[*ListOp*](#qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.list_ops.SummedOp.md b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.SummedOp.md new file mode 100644 index 00000000000..0fe3009f156 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.SummedOp.md @@ -0,0 +1,253 @@ +--- +title: SummedOp +description: API reference for qiskit.opflow.list_ops.SummedOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.list_ops.SummedOp +--- + +# SummedOp + + + +`qiskit.opflow.list_ops.SummedOp(oplist, coeff=1.0, abelian=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/list_ops/summed_op.py "view source code") + +Bases: [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +Deprecated: A class for lazily representing sums of Operators. Often Operators cannot be efficiently added to one another, but may be manipulated further so that they can be later. This class holds logic to indicate that the Operators in `oplist` are meant to be added together, and therefore if they reach a point in which they can be, such as after evaluation or conversion to matrices, they can be reduced by addition. + + + The class `qiskit.opflow.list_ops.summed_op.SummedOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **oplist** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")*]*) – The Operators being summed. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A coefficient multiplying the operator +* **abelian** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Indicates whether the Operators in `oplist` are known to mutually commute. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### abelian + +Whether the Operators in `oplist` are known to commute with one another. + +**Returns** + +A bool indicating whether the `oplist` is Abelian. + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### coeffs + +Return a list of the coefficients of the operators listed. Raises exception for nested Listops. + + + +### combo\_fn + +The function defining how to combine `oplist` (or Numbers, or NumPy arrays) to produce the Operator’s underlying function. For example, SummedOp’s combination function is to add all of the Operators in `oplist`. + +**Returns** + +The combination function. + + + +### distributive + + + +### grad\_combo\_fn + +The gradient of `combo_fn`. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### oplist + +The list of `OperatorBases` defining the underlying function of this Operator. + +**Returns** + +The Operators defining the ListOp + + + +### parameters + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of `self` and `other`, overloaded by `+`. + + + This appends `other` to `self.oplist` without checking `other` is already included or not. If you want to simplify them, please use `simplify()`. + + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +A `SummedOp` equivalent to the sum of self and other. + +**Return type** + +[*SummedOp*](#qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### collapse\_summands + + + +`collapse_summands()` + +Return Operator by simplifying duplicate operators. + +E.g., `SummedOp([2 * X ^ Y, X ^ Y]).collapse_summands() -> SummedOp([3 * X ^ Y])`. + +**Returns** + +A simplified `SummedOp` equivalent to self. + +**Return type** + +[*SummedOp*](#qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### equals + + + +`equals(other)` + +Check if other is equal to self. + + + This is not a mathematical check for equality. If `self` and `other` implement the same operation but differ in the representation (e.g. different type of summands) `equals` will evaluate to `False`. + + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The other operator to check for equality. + +**Returns** + +True, if other and self are equal, otherwise False. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +**Examples** + +```python +>>> from qiskit.opflow import X, Z +>>> 2 * X == X + X +True +>>> X + Z == Z + X +True +``` + +### reduce + + + +`reduce()` + +Try collapsing list or trees of sums. + +Tries to sum up duplicate operators and reduces the operators in the sum. + +**Returns** + +A collapsed version of self, if possible. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_circuit + + + +`to_circuit()` + +Returns the quantum circuit, representing the SummedOp. In the first step, the SummedOp is converted to MatrixOp. This is straightforward for most operators, but it is not supported for operators containing parameterized PrimitiveOps (in that case, OpflowError is raised). In the next step, the MatrixOp representation of SummedOp is converted to circuit. In most cases, if the summands themselves are unitary operators, the SummedOp itself is non-unitary and can not be converted to circuit. In that case, ExtensionError is raised in the underlying modules. + +**Returns** + +The circuit representation of the summed operator. + +**Raises** + +* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if SummedOp can not be converted to MatrixOp (e.g. SummedOp is composed of +* **parameterized PrimitiveOps**\*\*)\*\*\*\*.\*\* – + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Returns an equivalent Operator composed of only NumPy-based primitives, such as `MatrixOp` and `VectorStateFn`. + +**Return type** + +[*SummedOp*](#qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### to\_pauli\_op + + + +`to_pauli_op(massive=False)` + +Returns an equivalent Operator composed of only Pauli-based primitives, such as `PauliOp`. + +**Return type** + +[*SummedOp*](#qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.list_ops.TensoredOp.md b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.TensoredOp.md new file mode 100644 index 00000000000..bea4f8dcec2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.TensoredOp.md @@ -0,0 +1,218 @@ +--- +title: TensoredOp +description: API reference for qiskit.opflow.list_ops.TensoredOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.list_ops.TensoredOp +--- + +# TensoredOp + + + +`qiskit.opflow.list_ops.TensoredOp(oplist, coeff=1.0, abelian=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/list_ops/tensored_op.py "view source code") + +Bases: [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +Deprecated: A class for lazily representing tensor products of Operators. Often Operators cannot be efficiently tensored to one another, but may be manipulated further so that they can be later. This class holds logic to indicate that the Operators in `oplist` are meant to be tensored together, and therefore if they reach a point in which they can be, such as after conversion to QuantumCircuits, they can be reduced by tensor product. + + + The class `qiskit.opflow.list_ops.tensored_op.TensoredOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **oplist** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")*]*) – The Operators being tensored. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A coefficient multiplying the operator +* **abelian** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Indicates whether the Operators in `oplist` are known to mutually commute. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### abelian + +Whether the Operators in `oplist` are known to commute with one another. + +**Returns** + +A bool indicating whether the `oplist` is Abelian. + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### coeffs + +Return a list of the coefficients of the operators listed. Raises exception for nested Listops. + + + +### combo\_fn + +The function defining how to combine `oplist` (or Numbers, or NumPy arrays) to produce the Operator’s underlying function. For example, SummedOp’s combination function is to add all of the Operators in `oplist`. + +**Returns** + +The combination function. + + + +### distributive + + + +### grad\_combo\_fn + +The gradient of `combo_fn`. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### oplist + +The list of `OperatorBases` defining the underlying function of this Operator. + +**Returns** + +The Operators defining the ListOp + + + +### parameters + + + +### settings + +Return settings. + +## Methods + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +ListOp’s eval recursively evaluates each Operator in `oplist`, and combines the results using the recombination function `combo_fn`. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function. + +**Returns** + +The output of the `oplist` Operators’ evaluation function, combined with the `combo_fn`. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Raises** + +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – Raised if called for a subclass which is not distributive. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Operators with mixed hierarchies, such as a ListOp containing both PrimitiveOps and ListOps, are not supported. +* [**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – Attempting to call ListOp’s eval from a non-distributive subclass. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_circuit + + + +`to_circuit()` + +Returns the quantum circuit, representing the tensored operator. + +**Returns** + +The circuit representation of the tensored operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – for operators where a single underlying circuit can not be produced. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.list_ops.md b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.md new file mode 100644 index 00000000000..2552c2938c8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.list_ops.md @@ -0,0 +1,54 @@ +--- +title: list_ops +description: API reference for qiskit.opflow.list_ops +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow.list_ops +--- + + + + + +# qiskit.opflow\.list\_ops + + + +## List Operators + + + +`qiskit.opflow.list_ops` + + + The [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +List Operators are classes for storing and manipulating lists of Operators, State functions, or Measurements, and include some rule or `combo_fn` defining how the Operator functions of the list constituents should be combined to form to cumulative Operator function of the [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.ListOp"). For example, a [`SummedOp`](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp") has an addition-based `combo_fn`, so once the Operators in its list are evaluated against some bitstring to produce a list of results, we know to add up those results to produce the final result of the [`SummedOp`](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp")’s evaluation. In theory, this `combo_fn` can be any function over classical complex values, but for convenience we’ve chosen for them to be defined over NumPy arrays and values. This way, large numbers of evaluations, such as after calling [`to_matrix()`](qiskit.opflow.list_ops.ListOp#to_matrix "qiskit.opflow.list_ops.ListOp.to_matrix") on the list constituents, can be efficiently combined. While the combination function is defined over classical values, it should be understood as the operation by which each Operators’ underlying function is combined to form the underlying Operator function of the [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.ListOp"). In this way, the [`list_ops`](#module-qiskit.opflow.list_ops "qiskit.opflow.list_ops") are the basis for constructing large and sophisticated Operators, State Functions, and Measurements. + +The base [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.ListOp") class is particularly interesting, as its `combo_fn` is “the identity list Operation”. Meaning, if we understand the `combo_fn` as a function from a list of complex values to some output, one such function is returning the list as-is. This is powerful for constructing compact hierarchical Operators which return many measurements in multiple dimensional lists. For example, if we want to estimate the gradient of some Observable measurement with respect to some parameters in the State function, we can construct separate evaluation Operators for each parameter’s gradient which we must keep track of ourselves in a list, or we can construct a single [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.ListOp") containing the evaluation Operators for each parameter, so the [`eval()`](qiskit.opflow.list_ops.ListOp#eval "qiskit.opflow.list_ops.ListOp.eval") function returns the full gradient vector. Another excellent example of this power is constructing a Quantum kernel matrix: + +```python +data_sfn_list_op = ListOp(data_circuit_state_fns) +qkernel_op_circuits = ~data_sfn_list_op @ data_sfn_list_op +qkernel_sampled = CircuitSampler(backend).convert(qkernel_op_circuits) +qkernel_sampled.eval() +``` + +This will return the two dimensional Quantum kernel matrix, where each element is the inner product of some pair of the data State functions, or in other terms, a measurement of one data [`CircuitStateFn`](qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.CircuitStateFn") by another. + +You’ll encounter the [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.ListOp") subclasses ([`SummedOp`](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp"), [`ComposedOp`](qiskit.opflow.list_ops.ComposedOp "qiskit.opflow.list_ops.ComposedOp"), or [`TensoredOp`](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.TensoredOp")) more often as lazy results of Operator construction operations than as something you need to explicitly construct. Any time we don’t know how to efficiently add, compose, or tensor two [`primitive_ops`](qiskit.opflow.primitive_ops#module-qiskit.opflow.primitive_ops "qiskit.opflow.primitive_ops") or [`state_fns`](qiskit.opflow.state_fns#module-qiskit.opflow.state_fns "qiskit.opflow.state_fns") together, they’re returned in a [`SummedOp`](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp"), [`ComposedOp`](qiskit.opflow.list_ops.ComposedOp "qiskit.opflow.list_ops.ComposedOp"), or [`TensoredOp`](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.TensoredOp"), respectively, so we can still work with their combined function and perhaps convert them into an efficiently combine-able format later. + + + Combination functions do not always behave predictably, and you must understand the conversions you’re making when you working with [`list_ops`](#module-qiskit.opflow.list_ops "qiskit.opflow.list_ops"). Most notably - sampling a sum of two circuits on Quantum hardware does not incorporate interference between the wavefunctions! In this case, we’re sending our State functions through a depolarizing channel before adding them, rather than adding them directly before the measurement. + + +### List Operators + +| | | +| -------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------- | +| [`ListOp`](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.ListOp")(oplist\[, combo\_fn, coeff, abelian, ...]) | Deprecated: A Class for manipulating List Operators, and parent class to `SummedOp`, `ComposedOp` and `TensoredOp`. | +| [`ComposedOp`](qiskit.opflow.list_ops.ComposedOp "qiskit.opflow.list_ops.ComposedOp")(oplist\[, coeff, abelian]) | Deprecated: A class for lazily representing compositions of Operators. | +| [`SummedOp`](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.SummedOp")(oplist\[, coeff, abelian]) | Deprecated: A class for lazily representing sums of Operators. | +| [`TensoredOp`](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.TensoredOp")(oplist\[, coeff, abelian]) | Deprecated: A class for lazily representing tensor products of Operators. | + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.CircuitOp.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.CircuitOp.md new file mode 100644 index 00000000000..749d22e0a5d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.CircuitOp.md @@ -0,0 +1,338 @@ +--- +title: CircuitOp +description: API reference for qiskit.opflow.primitive_ops.CircuitOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.primitive_ops.CircuitOp +--- + +# CircuitOp + + + +`qiskit.opflow.primitive_ops.CircuitOp(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/primitive_ops/circuit_op.py "view source code") + +Bases: [`PrimitiveOp`](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + +Deprecated: Class for Operators backed by Terra’s `QuantumCircuit` module. + + + The class `qiskit.opflow.primitive_ops.circuit_op.CircuitOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The QuantumCircuit which defines the +* **function.** (*behavior of the underlying*) – +* **coeff** – A coefficient multiplying the primitive + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Unsupported primitive, or primitive has ClassicalRegisters. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`QuantumCircuit` + +The primitive defining the underlying function of the Operator. + +**Returns** + +The primitive object. + + + +### settings + +Return operator settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*CircuitOp*](#qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.circuit_op.CircuitOp") + +### assign\_parameters + + + +`assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### permute + + + +`permute(permutation)` + +Permute the qubits of the circuit. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j of the circuit should be permuted to position permutation\[j]. + +**Returns** + +A new CircuitOp containing the permuted circuit. + +**Return type** + +[*CircuitOp*](#qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.circuit_op.CircuitOp") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*CircuitOp*](#qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.circuit_op.CircuitOp") | [*TensoredOp*](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.tensored_op.TensoredOp") + +### to\_circuit + + + +`to_circuit()` + +Returns a `QuantumCircuit` equivalent to this Operator. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Returns a `CircuitOp` equivalent to this Operator. + +**Return type** + +[*CircuitOp*](#qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.circuit_op.CircuitOp") + +### to\_instruction + + + +`to_instruction()` + +Returns an `Instruction` equivalent to this Operator. + +**Return type** + +[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.MatrixOp.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.MatrixOp.md new file mode 100644 index 00000000000..5d2829aa22b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.MatrixOp.md @@ -0,0 +1,306 @@ +--- +title: MatrixOp +description: API reference for qiskit.opflow.primitive_ops.MatrixOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.primitive_ops.MatrixOp +--- + +# MatrixOp + + + +`qiskit.opflow.primitive_ops.MatrixOp(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/primitive_ops/matrix_op.py "view source code") + +Bases: [`PrimitiveOp`](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + +Deprecated: Class for Operators represented by matrices, backed by Terra’s `Operator` module. + + + The class `qiskit.opflow.primitive_ops.matrix_op.MatrixOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The matrix-like object which defines the behavior of the underlying function. +* **coeff** – A coefficient multiplying the primitive + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – invalid parameters. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – invalid parameters. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`Operator` + +The primitive defining the underlying function of the Operator. + +**Returns** + +The primitive object. + + + +### settings + +Return operator settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*MatrixOp*](#qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.matrix_op.MatrixOp") | [*SummedOp*](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*MatrixOp*](#qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.matrix_op.MatrixOp") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### exp\_i + + + +`exp_i()` + +Return a `CircuitOp` equivalent to e^-iH for this operator H + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### permute + + + +`permute(permutation=None)` + +Creates a new MatrixOp that acts on the permuted qubits. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – A list defining where each qubit should be permuted. The qubit at index j should be permuted to position permutation\[j]. + +**Returns** + +A new MatrixOp representing the permuted operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if indices do not define a new index for each qubit. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*MatrixOp*](#qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.matrix_op.MatrixOp") | [*TensoredOp*](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.tensored_op.TensoredOp") + +### to\_instruction + + + +`to_instruction()` + +Returns an `Instruction` equivalent to this Operator. + +**Return type** + +[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Returns a `MatrixOp` equivalent to this Operator. + +**Return type** + +[*MatrixOp*](#qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.matrix_op.MatrixOp") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliOp.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliOp.md new file mode 100644 index 00000000000..b199d43267a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliOp.md @@ -0,0 +1,337 @@ +--- +title: PauliOp +description: API reference for qiskit.opflow.primitive_ops.PauliOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.primitive_ops.PauliOp +--- + +# PauliOp + + + +`qiskit.opflow.primitive_ops.PauliOp(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/primitive_ops/pauli_op.py "view source code") + +Bases: [`PrimitiveOp`](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + +Deprecated: Class for Operators backed by Terra’s `Pauli` module. + + + The class `qiskit.opflow.primitive_ops.pauli_op.PauliOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The Pauli which defines the behavior of the underlying function. +* **coeff** – A coefficient multiplying the primitive. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – invalid parameters. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`Pauli` + +The primitive defining the underlying function of the Operator. + +**Returns** + +The primitive object. + + + +### settings + +Return operator settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*PauliOp*](#qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### exp\_i + + + +`exp_i()` + +Return a `CircuitOp` equivalent to e^-iH for this operator H. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### permute + + + +`permute(permutation)` + +Permutes the sequence of Pauli matrices. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each Pauli should be permuted. The Pauli at index j of the primitive should be permuted to position permutation\[j]. + +**Returns** + +A new PauliOp representing the permuted operator. For operator (X ^ Y ^ Z) and indices=\[1,2,4], it returns (X ^ I ^ Y ^ Z ^ I). + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if indices do not define a new index for each qubit. + +**Return type** + +[*PauliOp*](#qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_circuit + + + +`to_circuit()` + +Returns a `QuantumCircuit` equivalent to this Operator. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### to\_instruction + + + +`to_instruction()` + +Returns an `Instruction` equivalent to this Operator. + +**Return type** + +[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_pauli\_op + + + +`to_pauli_op(massive=False)` + +Returns a sum of `PauliOp` s equivalent to this Operator. + +**Return type** + +[*PauliOp*](#qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") + +### to\_spmatrix + + + +`to_spmatrix()` + +Returns SciPy sparse matrix representation of the Operator. + +**Returns** + +CSR sparse matrix representation of the Operator. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – invalid parameters. + +**Return type** + +*spmatrix* + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliSumOp.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliSumOp.md new file mode 100644 index 00000000000..20776cec8f6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PauliSumOp.md @@ -0,0 +1,449 @@ +--- +title: PauliSumOp +description: API reference for qiskit.opflow.primitive_ops.PauliSumOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.primitive_ops.PauliSumOp +--- + +# PauliSumOp + + + +`qiskit.opflow.primitive_ops.PauliSumOp(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/primitive_ops/pauli_sum_op.py "view source code") + +Bases: [`PrimitiveOp`](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp") + +Deprecated: Class for Operators backed by Terra’s `SparsePauliOp` class. + + + The class `qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The SparsePauliOp which defines the behavior of the underlying function. +* **coeff** – A coefficient multiplying the primitive. +* **grouping\_type** – The type of grouping. If None, the operator is not grouped. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – invalid parameters. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### coeffs + +Return the Pauli coefficients. + + + +### grouping\_type + +Type of Grouping + +**Type** + +Returns + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`SparsePauliOp` + +The primitive defining the underlying function of the Operator. + +**Returns** + +The primitive object. + + + +### settings + +Return operator settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*PauliSumOp*](#qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### exp\_i + + + +`exp_i()` + +Return a `CircuitOp` equivalent to e^-iH for this operator H. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### from\_list + + + +`classmethod from_list(pauli_list, coeff=1.0, dtype=)` + +Construct from a pauli\_list with the form \[(pauli\_str, coeffs)] + +**Parameters** + +* **pauli\_list** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*]]*) – A list of Tuple of pauli\_str and coefficient. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A coefficient multiplying the primitive. +* **dtype** ([*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)")) – The dtype to use to construct the internal SparsePauliOp. Defaults to `complex`. + +**Returns** + +The PauliSumOp constructed from the pauli\_list. + +**Return type** + +[*PauliSumOp*](#qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") + +### is\_hermitian + + + +`is_hermitian()` + +Return True if the operator is hermitian. + +Returns: Boolean value + +### is\_zero + + + +`is_zero()` + +Return this operator is zero operator or not. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### matrix\_iter + + + +`matrix_iter(sparse=False)` + +Return a matrix representation iterator. + +This is a lazy iterator that converts each term in the PauliSumOp into a matrix as it is used. To convert to a single matrix use the [`to_matrix()`](#qiskit.opflow.primitive_ops.PauliSumOp.to_matrix "qiskit.opflow.primitive_ops.PauliSumOp.to_matrix") method. + +**Parameters** + +**sparse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – optionally return sparse CSR matrices if True, otherwise return Numpy array matrices (Default: False) + +**Returns** + +matrix iterator object for the PauliSumOp. + +**Return type** + +MatrixIterator + +### mul + + + +`mul(scalar)` + +Returns the scalar multiplication of the Operator, overloaded by `*`, including support for Terra’s `Parameters`, which can be bound to values later (via `bind_parameters`). + +**Parameters** + +**scalar** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The real or complex scalar by which to multiply the Operator, or the `ParameterExpression` to serve as a placeholder for a scalar factor. + +**Returns** + +An `OperatorBase` equivalent to product of self and scalar. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### permute + + + +`permute(permutation)` + +Permutes the sequence of `PauliSumOp`. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each Pauli should be permuted. The Pauli at index j of the primitive should be permuted to position permutation\[j]. + +**Returns** + +A new PauliSumOp representing the permuted operator. For operator (X ^ Y ^ Z) and indices=\[1,2,4], it returns (X ^ I ^ Y ^ Z ^ I). + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if indices do not define a new index for each qubit. + +**Return type** + +[*PauliSumOp*](#qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`reduce(atol=None, rtol=None)` + +Simplify the primitive `SparsePauliOp`. + +**Parameters** + +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Absolute tolerance for checking if coefficients are zero (Default: 1e-8). +* **rtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Relative tolerance for checking if coefficients are zero (Default: 1e-5). + +**Returns** + +The simplified `PauliSumOp`. + +**Return type** + +[*PauliSumOp*](#qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*PauliSumOp*](#qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") | [*TensoredOp*](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.tensored_op.TensoredOp") + +### to\_instruction + + + +`to_instruction()` + +Returns an `Instruction` equivalent to this Operator. + +**Return type** + +[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_pauli\_op + + + +`to_pauli_op(massive=False)` + +Returns a sum of `PauliOp` s equivalent to this Operator. + +**Return type** + +[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.pauli_op.PauliOp") | [*SummedOp*](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### to\_spmatrix + + + +`to_spmatrix()` + +Returns SciPy sparse matrix representation of the `PauliSumOp`. + +**Returns** + +CSR sparse matrix representation of the `PauliSumOp`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – invalid parameters. + +**Return type** + +*spmatrix* + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PrimitiveOp.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PrimitiveOp.md new file mode 100644 index 00000000000..65736076e39 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.PrimitiveOp.md @@ -0,0 +1,429 @@ +--- +title: PrimitiveOp +description: API reference for qiskit.opflow.primitive_ops.PrimitiveOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.primitive_ops.PrimitiveOp +--- + +# PrimitiveOp + + + +`qiskit.opflow.primitive_ops.PrimitiveOp(primitive, coeff=1.0)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/primitive_ops/primitive_op.py "view source code") + +Bases: [`OperatorBase`](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +Deprecated: A class for representing basic Operators, backed by Operator primitives from Terra. This class (and inheritors) primarily serves to allow the underlying primitives to “flow” - i.e. interoperability and adherence to the Operator formalism - while the core computational logic mostly remains in the underlying primitives. For example, we would not produce an interface in Terra in which `QuantumCircuit1 + QuantumCircuit2` equaled the Operator sum of the circuit unitaries, rather than simply appending the circuits. However, within the Operator flow summing the unitaries is the expected behavior. + +Note that all mathematical methods are not in-place, meaning that they return a new object, but the underlying primitives are not copied. + + + The class `qiskit.opflow.primitive_ops.primitive_op.PrimitiveOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** ([*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *| spmatrix |*[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") *|*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")) – The operator primitive being wrapped. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A coefficient multiplying the primitive. + +**Return type** + +[PrimitiveOp](#qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.PrimitiveOp") + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +The primitive defining the underlying function of the Operator. + +**Returns** + +The primitive object. + + + +### settings + +Return operator settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### assign\_parameters + + + +`assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Return Operator Composition between self and other (linear algebra-style: A\@B(x) = A(B(x))), overloaded by `@`. + +Note: You must be conscious of Quantum Circuit vs. Linear Algebra ordering conventions. Meaning, X.compose(Y) produces an X∘Y on qubit 0, but would produce a QuantumCircuit which looks like + +> -\[Y]-\[X]- + +Because Terra prints circuits with the initial state at the left side of the circuit. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` with which to compose self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An `OperatorBase` equivalent to the function composition of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### exp\_i + + + +`exp_i()` + +Return Operator exponentiation, equaling e^(-i \* op) + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### log\_i + + + +`log_i(massive=False)` + +Return a `MatrixOp` equivalent to log(H)/-i for this operator H. This function is the effective inverse of exp\_i, equivalent to finding the Hermitian Operator which produces self when exponentiated. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### mul + + + +`mul(scalar)` + +Returns the scalar multiplication of the Operator, overloaded by `*`, including support for Terra’s `Parameters`, which can be bound to values later (via `bind_parameters`). + +**Parameters** + +**scalar** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The real or complex scalar by which to multiply the Operator, or the `ParameterExpression` to serve as a placeholder for a scalar factor. + +**Returns** + +An `OperatorBase` equivalent to product of self and scalar. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### permute + + + +`permute(permutation)` + +Permutes the qubits of the operator. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j should be permuted to position permutation\[j]. + +**Returns** + +A new OperatorBase containing the permuted operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – if indices do not define a new index for each qubit. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, X.tensor(Y) produces an X on qubit 0 and an Y on qubit 1, or X⨂Y, but would produce a QuantumCircuit which looks like + +> -\[Y]- -\[X]- + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensorpower + + + +`tensorpower(other)` + +Return tensor product with self multiple times, overloaded by `^`. + +**Parameters** + +**other** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The int number of times to tensor product self with itself via `tensorpower`. + +**Returns** + +An `OperatorBase` equivalent to the tensorpower of self by other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### to\_circuit + + + +`to_circuit()` + +Returns a `QuantumCircuit` equivalent to this Operator. + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Returns a `CircuitOp` equivalent to this Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_instruction + + + +`to_instruction()` + +Returns an `Instruction` equivalent to this Operator. + +**Return type** + +[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Returns a `MatrixOp` equivalent to this Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_pauli\_op + + + +`to_pauli_op(massive=False)` + +Returns a sum of `PauliOp` s equivalent to this Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.TaperedPauliSumOp.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.TaperedPauliSumOp.md new file mode 100644 index 00000000000..ab1b0c6ac54 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.TaperedPauliSumOp.md @@ -0,0 +1,130 @@ +--- +title: TaperedPauliSumOp +description: API reference for qiskit.opflow.primitive_ops.TaperedPauliSumOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.primitive_ops.TaperedPauliSumOp +--- + +# TaperedPauliSumOp + + + +`qiskit.opflow.primitive_ops.TaperedPauliSumOp(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/primitive_ops/tapered_pauli_sum_op.py "view source code") + +Bases: [`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp") + +Deprecated: Class for PauliSumOp after tapering + + + The class `qiskit.opflow.primitive_ops.tapered_pauli_sum_op.TaperedPauliSumOp` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The SparsePauliOp which defines the behavior of the underlying function. +* **z2\_symmetries** – Z2 symmetries which the Operator has. +* **coeff** – A coefficient multiplying the primitive. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – invalid parameters. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +The scalar coefficient multiplying the Operator. + +**Returns** + +The coefficient. + + + +### coeffs + +Return the Pauli coefficients. + + + +### grouping\_type + +Type of Grouping + +**Type** + +Returns + + + +### instance\_id + +Return the unique instance id. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`SparsePauliOp` + +The primitive defining the underlying function of the Operator. + +**Returns** + +The primitive object. + + + +### settings + +Return operator settings. + + + +### z2\_symmetries + +Z2 symmetries which the Operator has. + +**Returns** + +The Z2 Symmetries. + +## Methods + +### assign\_parameters + + + +`assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.Z2Symmetries.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.Z2Symmetries.md new file mode 100644 index 00000000000..6584875379a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.Z2Symmetries.md @@ -0,0 +1,220 @@ +--- +title: Z2Symmetries +description: API reference for qiskit.opflow.primitive_ops.Z2Symmetries +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.primitive_ops.Z2Symmetries +--- + +# Z2Symmetries + + + +`qiskit.opflow.primitive_ops.Z2Symmetries(symmetries, sq_paulis, sq_list, tapering_values=None, tol=1e-14)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/primitive_ops/tapered_pauli_sum_op.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: Z2 Symmetries + + + The class `qiskit.opflow.primitive_ops.tapered_pauli_sum_op.Z2Symmetries` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **symmetries** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli")*]*) – the list of Pauli objects representing the Z\_2 symmetries +* **sq\_paulis** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli")*]*) – the list of single - qubit Pauli objects to construct the Clifford operators +* **sq\_list** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – the list of support of the single-qubit Pauli objects used to build the Clifford operators +* **tapering\_values** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – values determines the sector. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Tolerance threshold for ignoring real and complex parts of a coefficient. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – Invalid paulis + +## Attributes + + + +### cliffords + +Get clifford operators, build based on symmetries and single-qubit X. :returns: a list of unitaries used to diagonalize the Hamiltonian. + + + +### settings + +Return operator settings. + + + +### sq\_list + +returns sq list + + + +### sq\_paulis + +returns sq paulis + + + +### symmetries + +return symmetries + + + +### tapering\_values + +returns tapering values + + + +### tol + +Tolerance threshold for ignoring real and complex parts of a coefficient. + +## Methods + +### consistent\_tapering + + + +`consistent_tapering(operator)` + +Tapering the operator with the same manner of how this tapered operator is created. i.e., using the same Cliffords and tapering values. + +**Parameters** + +**operator** ([*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp")) – the to-be-tapered operator + +**Returns** + +The tapered operator + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – The given operator does not commute with the symmetry + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### convert\_clifford + + + +`convert_clifford(operator)` + +This method operates the first part of the tapering. It converts the operator by composing it with the clifford unitaries defined in the current symmetry. + +**Parameters** + +**operator** ([*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp")) – to-be-tapered operator + +**Returns** + +[`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") corresponding to the converted operator. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – Z2 symmetries, single qubit pauli and single qubit list cannot be empty + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### copy + + + +`copy()` + +Get a copy of self. :returns: copy + +**Return type** + +[*Z2Symmetries*](#qiskit.opflow.primitive_ops.Z2Symmetries "qiskit.opflow.primitive_ops.tapered_pauli_sum_op.Z2Symmetries") + +### find\_Z2\_symmetries + + + +`classmethod find_Z2_symmetries(operator)` + +Finds Z2 Pauli-type symmetries of an Operator. + +**Returns** + +a z2\_symmetries object contains symmetries, single-qubit X, single-qubit list. + +**Return type** + +[*Z2Symmetries*](#qiskit.opflow.primitive_ops.Z2Symmetries "qiskit.opflow.primitive_ops.tapered_pauli_sum_op.Z2Symmetries") + +### is\_empty + + + +`is_empty()` + +Check the z2\_symmetries is empty or not. :returns: Empty or not + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### taper + + + +`taper(operator)` + +Taper an operator based on the z2\_symmetries info and sector defined by tapering\_values. The tapering\_values will be stored into the resulted operator for a record. + +The tapering is a two-step algorithm which first converts the operator into a [`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") with same eigenvalues but where some qubits are only acted upon with the Pauli operators I or X. The number M of these redundant qubits is equal to the number M of identified symmetries. + +The second step of the reduction consists in replacing these qubits with the possible eigenvalues of the corresponding Pauli X, giving 2^M new operators with M less qubits. If an eigenvalue sector was previously identified for the solution, then this reduces to 1 new operator with M less qubits. + +**Parameters** + +**operator** ([*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp")) – the to-be-tapered operator + +**Returns** + +\[[`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")]; otherwise, [`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") + +**Return type** + +If tapering\_values is None + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – Z2 symmetries, single qubit pauli and single qubit list cannot be empty + +### taper\_clifford + + + +`taper_clifford(operator)` + +This method operates the second part of the tapering. This function assumes that the input operators have already been transformed using [`convert_clifford()`](#qiskit.opflow.primitive_ops.Z2Symmetries.convert_clifford "qiskit.opflow.primitive_ops.Z2Symmetries.convert_clifford"). The redundant qubits due to the symmetries are dropped and replaced by their two possible eigenvalues. The tapering\_values will be stored into the resulted operator for a record. + +**Parameters** + +**operator** ([*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.pauli_sum_op.PauliSumOp")) – Partially tapered operator resulting from a call to [`convert_clifford()`](#qiskit.opflow.primitive_ops.Z2Symmetries.convert_clifford "qiskit.opflow.primitive_ops.Z2Symmetries.convert_clifford") + +**Returns** + +\[[`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")]; otherwise, [`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") + +**Return type** + +If tapering\_values is None + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – Z2 symmetries, single qubit pauli and single qubit list cannot be empty + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.md b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.md new file mode 100644 index 00000000000..56d01731352 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.primitive_ops.md @@ -0,0 +1,51 @@ +--- +title: primitive_ops +description: API reference for qiskit.opflow.primitive_ops +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow.primitive_ops +--- + + + + + +# qiskit.opflow\.primitive\_ops + + + +## Primitive Operators + + + +`qiskit.opflow.primitive_ops` + + + The [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +Operators are defined to be functions which take State functions to State functions. + +PrimitiveOps are the classes for representing basic Operators, backed by computational Operator primitives from Terra. These classes (and inheritors) primarily serve to allow the underlying primitives to “flow” - i.e. interoperability and adherence to the Operator formalism - while the core computational logic mostly remains in the underlying primitives. For example, we would not produce an interface in Terra in which `QuantumCircuit1 + QuantumCircuit2` equaled the Operator sum of the circuit unitaries, rather than simply appending the circuits. However, within the Operator flow summing the unitaries is the expected behavior. + + + All mathematical methods are not in-place, meaning that they return a new object, but the underlying primitives are not copied. + + +### Primitive Operators + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | +| [`PrimitiveOp`](qiskit.opflow.primitive_ops.PrimitiveOp "qiskit.opflow.primitive_ops.PrimitiveOp")(primitive\[, coeff]) | Deprecated: A class for representing basic Operators, backed by Operator primitives from Terra. | +| [`CircuitOp`](qiskit.opflow.primitive_ops.CircuitOp "qiskit.opflow.primitive_ops.CircuitOp")(\*args, \*\*kwargs) | Deprecated: Class for Operators backed by Terra's `QuantumCircuit` module. | +| [`MatrixOp`](qiskit.opflow.primitive_ops.MatrixOp "qiskit.opflow.primitive_ops.MatrixOp")(\*args, \*\*kwargs) | Deprecated: Class for Operators represented by matrices, backed by Terra's `Operator` module. | +| [`PauliOp`](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.PauliOp")(\*args, \*\*kwargs) | Deprecated: Class for Operators backed by Terra's `Pauli` module. | +| [`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp")(\*args, \*\*kwargs) | Deprecated: Class for Operators backed by Terra's `SparsePauliOp` class. | +| [`TaperedPauliSumOp`](qiskit.opflow.primitive_ops.TaperedPauliSumOp "qiskit.opflow.primitive_ops.TaperedPauliSumOp")(\*args, \*\*kwargs) | Deprecated: Class for PauliSumOp after tapering | + +### Symmetries + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------- | ------------------------- | +| [`Z2Symmetries`](qiskit.opflow.primitive_ops.Z2Symmetries "qiskit.opflow.primitive_ops.Z2Symmetries")(symmetries, sq\_paulis, sq\_list) | Deprecated: Z2 Symmetries | + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.CVaRMeasurement.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.CVaRMeasurement.md new file mode 100644 index 00000000000..cec5387bd2d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.CVaRMeasurement.md @@ -0,0 +1,352 @@ +--- +title: CVaRMeasurement +description: API reference for qiskit.opflow.state_fns.CVaRMeasurement +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.state_fns.CVaRMeasurement +--- + +# CVaRMeasurement + + + +`qiskit.opflow.state_fns.CVaRMeasurement(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/state_fns/cvar_measurement.py "view source code") + +Bases: [`OperatorStateFn`](qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn") + +**Deprecated: A specialized measurement class to compute CVaR expectation values.** + +See [https://arxiv.org/pdf/1907.04769.pdf](https://arxiv.org/pdf/1907.04769.pdf) for further details. + +Used in `CVaRExpectation`, see there for more details. + + + The class `qiskit.opflow.state_fns.cvar_measurement.CVaRMeasurement` is deprecated as of qiskit 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The `OperatorBase` which defines the diagonal operator measurement. +* **coeff** – A coefficient by which to multiply the state function +* **alpha** – A real-valued parameter between 0 and 1 which specifies the fraction of observed samples to include when computing the objective value. alpha = 1 corresponds to a standard observable expectation value. alpha = 0 corresponds to only using the single sample with the lowest energy. alpha = 0.5 corresponds to ranking each observation by lowest energy and using the best + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – TODO remove that this raises an error +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If alpha is not in \[0, 1]. +* [**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – If the primitive is not diagonal. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### alpha + +**A real-valued parameter between 0 and 1 which specifies the** + +fraction of observed samples to include when computing the objective value. alpha = 1 corresponds to a standard observable expectation value. alpha = 0 corresponds to only using the single sample with the lowest energy. alpha = 0.5 corresponds to ranking each observation by lowest energy and using the best half. + +**Returns** + +The parameter alpha which was given at initialization + + + +### coeff + +A coefficient by which the state function is multiplied. + + + +### instance\_id + +Return the unique instance id. + + + +### is\_measurement + +Whether the StateFn object is a measurement Operator. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`OperatorBase` + +The primitive which defines the behavior of the underlying State function. + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*SummedOp*](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### adjoint + + + +`adjoint()` + +The adjoint of a CVaRMeasurement is not defined. + +**Returns** + +Does not return anything, raises an error. + +**Raises** + +[**OpflowError**](opflow#qiskit.opflow.OpflowError "qiskit.opflow.OpflowError") – The adjoint of a CVaRMeasurement is not defined. + +### compute\_cvar + + + +`compute_cvar(energies, probabilities)` + +Given the energies of each sampled measurement outcome (H\_i) as well as the sampling probability of each measurement outcome (p\_i, we can compute the CVaR. Note that the sampling probabilities serve as an alternative to knowing the counts of each observation and that the input energies are assumed to be sorted in increasing order. + +Consider the outcome with index j, such that only some of the samples with measurement outcome j will be used in computing CVaR. The CVaR calculation can then be separated into two parts. First we sum each of the energies for outcomes i \< j, weighted by the probability of observing that outcome (i.e the normalized counts). Second, we add the energy for outcome j, weighted by the difference (α - sum\_i\ + +`eval(front=None)` + +Given the energies of each sampled measurement outcome (H\_i) as well as the sampling probability of each measurement outcome (p\_i, we can compute the CVaR as H\_j + 1/α\*(sum\_i\ + +`eval_variance(front=None)` + +Given the energies of each sampled measurement outcome (H\_i) as well as the sampling probability of each measurement outcome (p\_i, we can compute the variance of the CVaR estimator as H\_j^2 + 1/α \* (sum\_i\], where H is the diagonal observable and bi corresponds to measurement outcome i. Given this, E\[X^2] = E\[\^2] + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *| None*) – A StateFn or primitive which specifies the results of evaluating a quantum state. + +**Returns** + +**The Var\[CVaR] of the diagonal observable specified by self.primitive** + +and the sampled quantum state described by the inputs (energies, probabilities). For index j (described above), the CVaR is computed as H\_j^2 + 1/α\*(sum\_i\ + +`get_outcome_energies_probabilities(front=None)` + +In order to compute the CVaR of an observable expectation, we require the energies of each sampled measurement outcome as well as the sampling probability of each measurement outcome. Note that the counts for each measurement outcome will also suffice (and this is often how the CVaR is presented). + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – A StateFn or a primitive which defines a StateFn. This input holds the results of a sampled/simulated circuit. + +**Returns** + +**Two lists of equal length. energies contains the energy of each** + +unique measurement outcome computed against the diagonal observable stored in self.primitive. probabilities contains the corresponding sampling probability for each measurement outcome in energies. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – front isn’t a DictStateFn or VectorStateFn + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)"), [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")] + +### mul + + + +`mul(scalar)` + +Returns the scalar multiplication of the Operator, overloaded by `*`, including support for Terra’s `Parameters`, which can be bound to values later (via `bind_parameters`). + +**Parameters** + +**scalar** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The real or complex scalar by which to multiply the Operator, or the `ParameterExpression` to serve as a placeholder for a scalar factor. + +**Returns** + +An `OperatorBase` equivalent to product of self and scalar. + +**Return type** + +[*CVaRMeasurement*](#qiskit.opflow.state_fns.CVaRMeasurement "qiskit.opflow.state_fns.cvar_measurement.CVaRMeasurement") + +### sample + + + +`sample(shots=1024, massive=False, reverse_endianness=False)` + +Sample the state function as a normalized probability distribution. Returns dict of bitstrings in order of probability, with values being probability. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of samples to take to approximate the State function. +* **massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. +* **reverse\_endianness** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reverse the endianness of the bitstrings in the return dict to match Terra’s big-endianness. + +**Returns** + +A dict containing pairs sampled strings from the State function and sampling frequency divided by shots. + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, Plus.tensor(Zero) produces a |+⟩ on qubit 0 and a |0⟩ on qubit 1, or |+⟩⨂|0⟩, but would produce a QuantumCircuit like + +> |0⟩– |+⟩– + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorStateFn*](qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn") | [*TensoredOp*](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.tensored_op.TensoredOp") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Not defined. + +### to\_density\_matrix + + + +`to_density_matrix(massive=False)` + +Not defined. + +### to\_matrix + + + +`to_matrix(massive=False)` + +Not defined. + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Not defined. + +### traverse + + + +`traverse(convert_fn, coeff=None)` + +Apply the convert\_fn to the internal primitive if the primitive is an Operator (as in the case of `OperatorStateFn`). Otherwise do nothing. Used by converters. + +**Parameters** + +* **convert\_fn** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")) – The function to apply to the internal OperatorBase. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *| None*) – A coefficient to multiply by after applying convert\_fn. If it is None, self.coeff is used instead. + +**Returns** + +The converted StateFn. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.CircuitStateFn.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.CircuitStateFn.md new file mode 100644 index 00000000000..79358a9611d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.CircuitStateFn.md @@ -0,0 +1,375 @@ +--- +title: CircuitStateFn +description: API reference for qiskit.opflow.state_fns.CircuitStateFn +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.state_fns.CircuitStateFn +--- + +# CircuitStateFn + + + +`qiskit.opflow.state_fns.CircuitStateFn(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/state_fns/circuit_state_fn.py "view source code") + +Bases: [`StateFn`](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn") + +Deprecated: A class for state functions and measurements which are defined by the action of a QuantumCircuit starting from |0⟩, and stored using Terra’s `QuantumCircuit` class. + + + The class `qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The `QuantumCircuit` (or `Instruction`, which will be converted) which defines the behavior of the underlying function. +* **coeff** – A coefficient multiplying the state function. +* **is\_measurement** – Whether the StateFn is a measurement operator. +* **from\_operator** – if True the StateFn is derived from OperatorStateFn. (Default: False) + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Unsupported primitive, or primitive has ClassicalRegisters. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +A coefficient by which the state function is multiplied. + + + +### instance\_id + +Return the unique instance id. + + + +### is\_measurement + +Whether the StateFn object is a measurement Operator. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`QuantumCircuit` + +The primitive which defines the behavior of the underlying State function. + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*CircuitStateFn*](#qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn") + +### assign\_parameters + + + +`assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*CircuitStateFn*](#qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn") | [*ListOp*](qiskit.opflow.list_ops.ListOp "qiskit.opflow.list_ops.list_op.ListOp") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Composition (Linear algebra-style: A\@B(x) = A(B(x))) is not well defined for states in the binary function model, but is well defined for measurements. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to compose with self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An Operator equivalent to the function composition of self and other. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If self is not a measurement, it cannot be composed from the right. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### from\_dict + + + +`static from_dict(density_dict)` + +Construct the CircuitStateFn from a dict mapping strings to probability densities. + +**Parameters** + +**density\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dict representing the desired state. + +**Returns** + +The CircuitStateFn created from the dict. + +**Return type** + +[*CircuitStateFn*](#qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn") + +### from\_vector + + + +`static from_vector(statevector)` + +Construct the CircuitStateFn from a vector representing the statevector. + +**Parameters** + +**statevector** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – The statevector representing the desired state. + +**Returns** + +The CircuitStateFn created from the vector. + +**Return type** + +[*CircuitStateFn*](#qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn") + +### permute + + + +`permute(permutation)` + +Permute the qubits of the circuit. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j of the circuit should be permuted to position permutation\[j]. + +**Returns** + +A new CircuitStateFn containing the permuted circuit. + +**Return type** + +[*CircuitStateFn*](#qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*CircuitStateFn*](#qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn") + +### sample + + + +`sample(shots=1024, massive=False, reverse_endianness=False)` + +Sample the state function as a normalized probability distribution. Returns dict of bitstrings in order of probability, with values being probability. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, Plus.tensor(Zero) produces a |+⟩ on qubit 0 and a |0⟩ on qubit 1, or |+⟩⨂|0⟩, but would produce a QuantumCircuit like: + +> |0⟩– |+⟩– + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*CircuitStateFn*](#qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.circuit_state_fn.CircuitStateFn") | [*TensoredOp*](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.tensored_op.TensoredOp") + +### to\_circuit + + + +`to_circuit(meas=False)` + +Return QuantumCircuit representing StateFn + +**Return type** + +[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Return `StateFnCircuit` corresponding to this StateFn. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_density\_matrix + + + +`to_density_matrix(massive=False)` + +Return numpy matrix of density operator, warn if more than 16 qubits to force the user to set massive=True if they want such a large matrix. Generally big methods like this should require the use of a converter, but in this case a convenience method for quick hacking and access to classical tools is appropriate. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_instruction + + + +`to_instruction()` + +Return Instruction corresponding to primitive. + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.DictStateFn.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.DictStateFn.md new file mode 100644 index 00000000000..b147143c283 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.DictStateFn.md @@ -0,0 +1,307 @@ +--- +title: DictStateFn +description: API reference for qiskit.opflow.state_fns.DictStateFn +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.state_fns.DictStateFn +--- + +# DictStateFn + + + +`qiskit.opflow.state_fns.DictStateFn(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/state_fns/dict_state_fn.py "view source code") + +Bases: [`StateFn`](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn") + +Deprecated: A class for state functions and measurements which are defined by a lookup table, stored in a dict. + + + The class `qiskit.opflow.state_fns.dict_state_fn.DictStateFn` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The dict, single bitstring (if defining a basis sate), or Qiskit Result, which defines the behavior of the underlying function. +* **coeff** – A coefficient by which to multiply the state function. +* **is\_measurement** – Whether the StateFn is a measurement operator. +* **from\_operator** – if True the StateFn is derived from OperatorStateFn. (Default: False) + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – invalid parameters. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +A coefficient by which the state function is multiplied. + + + +### instance\_id + +Return the unique instance id. + + + +### is\_measurement + +Whether the StateFn object is a measurement Operator. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`Dict[str, complex]` + +The primitive which defines the behavior of the underlying State function. + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*DictStateFn*](#qiskit.opflow.state_fns.DictStateFn "qiskit.opflow.state_fns.dict_state_fn.DictStateFn") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### permute + + + +`permute(permutation)` + +Permute the qubits of the state function. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j of the circuit should be permuted to position permutation\[j]. + +**Returns** + +A new StateFn containing the permuted primitive. + +**Return type** + +[*DictStateFn*](#qiskit.opflow.state_fns.DictStateFn "qiskit.opflow.state_fns.dict_state_fn.DictStateFn") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### sample + + + +`sample(shots=1024, massive=False, reverse_endianness=False)` + +Sample the state function as a normalized probability distribution. Returns dict of bitstrings in order of probability, with values being probability. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of samples to take to approximate the State function. +* **massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. +* **reverse\_endianness** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reverse the endianness of the bitstrings in the return dict to match Terra’s big-endianness. + +**Returns** + +A dict containing pairs sampled strings from the State function and sampling frequency divided by shots. + +**Return type** + +[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, Plus.tensor(Zero) produces a |+⟩ on qubit 0 and a |0⟩ on qubit 1, or |+⟩⨂|0⟩, but would produce a QuantumCircuit like + +> |0⟩– |+⟩– + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Convert this state function to a `CircuitStateFn`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_density\_matrix + + + +`to_density_matrix(massive=False)` + +Return matrix representing product of StateFn evaluated on pairs of basis states. Overridden by child classes. + +**Parameters** + +**massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. + +**Returns** + +The NumPy array representing the density matrix of the State function. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If massive is set to False, and exponentially large computation is needed. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_spmatrix + + + +`to_spmatrix()` + +Same as to\_matrix, but returns csr sparse matrix. + +**Returns** + +CSR sparse matrix representation of the State function. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – invalid parameters. + +**Return type** + +*spmatrix* + +### to\_spmatrix\_op + + + +`to_spmatrix_op()` + +Convert this state function to a `SparseVectorStateFn`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.OperatorStateFn.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.OperatorStateFn.md new file mode 100644 index 00000000000..081f30b6006 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.OperatorStateFn.md @@ -0,0 +1,272 @@ +--- +title: OperatorStateFn +description: API reference for qiskit.opflow.state_fns.OperatorStateFn +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.state_fns.OperatorStateFn +--- + +# OperatorStateFn + + + +`qiskit.opflow.state_fns.OperatorStateFn(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/state_fns/operator_state_fn.py "view source code") + +Bases: [`StateFn`](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn") + +Deprecated: A class for state functions and measurements which are defined by a density Operator, stored using an `OperatorBase`. + + + The class `qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The `OperatorBase` which defines the behavior of the underlying State function. +* **coeff** – A coefficient by which to multiply the state function +* **is\_measurement** – Whether the StateFn is a measurement operator + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +A coefficient by which the state function is multiplied. + + + +### instance\_id + +Return the unique instance id. + + + +### is\_measurement + +Whether the StateFn object is a measurement Operator. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`OperatorBase` + +The primitive which defines the behavior of the underlying State function. + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorStateFn*](#qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn") | [*SummedOp*](qiskit.opflow.list_ops.SummedOp "qiskit.opflow.list_ops.summed_op.SummedOp") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*OperatorStateFn*](#qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### permute + + + +`permute(permutation)` + +Permute the qubits of the state function. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j of the circuit should be permuted to position permutation\[j]. + +**Returns** + +A new StateFn containing the permuted primitive. + +**Return type** + +[*OperatorStateFn*](#qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### sample + + + +`sample(shots=1024, massive=False, reverse_endianness=False)` + +Sample the state function as a normalized probability distribution. Returns dict of bitstrings in order of probability, with values being probability. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of samples to take to approximate the State function. +* **massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. +* **reverse\_endianness** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reverse the endianness of the bitstrings in the return dict to match Terra’s big-endianness. + +**Returns** + +A dict containing pairs sampled strings from the State function and sampling frequency divided by shots. + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, Plus.tensor(Zero) produces a |+⟩ on qubit 0 and a |0⟩ on qubit 1, or |+⟩⨂|0⟩, but would produce a QuantumCircuit like + +> |0⟩– |+⟩– + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorStateFn*](#qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn") | [*TensoredOp*](qiskit.opflow.list_ops.TensoredOp "qiskit.opflow.list_ops.tensored_op.TensoredOp") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Return `StateFnCircuit` corresponding to this StateFn. Ignore for now because this is undefined. TODO maybe call to\_pauli\_op and diagonalize here, but that could be very inefficient, e.g. splitting one Stabilizer measurement into hundreds of 1 qubit Paulis. + +### to\_density\_matrix + + + +`to_density_matrix(massive=False)` + +Return numpy matrix of density operator, warn if more than 16 qubits to force the user to set massive=True if they want such a large matrix. Generally big methods like this should require the use of a converter, but in this case a convenience method for quick hacking and access to classical tools is appropriate. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Note: this does not return a density matrix, it returns a classical matrix containing the quantum or classical vector representing the evaluation of the state function on each binary basis state. Do not assume this is is a normalized quantum or classical probability vector. If we allowed this to return a density matrix, then we would need to change the definition of composition to be \~Op @ StateFn @ Op for those cases, whereas by this methodology we can ensure that composition always means Op @ StateFn. + +Return numpy vector of state vector, warn if more than 16 qubits to force the user to set massive=True if they want such a large vector. + +**Parameters** + +**massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. + +**Returns** + +Vector of state vector + +**Return type** + +np.ndarray + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid parameters. + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Return a MatrixOp for this operator. + +**Return type** + +[*OperatorStateFn*](#qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.operator_state_fn.OperatorStateFn") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.SparseVectorStateFn.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.SparseVectorStateFn.md new file mode 100644 index 00000000000..66570accf44 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.SparseVectorStateFn.md @@ -0,0 +1,281 @@ +--- +title: SparseVectorStateFn +description: API reference for qiskit.opflow.state_fns.SparseVectorStateFn +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.state_fns.SparseVectorStateFn +--- + +# SparseVectorStateFn + + + +`qiskit.opflow.state_fns.SparseVectorStateFn(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/state_fns/sparse_vector_state_fn.py "view source code") + +Bases: [`StateFn`](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn") + +Deprecated: A class for sparse state functions and measurements in vector representation. + +This class uses `scipy.sparse.spmatrix` for the internal representation. + + + The class `qiskit.opflow.state_fns.sparse_vector_state_fn.SparseVectorStateFn` is deprecated as of qiskit 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The underlying sparse vector. +* **coeff** – A coefficient multiplying the state function. +* **is\_measurement** – Whether the StateFn is a measurement operator + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the primitive is not a column vector. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the number of elements in the primitive is not a power of 2. + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +A coefficient by which the state function is multiplied. + + + +### instance\_id + +Return the unique instance id. + + + +### is\_measurement + +Whether the StateFn object is a measurement Operator. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`spmatrix` + +The primitive which defines the behavior of the underlying State function. + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*SparseVectorStateFn*](#qiskit.opflow.state_fns.SparseVectorStateFn "qiskit.opflow.state_fns.sparse_vector_state_fn.SparseVectorStateFn") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### sample + + + +`sample(shots=1024, massive=False, reverse_endianness=False)` + +Sample the state function as a normalized probability distribution. Returns dict of bitstrings in order of probability, with values being probability. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of samples to take to approximate the State function. +* **massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. +* **reverse\_endianness** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reverse the endianness of the bitstrings in the return dict to match Terra’s big-endianness. + +**Returns** + +A dict containing pairs sampled strings from the State function and sampling frequency divided by shots. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Convert this state function to a `CircuitStateFn`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_dict\_fn + + + +`to_dict_fn()` + +Convert this state function to a `DictStateFn`. + +**Returns** + +A new DictStateFn equivalent to `self`. + +**Return type** + +[*StateFn*](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Return a `VectorStateFn` for this `StateFn`. + +**Parameters** + +**massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. + +**Returns** + +A VectorStateFn equivalent to self. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_spmatrix + + + +`to_spmatrix()` + +Return SciPy sparse matrix representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. + +**Returns** + +The SciPy `spmatrix` equivalent to this Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.StateFn.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.StateFn.md new file mode 100644 index 00000000000..f16bc314acd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.StateFn.md @@ -0,0 +1,461 @@ +--- +title: StateFn +description: API reference for qiskit.opflow.state_fns.StateFn +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.state_fns.StateFn +--- + +# StateFn + + + +`qiskit.opflow.state_fns.StateFn(primitive=None, coeff=1.0, is_measurement=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/state_fns/state_fn.py "view source code") + +Bases: [`OperatorBase`](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +Deprecated: A class for representing state functions and measurements. + +State functions are defined to be complex functions over a single binary string (as compared to an operator, which is defined as a function over two binary strings, or a function taking a binary function to another binary function). This function may be called by the eval() method. + +Measurements are defined to be functionals over StateFns, taking them to real values. Generally, this real value is interpreted to represent the probability of some classical state (binary string) being observed from a probabilistic or quantum system represented by a StateFn. This leads to the equivalent definition, which is that a measurement m is a function over binary strings producing StateFns, such that the probability of measuring a given binary string b from a system with StateFn f is equal to the inner product between f and m(b). + +NOTE: State functions here are not restricted to wave functions, as there is no requirement of normalization. + + + The class `qiskit.opflow.state_fns.state_fn.StateFn` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*Result*](qiskit.result.Result "qiskit.result.result.Result") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The primitive which defines the behavior of the underlying State function. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A coefficient by which the state function is multiplied. +* **is\_measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the StateFn is a measurement operator + +**Return type** + +[StateFn](#qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.StateFn") + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +A coefficient by which the state function is multiplied. + + + +### instance\_id + +Return the unique instance id. + + + +### is\_measurement + +Whether the StateFn object is a measurement Operator. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +The primitive which defines the behavior of the underlying State function. + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### assign\_parameters + + + +`assign_parameters(param_dict)` + +Binds scalar values to any Terra `Parameters` in the coefficients or primitives of the Operator, or substitutes one `Parameter` for another. This method differs from Terra’s `assign_parameters` in that it also supports lists of values to assign for a give `Parameter`, in which case self will be copied for each parameterization in the binding list(s), and all the copies will be returned in an `OpList`. If lists of parameterizations are used, every `Parameter` in the param\_dict must have the same length list of parameterizations. + +**Parameters** + +**param\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of `Parameters` to replace, and values or lists of values by which to replace them. + +**Returns** + +The `OperatorBase` with the `Parameters` in self replaced by the values or `Parameters` in param\_dict. If param\_dict contains parameterization lists, this `OperatorBase` is an `OpList`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### compose + + + +`compose(other, permutation=None, front=False)` + +Composition (Linear algebra-style: A\@B(x) = A(B(x))) is not well defined for states in the binary function model, but is well defined for measurements. + +**Parameters** + +* **other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The Operator to compose with self. +* **permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – `List[int]` which defines permutation on other operator. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If front==True, return `other.compose(self)`. + +**Returns** + +An Operator equivalent to the function composition of self and other. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If self is not a measurement, it cannot be composed from the right. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### equals + + + +`equals(other)` + +Evaluate Equality between Operators, overloaded by `==`. Only returns True if self and other are of the same representation (e.g. a DictStateFn and CircuitStateFn will never be equal, even if their vector representations are equal), their underlying primitives are equal (this means for ListOps, OperatorStateFns, or EvolvedOps the equality is evaluated recursively downwards), and their coefficients are equal. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to compare to self. + +**Returns** + +A bool equal to the equality of self and other. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### mul + + + +`mul(scalar)` + +Returns the scalar multiplication of the Operator, overloaded by `*`, including support for Terra’s `Parameters`, which can be bound to values later (via `bind_parameters`). + +**Parameters** + +**scalar** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The real or complex scalar by which to multiply the Operator, or the `ParameterExpression` to serve as a placeholder for a scalar factor. + +**Returns** + +An `OperatorBase` equivalent to product of self and scalar. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### permute + + + +`permute(permutation)` + +Permute the qubits of the state function. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j of the circuit should be permuted to position permutation\[j]. + +**Returns** + +A new StateFn containing the permuted primitive. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### power + + + +`power(exponent)` + +Compose with Self Multiple Times, undefined for StateFns. + +**Parameters** + +**exponent** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of times to compose self with self. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – This function is not defined for StateFns. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### reduce + + + +`reduce()` + +Try collapsing the Operator structure, usually after some type of conversion, e.g. trying to add Operators in a SummedOp or delete needless IGates in a CircuitOp. If no reduction is available, just returns self. + +**Returns** + +The reduced `OperatorBase`. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### sample + + + +`sample(shots=1024, massive=False, reverse_endianness=False)` + +Sample the state function as a normalized probability distribution. Returns dict of bitstrings in order of probability, with values being probability. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of samples to take to approximate the State function. +* **massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. +* **reverse\_endianness** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reverse the endianness of the bitstrings in the return dict to match Terra’s big-endianness. + +**Returns** + +A dict containing pairs sampled strings from the State function and sampling frequency divided by shots. + +**Return type** + +[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, Plus.tensor(Zero) produces a |+⟩ on qubit 0 and a |0⟩ on qubit 1, or |+⟩⨂|0⟩, but would produce a QuantumCircuit like + +> |0⟩– |+⟩– + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### tensorpower + + + +`tensorpower(other)` + +Return tensor product with self multiple times, overloaded by `^`. + +**Parameters** + +**other** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The int number of times to tensor product self with itself via `tensorpower`. + +**Returns** + +An `OperatorBase` equivalent to the tensorpower of self by other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Returns a `CircuitOp` equivalent to this Operator. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_density\_matrix + + + +`to_density_matrix(massive=False)` + +Return matrix representing product of StateFn evaluated on pairs of basis states. Overridden by child classes. + +**Parameters** + +**massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. + +**Returns** + +The NumPy array representing the density matrix of the State function. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If massive is set to False, and exponentially large computation is needed. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Return a `VectorStateFn` for this `StateFn`. + +**Parameters** + +**massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. + +**Returns** + +A VectorStateFn equivalent to self. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### traverse + + + +`traverse(convert_fn, coeff=None)` + +Apply the convert\_fn to the internal primitive if the primitive is an Operator (as in the case of `OperatorStateFn`). Otherwise do nothing. Used by converters. + +**Parameters** + +* **convert\_fn** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")) – The function to apply to the internal OperatorBase. +* **coeff** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *| None*) – A coefficient to multiply by after applying convert\_fn. If it is None, self.coeff is used instead. + +**Returns** + +The converted StateFn. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.VectorStateFn.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.VectorStateFn.md new file mode 100644 index 00000000000..c34f2bce9be --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.VectorStateFn.md @@ -0,0 +1,306 @@ +--- +title: VectorStateFn +description: API reference for qiskit.opflow.state_fns.VectorStateFn +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.opflow.state_fns.VectorStateFn +--- + +# VectorStateFn + + + +`qiskit.opflow.state_fns.VectorStateFn(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/opflow/state_fns/vector_state_fn.py "view source code") + +Bases: [`StateFn`](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn") + +Deprecated: A class for state functions and measurements which are defined in vector representation, and stored using Terra’s `Statevector` class. + + + The class `qiskit.opflow.state_fns.vector_state_fn.VectorStateFn` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +**Parameters** + +* **primitive** – The `Statevector`, NumPy array, or list, which defines the behavior of the underlying function. +* **coeff** – A coefficient multiplying the state function. +* **is\_measurement** – Whether the StateFn is a measurement operator + +## Attributes + + + +### INDENTATION + +`= '  '` + + + +### coeff + +A coefficient by which the state function is multiplied. + + + +### instance\_id + +Return the unique instance id. + + + +### is\_measurement + +Whether the StateFn object is a measurement Operator. + + + +### num\_qubits + + + +### parameters + + + +### primitive + +`Statevector` + +The primitive which defines the behavior of the underlying State function. + + + +### settings + +Return settings. + +## Methods + +### add + + + +`add(other)` + +Return Operator addition of self and other, overloaded by `+`. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – An `OperatorBase` with the same number of qubits as self, and in the same ‘Operator’, ‘State function’, or ‘Measurement’ category as self (i.e. the same type of underlying function). + +**Returns** + +An `OperatorBase` equivalent to the sum of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### adjoint + + + +`adjoint()` + +Return a new Operator equal to the Operator’s adjoint (conjugate transpose), overloaded by `~`. For StateFns, this also turns the StateFn into a measurement. + +**Returns** + +An `OperatorBase` equivalent to the adjoint of self. + +**Return type** + +[*VectorStateFn*](#qiskit.opflow.state_fns.VectorStateFn "qiskit.opflow.state_fns.vector_state_fn.VectorStateFn") + +### eval + + + +`eval(front=None)` + +Evaluate the Operator’s underlying function, either on a binary string or another Operator. A square binary Operator can be defined as a function taking a binary function to another binary function. This method returns the value of that function for a given StateFn or binary string. For example, `op.eval('0110').eval('1110')` can be seen as querying the Operator’s matrix representation by row 6 and column 14, and will return the complex value at those “indices.” Similarly for a StateFn, `op.eval('1011')` will return the complex value at row 11 of the vector representation of the StateFn, as all StateFns are defined to be evaluated from Zero implicitly (i.e. it is as if `.eval('0000')` is already called implicitly to always “indexing” from column 0). + +If `front` is None, the matrix-representation of the operator is returned. + +**Parameters** + +**front** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") *|*[*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") *| None*) – The bitstring, dict of bitstrings (with values being coefficients), or StateFn to evaluated by the Operator’s underlying function, or None. + +**Returns** + +The output of the Operator’s evaluation function. If self is a `StateFn`, the result is a float or complex. If self is an Operator (`PrimitiveOp, ComposedOp, SummedOp, EvolvedOp,` etc.), the result is a StateFn. If `front` is None, the matrix-representation of the operator is returned, which is a `MatrixOp` for the operators and a `VectorStateFn` for state-functions. If either self or front contain proper `ListOps` (not ListOp subclasses), the result is an n-dimensional list of complex or StateFn results, resulting from the recursive evaluation by each OperatorBase in the ListOps. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") | [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### permute + + + +`permute(permutation)` + +Permute the qubits of the state function. + +**Parameters** + +**permutation** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A list defining where each qubit should be permuted. The qubit at index j of the circuit should be permuted to position permutation\[j]. + +**Returns** + +A new StateFn containing the permuted primitive. + +**Return type** + +[*VectorStateFn*](#qiskit.opflow.state_fns.VectorStateFn "qiskit.opflow.state_fns.vector_state_fn.VectorStateFn") + +### primitive\_strings + + + +`primitive_strings()` + +Return a set of strings describing the primitives contained in the Operator. For example, `{'QuantumCircuit', 'Pauli'}`. For hierarchical Operators, such as `ListOps`, this can help illuminate the primitives represented in the various recursive levels, and therefore which conversions can be applied. + +**Returns** + +A set of strings describing the primitives contained within the Operator. + +**Return type** + +[*Set*](https://docs.python.org/3/library/typing.html#typing.Set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### sample + + + +`sample(shots=1024, massive=False, reverse_endianness=False)` + +Sample the state function as a normalized probability distribution. Returns dict of bitstrings in order of probability, with values being probability. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of samples to take to approximate the State function. +* **massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. +* **reverse\_endianness** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to reverse the endianness of the bitstrings in the return dict to match Terra’s big-endianness. + +**Returns** + +A dict containing pairs sampled strings from the State function and sampling frequency divided by shots. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### tensor + + + +`tensor(other)` + +Return tensor product between self and other, overloaded by `^`. Note: You must be conscious of Qiskit’s big-endian bit printing convention. Meaning, Plus.tensor(Zero) produces a |+⟩ on qubit 0 and a |0⟩ on qubit 1, or |+⟩⨂|0⟩, but would produce a QuantumCircuit like + +> |0⟩– |+⟩– + +Because Terra prints circuits and results with qubit 0 at the end of the string or circuit. + +**Parameters** + +**other** ([*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase")) – The `OperatorBase` to tensor product with self. + +**Returns** + +An `OperatorBase` equivalent to the tensor product of self and other. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_circuit\_op + + + +`to_circuit_op()` + +Return `StateFnCircuit` corresponding to this StateFn. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + +### to\_density\_matrix + + + +`to_density_matrix(massive=False)` + +Return matrix representing product of StateFn evaluated on pairs of basis states. Overridden by child classes. + +**Parameters** + +**massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. + +**Returns** + +The NumPy array representing the density matrix of the State function. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If massive is set to False, and exponentially large computation is needed. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_dict\_fn + + + +`to_dict_fn()` + +Creates the equivalent state function of type DictStateFn. + +**Returns** + +A new DictStateFn equivalent to `self`. + +**Return type** + +[*StateFn*](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.state_fn.StateFn") + +### to\_matrix + + + +`to_matrix(massive=False)` + +Return NumPy representation of the Operator. Represents the evaluation of the Operator’s underlying function on every combination of basis binary strings. Warn if more than 16 qubits to force having to set `massive=True` if such a large vector is desired. + +**Returns** + +The NumPy `ndarray` equivalent to this Operator. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### to\_matrix\_op + + + +`to_matrix_op(massive=False)` + +Return a `VectorStateFn` for this `StateFn`. + +**Parameters** + +**massive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to allow large conversions, e.g. creating a matrix representing over 16 qubits. + +**Returns** + +A VectorStateFn equivalent to self. + +**Return type** + +[*OperatorBase*](qiskit.opflow.OperatorBase "qiskit.opflow.operator_base.OperatorBase") + diff --git a/docs/api/qiskit/0.46/qiskit.opflow.state_fns.md b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.md new file mode 100644 index 00000000000..17a36c8009d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.opflow.state_fns.md @@ -0,0 +1,50 @@ +--- +title: state_fns +description: API reference for qiskit.opflow.state_fns +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.opflow.state_fns +--- + + + + + +# qiskit.opflow\.state\_fns + + + +## State Functions + + + +`qiskit.opflow.state_fns` + + + The [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow") module is deprecated and will be removed no earlier than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/opflow\_migration](https://qisk.it/opflow_migration). + + +State functions are defined to be complex functions over a single binary string (as compared to an operator, which is defined as a function over two binary strings, or a function taking a binary function to another binary function). This function may be called by the eval() method. + +Measurements are defined to be functionals over StateFns, taking them to real values. Generally, this real value is interpreted to represent the probability of some classical state (binary string) being observed from a probabilistic or quantum system represented by a StateFn. This leads to the equivalent definition, which is that a measurement m is a function over binary strings producing StateFns, such that the probability of measuring a given binary string b from a system with StateFn f is equal to the inner product between f and m(b). + + + All mathematical methods between StateFns are not in-place, meaning that they return a new object, but the underlying primitives are not copied. + + + + State functions here are not restricted to wave functions, as there is no requirement of normalization. + + +### State Functions + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`StateFn`](qiskit.opflow.state_fns.StateFn "qiskit.opflow.state_fns.StateFn")(\[primitive, coeff, is\_measurement]) | Deprecated: A class for representing state functions and measurements. | +| [`CircuitStateFn`](qiskit.opflow.state_fns.CircuitStateFn "qiskit.opflow.state_fns.CircuitStateFn")(\*args, \*\*kwargs) | Deprecated: A class for state functions and measurements which are defined by the action of a QuantumCircuit starting from \|0⟩, and stored using Terra's `QuantumCircuit` class. | +| [`DictStateFn`](qiskit.opflow.state_fns.DictStateFn "qiskit.opflow.state_fns.DictStateFn")(\*args, \*\*kwargs) | Deprecated: A class for state functions and measurements which are defined by a lookup table, stored in a dict. | +| [`VectorStateFn`](qiskit.opflow.state_fns.VectorStateFn "qiskit.opflow.state_fns.VectorStateFn")(\*args, \*\*kwargs) | Deprecated: A class for state functions and measurements which are defined in vector representation, and stored using Terra's `Statevector` class. | +| [`SparseVectorStateFn`](qiskit.opflow.state_fns.SparseVectorStateFn "qiskit.opflow.state_fns.SparseVectorStateFn")(\*args, \*\*kwargs) | Deprecated: A class for sparse state functions and measurements in vector representation. | +| [`OperatorStateFn`](qiskit.opflow.state_fns.OperatorStateFn "qiskit.opflow.state_fns.OperatorStateFn")(\*args, \*\*kwargs) | Deprecated: A class for state functions and measurements which are defined by a density Operator, stored using an `OperatorBase`. | +| [`CVaRMeasurement`](qiskit.opflow.state_fns.CVaRMeasurement "qiskit.opflow.state_fns.CVaRMeasurement")(\*args, \*\*kwargs) | Deprecated: A specialized measurement class to compute CVaR expectation values. | + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.BaseController.md b/docs/api/qiskit/0.46/qiskit.passmanager.BaseController.md new file mode 100644 index 00000000000..e7c19d26414 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.BaseController.md @@ -0,0 +1,73 @@ +--- +title: BaseController +description: API reference for qiskit.passmanager.BaseController +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.BaseController +--- + +# BaseController + + + +`qiskit.passmanager.BaseController(options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/base_tasks.py "view source code") + +Bases: `Task`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class of controller. + +A controller is built with a collection of pass manager tasks, and a subclass provides a custom logic to choose next task to run. Note a controller can be nested into another controller, and a controller itself doesn’t provide any subroutine to modify the input IR. + +Create new flow controller. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any] | None*) – Option for this flow controller. + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### iter\_tasks + + + +`abstract iter_tasks(state)` + +A custom logic to choose a next task to run. + +Controller subclass can consume the state to build a proper task pipeline. The updated state after a task execution will be fed back in as the “return” value of any `yield` statements. This indicates the order of task execution is only determined at running time. This method is not allowed to mutate the given state object. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – The state of the passmanager workflow at the beginning of this flow controller’s execution. +* **state** – the state of pass manager after the execution of the last task that was yielded. The generator does not need to inspect this if it is irrelevant to its logic, nor update it. + +**Yields** + +*Task* – Next task to run. + +**Return type** + +[*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[*Task*, [*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState"), None] + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.BasePassManager.md b/docs/api/qiskit/0.46/qiskit.passmanager.BasePassManager.md new file mode 100644 index 00000000000..a5a9ca4523b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.BasePassManager.md @@ -0,0 +1,141 @@ +--- +title: BasePassManager +description: API reference for qiskit.passmanager.BasePassManager +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.BasePassManager +--- + +# BasePassManager + + + +`qiskit.passmanager.BasePassManager(tasks=(), max_iteration=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/passmanager.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Pass manager base class. + +Initialize an empty pass manager object. + +**Parameters** + +* **tasks** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A pass set to be added to the pass manager schedule. +* **max\_iteration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of iterations the schedule will be looped if the condition is not met. + +## Methods + +### append + + + +`append(tasks)` + +Append tasks to the schedule of passes. + +**Parameters** + +**tasks** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A set of pass manager tasks to be added to schedule. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – When any element of tasks is not a subclass of passmanager Task. + +### remove + + + +`remove(index)` + +Removes a particular pass in the scheduler. + +**Parameters** + +**index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Pass index to remove, based on the position in `passes()`. + +**Raises** + +[**PassManagerError**](passmanager#qiskit.passmanager.PassManagerError "qiskit.passmanager.PassManagerError") – If the index is not found. + +### replace + + + +`replace(index, tasks)` + +Replace a particular pass in the scheduler. + +**Parameters** + +* **index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Task index to replace, based on the position in `tasks()` +* **tasks** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A set of pass manager tasks to be added to schedule. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – When any element of tasks is not a subclass of passmanager Task. +* [**PassManagerError**](passmanager#qiskit.passmanager.PassManagerError "qiskit.passmanager.PassManagerError") – If the index is not found. + +### run + + + +`run(in_programs, callback=None, **kwargs)` + +Run all the passes on the specified `in_programs`. + +**Parameters** + +* **in\_programs** (*Any |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Any]*) – Input programs to transform via all the registered passes. A single input object cannot be a Python builtin list object. A list object is considered as multiple input objects to optimize. + +* **callback** (*Callable*) – + + A callback function that will be called after each pass execution. The function will be called with 4 keyword arguments: + + ```python + task (GenericPass): the pass being run + passmanager_ir (Any): depending on pass manager subclass + property_set (PropertySet): the property set + running_time (float): the time to execute the pass + count (int): the index for the pass execution + ``` + + The exact arguments pass expose the internals of the pass manager and are subject to change as the pass manager internals change. If you intend to reuse a callback function over multiple releases be sure to check that the arguments being passed are the same. + + To use the callback feature you define a function that will take in kwargs dict and access the variables. For example: + + ```python + def callback_func(**kwargs): + task = kwargs['task'] + passmanager_ir = kwargs['passmanager_ir'] + property_set = kwargs['property_set'] + running_time = kwargs['running_time'] + count = kwargs['count'] + ... + ``` + +* **kwargs** – Arbitrary arguments passed to the compiler frontend and backend. + +**Returns** + +The transformed program(s). + +**Return type** + +Any + +### to\_flow\_controller + + + +`to_flow_controller()` + +Linearize this manager into a single [`FlowControllerLinear`](qiskit.passmanager.FlowControllerLinear "qiskit.passmanager.FlowControllerLinear"), so that it can be nested inside another pass manager. + +**Returns** + +A linearized pass manager. + +**Return type** + +[*FlowControllerLinear*](qiskit.passmanager.FlowControllerLinear "qiskit.passmanager.flow_controllers.FlowControllerLinear") + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.ConditionalController.md b/docs/api/qiskit/0.46/qiskit.passmanager.ConditionalController.md new file mode 100644 index 00000000000..d889dfc2896 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.ConditionalController.md @@ -0,0 +1,95 @@ +--- +title: ConditionalController +description: API reference for qiskit.passmanager.ConditionalController +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.ConditionalController +--- + +# ConditionalController + + + +`qiskit.passmanager.ConditionalController(tasks=(), condition=None, *, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/flow_controllers.py "view source code") + +Bases: [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.base_tasks.BaseController") + +A flow controller runs the pipeline once if the condition is true, or does nothing if the condition is false. + +Create new flow controller. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any] | None*) – Option for this flow controller. + +## Attributes + + + +### passes + +Alias of tasks for backward compatibility. + +## Methods + +### append + + + +`append(passes)` + +Add new task to pipeline. + + + The method `qiskit.passmanager.flow_controllers.ConditionalController.append()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0 release. All tasks must be provided at construction time of the controller object. + + +**Parameters** + +**passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A new task or list of tasks to add. + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### iter\_tasks + + + +`iter_tasks(state)` + +A custom logic to choose a next task to run. + +Controller subclass can consume the state to build a proper task pipeline. The updated state after a task execution will be fed back in as the “return” value of any `yield` statements. This indicates the order of task execution is only determined at running time. This method is not allowed to mutate the given state object. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – The state of the passmanager workflow at the beginning of this flow controller’s execution. +* **state** – the state of pass manager after the execution of the last task that was yielded. The generator does not need to inspect this if it is irrelevant to its logic, nor update it. + +**Yields** + +*Task* – Next task to run. + +**Return type** + +[*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[*Task*, [*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState"), None] + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.DoWhileController.md b/docs/api/qiskit/0.46/qiskit.passmanager.DoWhileController.md new file mode 100644 index 00000000000..20ce34f6c77 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.DoWhileController.md @@ -0,0 +1,97 @@ +--- +title: DoWhileController +description: API reference for qiskit.passmanager.DoWhileController +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.DoWhileController +--- + +# DoWhileController + + + +`qiskit.passmanager.DoWhileController(tasks=(), do_while=None, *, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/flow_controllers.py "view source code") + +Bases: [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.base_tasks.BaseController") + +Run the given tasks in a loop until the `do_while` condition on the property set becomes `False`. + +The given tasks will always run at least once, and on iteration of the loop, all the tasks will be run (with the exception of a failure state being set). + +Create new flow controller. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any] | None*) – Option for this flow controller. + +## Attributes + + + +### passes + +Alias of tasks for backward compatibility. + +## Methods + +### append + + + +`append(passes)` + +Add new task to pipeline. + + + The method `qiskit.passmanager.flow_controllers.DoWhileController.append()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0 release. All tasks must be provided at construction time of the controller object. + + +**Parameters** + +**passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A new task or list of tasks to add. + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### iter\_tasks + + + +`iter_tasks(state)` + +A custom logic to choose a next task to run. + +Controller subclass can consume the state to build a proper task pipeline. The updated state after a task execution will be fed back in as the “return” value of any `yield` statements. This indicates the order of task execution is only determined at running time. This method is not allowed to mutate the given state object. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – The state of the passmanager workflow at the beginning of this flow controller’s execution. +* **state** – the state of pass manager after the execution of the last task that was yielded. The generator does not need to inspect this if it is irrelevant to its logic, nor update it. + +**Yields** + +*Task* – Next task to run. + +**Return type** + +[*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[*Task*, [*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState"), None] + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.FlowController.md b/docs/api/qiskit/0.46/qiskit.passmanager.FlowController.md new file mode 100644 index 00000000000..9d4a3323f1e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.FlowController.md @@ -0,0 +1,168 @@ +--- +title: FlowController +description: API reference for qiskit.passmanager.FlowController +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.FlowController +--- + +# FlowController + + + +`qiskit.passmanager.FlowController(options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/flow_controllers.py "view source code") + +Bases: [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.base_tasks.BaseController") + +A legacy factory for other flow controllers. + + + This class is primarily for compatibility with legacy versions of Qiskit, and in general, you should prefer simply instantiating the controller you want, and adding it to the relevant [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") or other controller. Its use is deprecated. + + +This allows syntactic sugar for writing pipelines. For example: + +```python +FlowController.add_flow_controller("my_condition", CustomController) + +controller = FlowController.controller_factory( + [PassA(), PassB()], + {"max_iteration": 1000}, + condition=lambda prop_set: prop_set["x"] == 0, + do_while=lambda prop_set: prop_set["x"] < 100, + my_condition=lambda prop_set: prop_set["y"] = "abc", +) +``` + +This creates a nested flow controller that runs when the value `x` in the [`PropertySet`](qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet") is zero and repeats the pipeline until the value becomes 100. In each innermost loop, the custom iteration condition provided by the `CustomController` is also evaluated. + + + [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.BaseController") must be directly subclassed to define a custom flow controller. This class provides a controller factory method, which consumes a class variable [`registered_controllers`](#qiskit.passmanager.FlowController.registered_controllers "qiskit.passmanager.FlowController.registered_controllers"). Subclassing FlowController may cause unexpected behavior in the factory method. Note that factory method implicitly determines the priority of the builtin controllers when multiple controllers are called together, and the behavior of generated controller is hardly debugged. + + + + The class `qiskit.passmanager.flow_controllers.FlowController` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0 release. The base class of flow controller is now qiskit.passmanager.BaseController. This class exists only for the controller namespace used to map a controller name tothe corresponding class object, which is used to instantiate a controller with keyword argument in PassManager.append method. This pattern was also deprecated. + + +## Attributes + + + +### hierarchy + +`= ['condition', 'do_while']` + + + +### registered\_controllers = \{'condition' + +`= {'condition':` + +`= {'condition': , 'do_while': }` + +## Methods + +### add\_flow\_controller + + + +`classmethod add_flow_controller(name, controller)` + +Adds a flow controller. + + + The method `qiskit.passmanager.flow_controllers.FlowController.add_flow_controller()` is deprecated as of qiskit 0.45.0. It will be removed in the 1.0 release. The controller factory method is deprecated and managing the custom flow controllers with aliases no longer helps building the task pipeline. Controllers must be explicitly instantiated and appended to the pipeline. + + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Alias of controller class in the namespace. +* **controller** ([*Type*](https://docs.python.org/3/library/typing.html#typing.Type "(in Python v3.12)")*\[*[*BaseController*](qiskit.passmanager.BaseController "qiskit.passmanager.base_tasks.BaseController")*]*) – Flow controller class. + +### controller\_factory + + + +`classmethod controller_factory(passes, options, **controllers)` + +Create a new flow controller with normalization. + + + The method `qiskit.passmanager.flow_controllers.FlowController.controller_factory()` is deprecated as of qiskit 0.45.0. It will be removed in the 1.0 release. FlowController objects must be explicitly instantiated. Building controllers with keyword arguments ignores the order when multiple keyword arguments are provided together, which is likely unsafe. + + +**Parameters** + +* **passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A list of optimization tasks. +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Option for this flow controller. +* **controllers** – Dictionary of controller callables keyed on flow controller alias. + +**Returns** + +An instance of normalized flow controller. + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### iter\_tasks + + + +`abstract iter_tasks(state)` + +A custom logic to choose a next task to run. + +Controller subclass can consume the state to build a proper task pipeline. The updated state after a task execution will be fed back in as the “return” value of any `yield` statements. This indicates the order of task execution is only determined at running time. This method is not allowed to mutate the given state object. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – The state of the passmanager workflow at the beginning of this flow controller’s execution. +* **state** – the state of pass manager after the execution of the last task that was yielded. The generator does not need to inspect this if it is irrelevant to its logic, nor update it. + +**Yields** + +*Task* – Next task to run. + +**Return type** + +[*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[*Task*, [*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState"), None] + +### remove\_flow\_controller + + + +`classmethod remove_flow_controller(name)` + +Removes a flow controller. + + + The method `qiskit.passmanager.flow_controllers.FlowController.remove_flow_controller()` is deprecated as of qiskit 0.45.0. It will be removed in the 1.0 release. The controller factory method is deprecated and managing the custom flow controllers with aliases no longer helps building the task pipeline. Controllers must be explicitly instantiated and appended to the pipeline. + + +**Parameters** + +**name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Alias of the controller to remove. + +**Raises** + +[**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – If the controller to remove was not registered. + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.FlowControllerLinear.md b/docs/api/qiskit/0.46/qiskit.passmanager.FlowControllerLinear.md new file mode 100644 index 00000000000..78c2403a6cc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.FlowControllerLinear.md @@ -0,0 +1,95 @@ +--- +title: FlowControllerLinear +description: API reference for qiskit.passmanager.FlowControllerLinear +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.FlowControllerLinear +--- + +# FlowControllerLinear + + + +`qiskit.passmanager.FlowControllerLinear(tasks=(), *, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/flow_controllers.py "view source code") + +Bases: [`BaseController`](qiskit.passmanager.BaseController "qiskit.passmanager.base_tasks.BaseController") + +A standard flow controller that runs tasks one after the other. + +Create new flow controller. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any] | None*) – Option for this flow controller. + +## Attributes + + + +### passes + +Alias of tasks for backward compatibility. + +## Methods + +### append + + + +`append(passes)` + +Add new task to pipeline. + + + The method `qiskit.passmanager.flow_controllers.FlowControllerLinear.append()` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0 release. All tasks must be provided at construction time of the controller object. + + +**Parameters** + +**passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A new task or list of tasks to add. + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### iter\_tasks + + + +`iter_tasks(state)` + +A custom logic to choose a next task to run. + +Controller subclass can consume the state to build a proper task pipeline. The updated state after a task execution will be fed back in as the “return” value of any `yield` statements. This indicates the order of task execution is only determined at running time. This method is not allowed to mutate the given state object. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – The state of the passmanager workflow at the beginning of this flow controller’s execution. +* **state** – the state of pass manager after the execution of the last task that was yielded. The generator does not need to inspect this if it is irrelevant to its logic, nor update it. + +**Yields** + +*Task* – Next task to run. + +**Return type** + +[*Generator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Generator "(in Python v3.12)")\[*Task*, [*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState"), None] + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.GenericPass.md b/docs/api/qiskit/0.46/qiskit.passmanager.GenericPass.md new file mode 100644 index 00000000000..20f324c196d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.GenericPass.md @@ -0,0 +1,97 @@ +--- +title: GenericPass +description: API reference for qiskit.passmanager.GenericPass +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.GenericPass +--- + +# GenericPass + + + +`qiskit.passmanager.GenericPass`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/base_tasks.py "view source code") + +Bases: `Task`, [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class of a single pass manager task. + +A pass instance can read and write to the provided [`PropertySet`](qiskit.passmanager.PropertySet "qiskit.passmanager.PropertySet"), and may modify the input pass manager IR. + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`abstract run(passmanager_ir)` + +Run optimization task. + +**Parameters** + +**passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. + +**Returns** + +Optimized Qiskit IR. + +**Return type** + +[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.PassManagerState.md b/docs/api/qiskit/0.46/qiskit.passmanager.PassManagerState.md new file mode 100644 index 00000000000..4d876b0c43d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.PassManagerState.md @@ -0,0 +1,40 @@ +--- +title: PassManagerState +description: API reference for qiskit.passmanager.PassManagerState +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.PassManagerState +--- + +# PassManagerState + + + +`qiskit.passmanager.PassManagerState(workflow_status, property_set)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/compilation_status.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A portable container object that pass manager tasks communicate through generator. + +This object can contain every information about the running pass manager workflow, except for the IR object being optimized. The data structure consists of two elements; one for the status of the workflow itself, and another one for the additional information about the IR analyzed through pass executions. This container aims at just providing a robust interface for the `Task.execute()`, and no logic that modifies the container elements must be implemented. + +This object is mutable, and might be mutated by pass executions. + +## Attributes + + + +### workflow\_status + +`WorkflowStatus` + +Status of the current compilation workflow. + + + +### property\_set + +`PropertySet` + +Information about IR being optimized. + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.PropertySet.md b/docs/api/qiskit/0.46/qiskit.passmanager.PropertySet.md new file mode 100644 index 00000000000..735c0e8b0b3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.PropertySet.md @@ -0,0 +1,102 @@ +--- +title: PropertySet +description: API reference for qiskit.passmanager.PropertySet +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.PropertySet +--- + +# PropertySet + + + +`qiskit.passmanager.PropertySet`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/compilation_status.py "view source code") + +Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +A default dictionary-like object. + +## Methods + +### clear + + + +`clear() → None.  Remove all items from D.` + +### copy + + + +`copy() → a shallow copy of D` + +### fromkeys + + + +`fromkeys(value=None, /)` + +Create a new dictionary with keys from iterable and values set to value. + +### get + + + +`get(key, default=None, /)` + +Return the value for key if key is in the dictionary, else default. + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### pop + + + +`pop(k[, d]) → v, remove specified key and return the corresponding value.` + +If key is not found, default is returned if given, otherwise KeyError is raised + +### popitem + + + +`popitem()` + +Remove and return a (key, value) pair as a 2-tuple. + +Pairs are returned in LIFO (last-in, first-out) order. Raises KeyError if the dict is empty. + +### setdefault + + + +`setdefault(key, default=None, /)` + +Insert key with a value of default if key is not in the dictionary. + +Return the value for key if key is in the dictionary, else default. + +### update + + + +`update([E, ]**F) → None.  Update D from dict/iterable E and F.` + +If E is present and has a .keys() method, then does: for k in E: D\[k] = E\[k] If E is present and lacks a .keys() method, then does: for k, v in E: D\[k] = v In either case, this is followed by: for k in F: D\[k] = F\[k] + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.passmanager.WorkflowStatus.md b/docs/api/qiskit/0.46/qiskit.passmanager.WorkflowStatus.md new file mode 100644 index 00000000000..9b1711c7bc8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.passmanager.WorkflowStatus.md @@ -0,0 +1,50 @@ +--- +title: WorkflowStatus +description: API reference for qiskit.passmanager.WorkflowStatus +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.passmanager.WorkflowStatus +--- + +# WorkflowStatus + + + +`qiskit.passmanager.WorkflowStatus(count=0, completed_passes=, previous_run=RunState.FAIL)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/passmanager/compilation_status.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Collection of compilation status of workflow, i.e. pass manager run. + +This data structure is initialized when the pass manager is run, and recursively handed over to underlying tasks. Each pass will update this status once after being executed, and the lifetime of the workflow status object is the time during which the pass manager is running. + +## Attributes + + + +### count + +`int` + +`= 0` + +Current number of pass execution. + + + +### previous\_run + +`RunState` + +`= 1` + +Status of the latest pass run. + + + +### completed\_passes + +`set` + +Passes already run that have not been invalidated. + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.BackendEstimator.md b/docs/api/qiskit/0.46/qiskit.primitives.BackendEstimator.md new file mode 100644 index 00000000000..698aae34ecd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.BackendEstimator.md @@ -0,0 +1,172 @@ +--- +title: BackendEstimator +description: API reference for qiskit.primitives.BackendEstimator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BackendEstimator +--- + +# BackendEstimator + + + +`qiskit.primitives.BackendEstimator(backend, options=None, abelian_grouping=True, bound_pass_manager=None, skip_transpilation=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/backend_estimator.py "view source code") + +Bases: [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.base.base_estimator.BaseEstimator")\[`PrimitiveJob`\[[`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.base.estimator_result.EstimatorResult")]] + +Evaluates expectation value using Pauli rotation gates. + +The [`BackendEstimator`](#qiskit.primitives.BackendEstimator "qiskit.primitives.BackendEstimator") class is a generic implementation of the [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") interface that is used to wrap a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") (or [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1")) object in the [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") API. It facilitates using backends that do not provide a native [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator") implementation in places that work with [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator"), such as algorithms in [`qiskit.algorithms`](algorithms#module-qiskit.algorithms "qiskit.algorithms") including [`VQE`](qiskit.algorithms.minimum_eigensolvers.VQE "qiskit.algorithms.minimum_eigensolvers.VQE"). However, if you’re using a provider that has a native implementation of [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator"), it is a better choice to leverage that native implementation as it will likely include additional optimizations and be a more efficient implementation. The generic nature of this class precludes doing any provider- or backend-specific optimizations. + +Initialize a new BackendEstimator instance + +**Parameters** + +* **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") *|*[*BackendV2*](qiskit.providers.BackendV2 "qiskit.providers.BackendV2")) – Required: the backend to run the primitive on +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Default options. +* **abelian\_grouping** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the observable should be grouped into commuting +* **bound\_pass\_manager** ([*PassManager*](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") *| None*) – An optional pass manager to run after parameter binding. +* **skip\_transpilation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If this is set to True the internal compilation of the input circuits is skipped and the circuit objects will be directly executed when this object is called. + +## Attributes + + + +### backend + +Returns: The backend which this estimator object based on + + + +### circuits + +Quantum circuits that represents quantum states. + +**Returns** + +The quantum circuits. + + + +### observables + +Observables to be estimated. + +**Returns** + +The observables. + + + +### options + +Return options values for the estimator. + +**Returns** + +options + + + +### parameters + +Parameters of the quantum circuits. + +**Returns** + +Parameters, where `parameters[i][j]` is the j-th parameter of the i-th circuit. + + + +### preprocessed\_circuits + +Transpiled quantum circuits produced by preprocessing :returns: List of the transpiled quantum circuit + + + +### transpile\_options + +Return the transpiler options for transpiling the circuits. + + + +### transpiled\_circuits + +Transpiled quantum circuits. :returns: List of the transpiled quantum circuit + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the instance has been closed. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values=None, **run_options)` + +Run the job of the estimation of expectation value(s). + +`circuits`, `observables`, and `parameter_values` should have the same length. The i-th element of the result is the expectation of observable + +```python +obs = observables[i] +``` + +for the state prepared by + +```python +circ = circuits[i] +``` + +with bound parameters + +```python +values = parameter_values[i]. +``` + + + Implicit conversion from a `PauliList` to a `SparsePauliOp` with `coeffs=1` in the `observables` arguments is deprecated as of Qiskit 0.46 and will be removed in Qiskit 1.0. You should explicitly convert to a `SparsePauli` using `SparsePauliOp(pauli_list)` to avoid this warning. + + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] |* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – one or more circuit objects. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – one or more observable objects. Several formats are allowed; importantly, `str` should follow the string representation format for [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") objects. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – concrete parameters to be bound. +* **run\_options** – runtime options used for circuit execution. + +**Returns** + +The job object of EstimatorResult. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Invalid argument type given. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid argument values given. + +**Return type** + +T + +### set\_options + + + +`set_options(**fields)` + +Set options values for the estimator. + +**Parameters** + +**\*\*fields** – The fields to update the options + +### set\_transpile\_options + + + +`set_transpile_options(**fields)` + +Set the transpiler options for transpiler. :param \*\*fields: The fields to update the options + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.BackendSampler.md b/docs/api/qiskit/0.46/qiskit.primitives.BackendSampler.md new file mode 100644 index 00000000000..b10f1c3958e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.BackendSampler.md @@ -0,0 +1,153 @@ +--- +title: BackendSampler +description: API reference for qiskit.primitives.BackendSampler +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BackendSampler +--- + +# BackendSampler + + + +`qiskit.primitives.BackendSampler(backend, options=None, bound_pass_manager=None, skip_transpilation=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/backend_sampler.py "view source code") + +Bases: [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.base.base_sampler.BaseSampler")\[`PrimitiveJob`\[[`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.base.sampler_result.SamplerResult")]] + +A [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") implementation that provides an interface for leveraging the sampler interface from any backend. + +This class provides a sampler interface from any backend and doesn’t do any measurement mitigation, it just computes the probability distribution from the counts. It facilitates using backends that do not provide a native [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler") implementation in places that work with [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler"), such as algorithms in [`qiskit.algorithms`](algorithms#module-qiskit.algorithms "qiskit.algorithms") including [`SamplingVQE`](qiskit.algorithms.minimum_eigensolvers.SamplingVQE "qiskit.algorithms.minimum_eigensolvers.SamplingVQE"). However, if you’re using a provider that has a native implementation of [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler"), it is a better choice to leverage that native implementation as it will likely include additional optimizations and be a more efficient implementation. The generic nature of this class precludes doing any provider- or backend-specific optimizations. + +Initialize a new BackendSampler + +**Parameters** + +* **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") *|*[*BackendV2*](qiskit.providers.BackendV2 "qiskit.providers.BackendV2")) – Required: the backend to run the sampler primitive on +* **options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Default options. +* **bound\_pass\_manager** ([*PassManager*](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") *| None*) – An optional pass manager to run after parameter binding. +* **skip\_transpilation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If this is set to True the internal compilation of the input circuits is skipped and the circuit objects will be directly executed when this objected is called. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If backend is not provided + +## Attributes + + + +### backend + +Returns: The backend which this sampler object based on + + + +### circuits + +Quantum circuits to be sampled. + +**Returns** + +The quantum circuits to be sampled. + + + +### options + +Return options values for the estimator. + +**Returns** + +options + + + +### parameters + +Parameters of quantum circuits. + +**Returns** + +List of the parameters in each quantum circuit. + + + +### preprocessed\_circuits + +Preprocessed quantum circuits produced by preprocessing :returns: List of the transpiled quantum circuit + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the instance has been closed. + + + +### transpile\_options + +Return the transpiler options for transpiling the circuits. + + + +### transpiled\_circuits + +Transpiled quantum circuits. :returns: List of the transpiled quantum circuit + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the instance has been closed. + +## Methods + +### run + + + +`run(circuits, parameter_values=None, **run_options)` + +Run the job of the sampling of bitstrings. + +**Parameters** + +* **circuits** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – One of more circuit objects. +* **parameter\_values** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Parameters to be bound to the circuit. +* **run\_options** – Backend runtime options used for circuit execution. + +**Returns** + +The job object of the result of the sampler. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +T + +### set\_options + + + +`set_options(**fields)` + +Set options values for the estimator. + +**Parameters** + +**\*\*fields** – The fields to update the options + +### set\_transpile\_options + + + +`set_transpile_options(**fields)` + +Set the transpiler options for transpiler. :param \*\*fields: The fields to update the options. + +**Returns** + +self. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the instance has been closed. + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.BaseEstimator.md b/docs/api/qiskit/0.46/qiskit.primitives.BaseEstimator.md new file mode 100644 index 00000000000..e1a0f4cdf54 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.BaseEstimator.md @@ -0,0 +1,132 @@ +--- +title: BaseEstimator +description: API reference for qiskit.primitives.BaseEstimator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BaseEstimator +--- + +# BaseEstimator + + + +`qiskit.primitives.BaseEstimator(*, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/base/base_estimator.py "view source code") + +Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] + +Estimator base class. + +Base class for Estimator that estimates expectation values of quantum circuits and observables. + +Creating an instance of an Estimator, or using one in a `with` context opens a session that holds resources until the instance is `close()` ed or the context is exited. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Default options. + +## Attributes + + + +### circuits + +Quantum circuits that represents quantum states. + +**Returns** + +The quantum circuits. + + + +### observables + +Observables to be estimated. + +**Returns** + +The observables. + + + +### options + +Return options values for the estimator. + +**Returns** + +options + + + +### parameters + +Parameters of the quantum circuits. + +**Returns** + +Parameters, where `parameters[i][j]` is the j-th parameter of the i-th circuit. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values=None, **run_options)` + +Run the job of the estimation of expectation value(s). + +`circuits`, `observables`, and `parameter_values` should have the same length. The i-th element of the result is the expectation of observable + +```python +obs = observables[i] +``` + +for the state prepared by + +```python +circ = circuits[i] +``` + +with bound parameters + +```python +values = parameter_values[i]. +``` + + + Implicit conversion from a `PauliList` to a `SparsePauliOp` with `coeffs=1` in the `observables` arguments is deprecated as of Qiskit 0.46 and will be removed in Qiskit 1.0. You should explicitly convert to a `SparsePauli` using `SparsePauliOp(pauli_list)` to avoid this warning. + + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] |* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – one or more circuit objects. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – one or more observable objects. Several formats are allowed; importantly, `str` should follow the string representation format for [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") objects. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – concrete parameters to be bound. +* **run\_options** – runtime options used for circuit execution. + +**Returns** + +The job object of EstimatorResult. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Invalid argument type given. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid argument values given. + +**Return type** + +T + +### set\_options + + + +`set_options(**fields)` + +Set options values for the estimator. + +**Parameters** + +**\*\*fields** – The fields to update the options + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.BaseSampler.md b/docs/api/qiskit/0.46/qiskit.primitives.BaseSampler.md new file mode 100644 index 00000000000..a2634c0d2c9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.BaseSampler.md @@ -0,0 +1,96 @@ +--- +title: BaseSampler +description: API reference for qiskit.primitives.BaseSampler +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.BaseSampler +--- + +# BaseSampler + + + +`qiskit.primitives.BaseSampler(*, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/base/base_sampler.py "view source code") + +Bases: `BasePrimitive`, [`Generic`](https://docs.python.org/3/library/typing.html#typing.Generic "(in Python v3.12)")\[`T`] + +Sampler base class + +Base class of Sampler that calculates quasi-probabilities of bitstrings from quantum circuits. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Default options. + +## Attributes + + + +### circuits + +Quantum circuits to be sampled. + +**Returns** + +The quantum circuits to be sampled. + + + +### options + +Return options values for the estimator. + +**Returns** + +options + + + +### parameters + +Parameters of quantum circuits. + +**Returns** + +List of the parameters in each quantum circuit. + +## Methods + +### run + + + +`run(circuits, parameter_values=None, **run_options)` + +Run the job of the sampling of bitstrings. + +**Parameters** + +* **circuits** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – One of more circuit objects. +* **parameter\_values** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Parameters to be bound to the circuit. +* **run\_options** – Backend runtime options used for circuit execution. + +**Returns** + +The job object of the result of the sampler. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +T + +### set\_options + + + +`set_options(**fields)` + +Set options values for the estimator. + +**Parameters** + +**\*\*fields** – The fields to update the options + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.Estimator.md b/docs/api/qiskit/0.46/qiskit.primitives.Estimator.md new file mode 100644 index 00000000000..997c9dcd96d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.Estimator.md @@ -0,0 +1,137 @@ +--- +title: Estimator +description: API reference for qiskit.primitives.Estimator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.Estimator +--- + +# Estimator + + + +`qiskit.primitives.Estimator(*, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/estimator.py "view source code") + +Bases: [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.base.base_estimator.BaseEstimator")\[`PrimitiveJob`\[[`EstimatorResult`](qiskit.primitives.EstimatorResult "qiskit.primitives.base.estimator_result.EstimatorResult")]] + +Reference implementation of [`BaseEstimator`](qiskit.primitives.BaseEstimator "qiskit.primitives.BaseEstimator"). + +**Run Options** + +* **shots** (None or int) – The number of shots. If None, it calculates the exact expectation values. Otherwise, it samples from normal distributions with standard errors as standard deviations using normal distribution approximation. +* **seed** (np.random.Generator or int) – Set a fixed seed or generator for the normal distribution. If shots is None, this option is ignored. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Default options. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if some classical bits are not used for measurements. + +## Attributes + + + +### circuits + +Quantum circuits that represents quantum states. + +**Returns** + +The quantum circuits. + + + +### observables + +Observables to be estimated. + +**Returns** + +The observables. + + + +### options + +Return options values for the estimator. + +**Returns** + +options + + + +### parameters + +Parameters of the quantum circuits. + +**Returns** + +Parameters, where `parameters[i][j]` is the j-th parameter of the i-th circuit. + +## Methods + +### run + + + +`run(circuits, observables, parameter_values=None, **run_options)` + +Run the job of the estimation of expectation value(s). + +`circuits`, `observables`, and `parameter_values` should have the same length. The i-th element of the result is the expectation of observable + +```python +obs = observables[i] +``` + +for the state prepared by + +```python +circ = circuits[i] +``` + +with bound parameters + +```python +values = parameter_values[i]. +``` + + + Implicit conversion from a `PauliList` to a `SparsePauliOp` with `coeffs=1` in the `observables` arguments is deprecated as of Qiskit 0.46 and will be removed in Qiskit 1.0. You should explicitly convert to a `SparsePauli` using `SparsePauliOp(pauli_list)` to avoid this warning. + + +**Parameters** + +* **circuits** (*Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] |* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – one or more circuit objects. +* **observables** (*Sequence\[BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | BaseOperator |* [*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – one or more observable objects. Several formats are allowed; importantly, `str` should follow the string representation format for [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") objects. +* **parameter\_values** (*Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] |* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – concrete parameters to be bound. +* **run\_options** – runtime options used for circuit execution. + +**Returns** + +The job object of EstimatorResult. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – Invalid argument type given. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid argument values given. + +**Return type** + +T + +### set\_options + + + +`set_options(**fields)` + +Set options values for the estimator. + +**Parameters** + +**\*\*fields** – The fields to update the options + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.EstimatorResult.md b/docs/api/qiskit/0.46/qiskit.primitives.EstimatorResult.md new file mode 100644 index 00000000000..3ef9672c1ca --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.EstimatorResult.md @@ -0,0 +1,81 @@ +--- +title: EstimatorResult +description: API reference for qiskit.primitives.EstimatorResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.EstimatorResult +--- + +# EstimatorResult + + + +`qiskit.primitives.EstimatorResult(values, metadata)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/base/estimator_result.py "view source code") + +Bases: `_BasePrimitiveResult` + +Result of Estimator. + +```python +result = estimator.run(circuits, observables, params).result() +``` + +where the i-th elements of `result` correspond to the circuit and observable given by `circuits[i]`, `observables[i]`, and the parameter values bounds by `params[i]`. For example, `results.values[i]` gives the expectation value, and `result.metadata[i]` is a metadata dictionary for this circuit and parameters. + +**Parameters** + +* **values** (*np.ndarray*) – The array of the expectation values. +* **metadata** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*]*) – List of the metadata. + +## Attributes + + + +### experiments + +Experiment data dicts in any inheriting result dataclass. + + + The property `qiskit.primitives.base.base_result._BasePrimitiveResult.experiments` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. + + + + +### num\_experiments + +Number of experiments in any inheriting result dataclass. + + + The property `qiskit.primitives.base.base_result._BasePrimitiveResult.num_experiments` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. + + + + +### values + +`np.ndarray[Any, np.dtype[np.float64]]` + + + +### metadata + +`list[dict[str, Any]]` + +## Methods + +### decompose + + + +`decompose()` + +Generate single experiment result objects from self. + + + The method `qiskit.primitives.base.base_result._BasePrimitiveResult.decompose()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. + + +**Return type** + +[*Iterator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Iterator "(in Python v3.12)")\[*\_BasePrimitiveResult*] + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.Sampler.md b/docs/api/qiskit/0.46/qiskit.primitives.Sampler.md new file mode 100644 index 00000000000..e37a1dde922 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.Sampler.md @@ -0,0 +1,105 @@ +--- +title: Sampler +description: API reference for qiskit.primitives.Sampler +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.Sampler +--- + +# Sampler + + + +`qiskit.primitives.Sampler(*, options=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/sampler.py "view source code") + +Bases: [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.base.base_sampler.BaseSampler")\[`PrimitiveJob`\[[`SamplerResult`](qiskit.primitives.SamplerResult "qiskit.primitives.base.sampler_result.SamplerResult")]] + +Sampler class. + +[`Sampler`](#qiskit.primitives.Sampler "qiskit.primitives.Sampler") is a reference implementation of [`BaseSampler`](qiskit.primitives.BaseSampler "qiskit.primitives.BaseSampler"). + +**Run Options** + +* **shots** (None or int) – The number of shots. If None, it calculates the probabilities. Otherwise, it samples from multinomial distributions. +* **seed** (np.random.Generator or int) – Set a fixed seed or generator for the multinomial distribution. If shots is None, this option is ignored. + +**Parameters** + +**options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Default options. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if some classical bits are not used for measurements. + +## Attributes + + + +### circuits + +Quantum circuits to be sampled. + +**Returns** + +The quantum circuits to be sampled. + + + +### options + +Return options values for the estimator. + +**Returns** + +options + + + +### parameters + +Parameters of quantum circuits. + +**Returns** + +List of the parameters in each quantum circuit. + +## Methods + +### run + + + +`run(circuits, parameter_values=None, **run_options)` + +Run the job of the sampling of bitstrings. + +**Parameters** + +* **circuits** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *| Sequence\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – One of more circuit objects. +* **parameter\_values** (*Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | Sequence\[Sequence\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]] | None*) – Parameters to be bound to the circuit. +* **run\_options** – Backend runtime options used for circuit execution. + +**Returns** + +The job object of the result of the sampler. The i-th result corresponds to `circuits[i]` evaluated with parameters bound as `parameter_values[i]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid arguments are given. + +**Return type** + +T + +### set\_options + + + +`set_options(**fields)` + +Set options values for the estimator. + +**Parameters** + +**\*\*fields** – The fields to update the options + diff --git a/docs/api/qiskit/0.46/qiskit.primitives.SamplerResult.md b/docs/api/qiskit/0.46/qiskit.primitives.SamplerResult.md new file mode 100644 index 00000000000..0cc0ee6acda --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.primitives.SamplerResult.md @@ -0,0 +1,81 @@ +--- +title: SamplerResult +description: API reference for qiskit.primitives.SamplerResult +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.primitives.SamplerResult +--- + +# SamplerResult + + + +`qiskit.primitives.SamplerResult(quasi_dists, metadata)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/primitives/base/sampler_result.py "view source code") + +Bases: `_BasePrimitiveResult` + +Result of Sampler. + +```python +result = sampler.run(circuits, params).result() +``` + +where the i-th elements of `result` correspond to the circuit given by `circuits[i]`, and the parameter values bounds by `params[i]`. For example, `results.quasi_dists[i]` gives the quasi-probabilities of bitstrings, and `result.metadata[i]` is a metadata dictionary for this circuit and parameters. + +**Parameters** + +* **quasi\_dists** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*QuasiDistribution*](qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution")*]*) – List of the quasi-probabilities. +* **metadata** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*]*) – List of the metadata. + +## Attributes + + + +### experiments + +Experiment data dicts in any inheriting result dataclass. + + + The property `qiskit.primitives.base.base_result._BasePrimitiveResult.experiments` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. + + + + +### num\_experiments + +Number of experiments in any inheriting result dataclass. + + + The property `qiskit.primitives.base.base_result._BasePrimitiveResult.num_experiments` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. + + + + +### quasi\_dists + +`list[qiskit.result.distributions.quasi.QuasiDistribution]` + + + +### metadata + +`list[dict[str, Any]]` + +## Methods + +### decompose + + + +`decompose()` + +Generate single experiment result objects from self. + + + The method `qiskit.primitives.base.base_result._BasePrimitiveResult.decompose()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. + + +**Return type** + +[*Iterator*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Iterator "(in Python v3.12)")\[*\_BasePrimitiveResult*] + diff --git a/docs/api/qiskit/0.46/qiskit.providers.Backend.md b/docs/api/qiskit/0.46/qiskit.providers.Backend.md new file mode 100644 index 00000000000..ccc88952e78 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.Backend.md @@ -0,0 +1,28 @@ +--- +title: Backend +description: API reference for qiskit.providers.Backend +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.Backend +--- + +# Backend + + + +`qiskit.providers.Backend`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/backend.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Base common type for all versioned Backend abstract classes. + +Note this class should not be inherited from directly, it is intended to be used for type checking. When implementing a provider you should use the versioned abstract classes as the parent class and not this class directly. + +## Attributes + + + +### version + +`= 0` + diff --git a/docs/api/qiskit/0.46/qiskit.providers.BackendV1.md b/docs/api/qiskit/0.46/qiskit.providers.BackendV1.md new file mode 100644 index 00000000000..535cb868e57 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.BackendV1.md @@ -0,0 +1,213 @@ +--- +title: BackendV1 +description: API reference for qiskit.providers.BackendV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.BackendV1 +--- + +# BackendV1 + + + +`qiskit.providers.BackendV1(configuration, provider=None, **fields)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/backend.py "view source code") + +Bases: [`Backend`](qiskit.providers.Backend "qiskit.providers.backend.Backend"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Abstract class for Backends + +This abstract class is to be used for all Backend objects created by a provider. There are several classes of information contained in a Backend. The first are the attributes of the class itself. These should be used to defined the immutable characteristics of the backend. The `options` attribute of the backend is used to contain the dynamic user configurable options of the backend. It should be used more for runtime options that configure how the backend is used. For example, something like a `shots` field for a backend that runs experiments which would contain an int for how many shots to execute. The `properties` attribute is optionally defined [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") object and is used to return measured properties, or properties of a backend that may change over time. The simplest example of this would be a version string, which will change as a backend is updated, but also could be something like noise parameters for backends that run experiments. + +This first version of the Backend abstract class is written to be mostly backwards compatible with the legacy providers interface. This includes reusing the model objects [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") and [`BackendConfiguration`](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration"). This was done to ease the transition for users and provider maintainers to the new versioned providers. Expect, future versions of this abstract class to change the data model and interface. + +Subclasses of this should override the public method [`run()`](#qiskit.providers.BackendV1.run "qiskit.providers.BackendV1.run") and the internal [`_default_options()`](#qiskit.providers.BackendV1._default_options "qiskit.providers.BackendV1._default_options"): + +### \_default\_options + + + +`abstract classmethod _default_options()` + +Return the default options + +This method will return a [`qiskit.providers.Options`](qiskit.providers.Options "qiskit.providers.Options") subclass object that will be used for the default options. These should be the default parameters to use for the options of the backend. + +**Returns** + +**A options object with** + +default values set + +**Return type** + +[qiskit.providers.Options](qiskit.providers.Options "qiskit.providers.Options") + +Initialize a backend class + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – A backend configuration object for the backend object. +* **provider** ([*qiskit.providers.Provider*](qiskit.providers.Provider "qiskit.providers.Provider")) – Optionally, the provider object that this Backend comes from. +* **fields** – kwargs for the values to use to override the default options. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – if input field not a valid options + +In addition to the public abstract methods, subclasses should also implement the following private methods: + +`abstract classmethod _default_options()` + +Return the default options + +This method will return a [`qiskit.providers.Options`](qiskit.providers.Options "qiskit.providers.Options") subclass object that will be used for the default options. These should be the default parameters to use for the options of the backend. + +**Returns** + +**A options object with** + +default values set + +**Return type** + +[qiskit.providers.Options](qiskit.providers.Options "qiskit.providers.Options") + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.BackendV1.run "qiskit.providers.BackendV1.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return the backend properties. + +**Returns** + +the configuration for the backend. If the backend does not support properties, it returns `None`. + +**Return type** + +[BackendProperties](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`abstract run(run_input, **options)` + +Run on the backend. + +This method returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object that runs circuits. Depending on the backend this may be either an async or sync call. It is at the discretion of the provider to decide whether running should block until the execution is finished or not: the Job class can handle either situation. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. For legacy providers migrating to the new versioned providers, provider interface a [`QasmQobj`](qiskit.qobj.QasmQobj "qiskit.qobj.QasmQobj") or [`PulseQobj`](qiskit.qobj.PulseQobj "qiskit.qobj.PulseQobj") objects should probably be supported too (but deprecated) for backwards compatibility. Be sure to update the docstrings of subclasses implementing this method to document that. New provider implementations should not do this though as [`qiskit.qobj`](qobj#module-qiskit.qobj "qiskit.qobj") will be deprecated and removed along with the legacy providers interface. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.BackendV2.md b/docs/api/qiskit/0.46/qiskit.providers.BackendV2.md new file mode 100644 index 00000000000..a7b0012d7b0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.BackendV2.md @@ -0,0 +1,382 @@ +--- +title: BackendV2 +description: API reference for qiskit.providers.BackendV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.BackendV2 +--- + +# BackendV2 + + + +`qiskit.providers.BackendV2(provider=None, name=None, description=None, online_date=None, backend_version=None, **fields)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/backend.py "view source code") + +Bases: [`Backend`](qiskit.providers.Backend "qiskit.providers.backend.Backend"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Abstract class for Backends + +This abstract class is to be used for all Backend objects created by a provider. This version differs from earlier abstract Backend classes in that the configuration attribute no longer exists. Instead, attributes exposing equivalent required immutable properties of the backend device are added. For example `backend.configuration().n_qubits` is accessible from `backend.num_qubits` now. + +The `options` attribute of the backend is used to contain the dynamic user configurable options of the backend. It should be used more for runtime options that configure how the backend is used. For example, something like a `shots` field for a backend that runs experiments which would contain an int for how many shots to execute. + +If migrating a provider from [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") one thing to keep in mind is for backwards compatibility you might need to add a configuration method that will build a [`BackendConfiguration`](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") object and [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") from the attributes defined in this class for backwards compatibility. + +A backend object can optionally contain methods named `get_translation_stage_plugin` and `get_scheduling_stage_plugin`. If these methods are present on a backend object and this object is used for [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`generate_preset_pass_manager()`](transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") the transpilation process will default to using the output from those methods as the scheduling stage and the translation compilation stage. This enables a backend which has custom requirements for compilation to specify a stage plugin for these stages to enable custom transformation of the circuit to ensure it is runnable on the backend. These hooks are enabled by default and should only be used to enable extra compilation steps if they are **required** to ensure a circuit is executable on the backend or have the expected level of performance. These methods are passed no input arguments and are expected to return a `str` representing the method name which should be a stage plugin (see: [`qiskit.transpiler.preset_passmanagers.plugin`](transpiler_plugins#module-qiskit.transpiler.preset_passmanagers.plugin "qiskit.transpiler.preset_passmanagers.plugin") for more details on plugins). The typical expected use case is for a backend provider to implement a stage plugin for `translation` or `scheduling` that contains the custom compilation passes and then for the hook methods on the backend object to return the plugin name so that [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") will use it by default when targetting the backend. + +Subclasses of this should override the public method [`run()`](#qiskit.providers.BackendV2.run "qiskit.providers.BackendV2.run") and the internal [`_default_options()`](#qiskit.providers.BackendV2._default_options "qiskit.providers.BackendV2._default_options"): + +### \_default\_options + + + +`abstract classmethod _default_options()` + +Return the default options + +This method will return a [`qiskit.providers.Options`](qiskit.providers.Options "qiskit.providers.Options") subclass object that will be used for the default options. These should be the default parameters to use for the options of the backend. + +**Returns** + +**A options object with** + +default values set + +**Return type** + +[qiskit.providers.Options](qiskit.providers.Options "qiskit.providers.Options") + +Initialize a BackendV2 based backend + +**Parameters** + +* **provider** ([*Provider*](qiskit.providers.Provider "qiskit.providers.provider.Provider")) – An optional backwards reference to the [`Provider`](qiskit.providers.Provider "qiskit.providers.Provider") object that the backend is from +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional name for the backend +* **description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional description of the backend +* **online\_date** ([*datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)")) – An optional datetime the backend was brought online +* **backend\_version** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional backend version string. This differs from the [`version`](#qiskit.providers.BackendV2.version "qiskit.providers.BackendV2.version") attribute as [`version`](#qiskit.providers.BackendV2.version "qiskit.providers.BackendV2.version") is for the abstract [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface version of the object while `backend_version` is for versioning the backend itself. +* **fields** – kwargs for the values to use to override the default options. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If a field is specified that’s outside the backend’s options + +## Attributes + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the output signal timestep + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + +The maximum number of circuits (or Pulse schedules) that can be run in a single job. + +If there is no limit this will return None + + + +### meas\_map + +Return the grouping of measurements which are multiplexed + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.BackendV2.run "qiskit.providers.BackendV2.run") method. + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](#qiskit.providers.BackendV2.version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`abstract run(run_input, **options)` + +Run on the backend. + +This method returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object that runs circuits. Depending on the backend this may be either an async or sync call. It is at the discretion of the provider to decide whether running should block until the execution is finished or not: the Job class can handle either situation. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.BackendV2Converter.md b/docs/api/qiskit/0.46/qiskit.providers.BackendV2Converter.md new file mode 100644 index 00000000000..639851eb89f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.BackendV2Converter.md @@ -0,0 +1,333 @@ +--- +title: BackendV2Converter +description: API reference for qiskit.providers.BackendV2Converter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.BackendV2Converter +--- + +# BackendV2Converter + + + +`qiskit.providers.BackendV2Converter(backend, name_mapping=None, add_delay=False, filter_faulty=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/backend_compat.py "view source code") + +Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") + +A converter class that takes a [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") instance and wraps it in a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") interface. + +This class implements the [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") interface and is used to enable common access patterns between [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") and [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2"). This class should only be used if you need a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") and still need compatibility with [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1"). + +When using custom calibrations (or other custom workflows) it is **not** recommended to mutate the `BackendV1` object before applying this converter. For example, in order to convert a `BackendV1` object with a customized `defaults().instruction_schedule_map`, which has a custom calibration for an operation, the operation name must be in `configuration().basis_gates` and `name_mapping` must be supplied for the operation. Otherwise, the operation will be dropped in the resulting `BackendV2` object. + +Instead it is typically better to add custom calibrations **after** applying this converter instead of updating `BackendV1.defaults()` in advance. For example: + +```python +backend_v2 = BackendV2Converter(backend_v1) +backend_v2.target.add_instruction( + custom_gate, {(0, 1): InstructionProperties(calibration=custom_sched)} +) +``` + +Initialize a BackendV2 converter instance based on a BackendV1 instance. + +**Parameters** + +* **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.BackendV1")) – The input [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.BackendV1") based backend to wrap in a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") interface +* **name\_mapping** (*Optional\[Dict\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any]]*) – An optional dictionary that maps custom gate/operation names in `backend` to an [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") object representing that gate/operation. By default most standard gates names are mapped to the standard gate object from [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") this only needs to be specified if the input `backend` defines gates in names outside that set. +* **add\_delay** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to true a [`Delay`](qiskit.circuit.Delay "qiskit.circuit.Delay") operation will be added to the target as a supported operation for all qubits +* **filter\_faulty** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If the [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") object (if present) for `backend` has any qubits or gates flagged as non-operational filter those from the output target. + +## Attributes + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.BackendV2Converter.run "qiskit.providers.BackendV2Converter.run") method. + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the backend. + +This method returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object that runs circuits. Depending on the backend this may be either an async or sync call. It is at the discretion of the provider to decide whether running should block until the execution is finished or not: the Job class can handle either situation. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.Job.md b/docs/api/qiskit/0.46/qiskit.providers.Job.md new file mode 100644 index 00000000000..9942bfc73fd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.Job.md @@ -0,0 +1,28 @@ +--- +title: Job +description: API reference for qiskit.providers.Job +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.Job +--- + +# Job + + + +`qiskit.providers.Job`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/job.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Base common type for all versioned Job abstract classes. + +Note this class should not be inherited from directly, it is intended to be used for type checking. When implementing a provider you should use the versioned abstract classes as the parent class and not this class directly. + +## Attributes + + + +### version + +`= 0` + diff --git a/docs/api/qiskit/0.46/qiskit.providers.JobStatus.md b/docs/api/qiskit/0.46/qiskit.providers.JobStatus.md new file mode 100644 index 00000000000..90d8f04f89c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.JobStatus.md @@ -0,0 +1,62 @@ +--- +title: JobStatus +description: API reference for qiskit.providers.JobStatus +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.JobStatus +--- + +# JobStatus + + + +`qiskit.providers.JobStatus(value)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/jobstatus.py "view source code") + +Bases: [`Enum`](https://docs.python.org/3/library/enum.html#enum.Enum "(in Python v3.12)") + +Class for job status enumerated type. + +## Attributes + + + +### INITIALIZING + +`= 'job is being initialized'` + + + +### QUEUED + +`= 'job is queued'` + + + +### VALIDATING + +`= 'job is being validated'` + + + +### RUNNING + +`= 'job is actively running'` + + + +### CANCELLED + +`= 'job has been cancelled'` + + + +### DONE + +`= 'job has successfully run'` + + + +### ERROR + +`= 'job incurred error'` + diff --git a/docs/api/qiskit/0.46/qiskit.providers.JobV1.md b/docs/api/qiskit/0.46/qiskit.providers.JobV1.md new file mode 100644 index 00000000000..ae761dec4f1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.JobV1.md @@ -0,0 +1,170 @@ +--- +title: JobV1 +description: API reference for qiskit.providers.JobV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.JobV1 +--- + +# JobV1 + + + +`qiskit.providers.JobV1(backend, job_id, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/job.py "view source code") + +Bases: [`Job`](qiskit.providers.Job "qiskit.providers.job.Job"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Class to handle jobs + +This first version of the Backend abstract class is written to be mostly backwards compatible with the legacy providers interface. This was done to ease the transition for users and provider maintainers to the new versioned providers. Expect, future versions of this abstract class to change the data model and interface. + +Initializes the asynchronous job. + +**Parameters** + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *| None*) – the backend used to run the job. +* **job\_id** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a unique id in the context of the backend used to run the job. +* **kwargs** – Any key value metadata to associate with this job. + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backend + + + +`backend()` + +Return the backend where this job was executed. + +**Return type** + +[*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") + +### cancel + + + +`cancel()` + +Attempt to cancel the job. + +### cancelled + + + +`cancelled()` + +Return whether the job has been cancelled. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### done + + + +`done()` + +Return whether the job has successfully run. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### in\_final\_state + + + +`in_final_state()` + +Return whether the job is in a final job state such as `DONE` or `ERROR`. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### job\_id + + + +`job_id()` + +Return a unique id identifying the job. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### result + + + +`abstract result()` + +Return the results of the job. + +### running + + + +`running()` + +Return whether the job is actively running. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### status + + + +`abstract status()` + +Return the status of the job, among the values of `JobStatus`. + +### submit + + + +`abstract submit()` + +Submit the job to the backend for execution. + +### wait\_for\_final\_state + + + +`wait_for_final_state(timeout=None, wait=5, callback=None)` + +Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. + +**Parameters** + +* **timeout** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Seconds to wait for the job. If `None`, wait indefinitely. + +* **wait** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Seconds between queries. + +* **callback** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – + + Callback function invoked after each query. The following positional arguments are provided to the callback function: + + * job\_id: Job ID + * job\_status: Status of the job from the last query + * job: This BaseJob instance + + Note: different subclass might provide different arguments to the callback function. + +**Raises** + +[**JobTimeoutError**](providers#qiskit.providers.JobTimeoutError "qiskit.providers.JobTimeoutError") – If the job does not reach a final state before the specified timeout. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.Options.md b/docs/api/qiskit/0.46/qiskit.providers.Options.md new file mode 100644 index 00000000000..a2e57a2bf0a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.Options.md @@ -0,0 +1,125 @@ +--- +title: Options +description: API reference for qiskit.providers.Options +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.Options +--- + +# Options + + + +`qiskit.providers.Options(**kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/options.py "view source code") + +Bases: [`Mapping`](https://docs.python.org/3/library/collections.abc.html#collections.abc.Mapping "(in Python v3.12)") + +Base options object + +This class is what all backend options are based on. The properties of the class are intended to be all dynamically adjustable so that a user can reconfigure the backend on demand. If a property is immutable to the user (eg something like number of qubits) that should be a configuration of the backend class itself instead of the options. + +Instances of this class behave like dictionaries. Accessing an option with a default value can be done with the get() method: + +```python +>>> options = Options(opt1=1, opt2=2) +>>> options.get("opt1") +1 +>>> options.get("opt3", default="hello") +'hello' +``` + +Key-value pairs for all options can be retrieved using the items() method: + +```python +>>> list(options.items()) +[('opt1', 1), ('opt2', 2)] +``` + +Options can be updated by name: + +```python +>>> options["opt1"] = 3 +>>> options.get("opt1") +3 +``` + +Runtime validators can be registered. See set\_validator. Updates through update\_options and indexing (\_\_setitem\_\_) validate the new value before performing the update and raise ValueError if the new value is invalid. + +```python +>>> options.set_validator("opt1", (1, 5)) +>>> options["opt1"] = 4 +>>> options["opt1"] +4 +>>> options["opt1"] = 10 +Traceback (most recent call last): +... +ValueError: ... +``` + +## Attributes + + + +### validator + +## Methods + +### get + + + +`get(k[, d]) → D[k] if k in D, else d.  d defaults to None.` + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### set\_validator + + + +`set_validator(field, validator_value)` + +Set an optional validator for a field in the options + +Setting a validator enables changes to an options values to be validated for correctness when [`update_options()`](#qiskit.providers.Options.update_options "qiskit.providers.Options.update_options") is called. For example if you have a numeric field like `shots` you can specify a bounds tuple that set an upper and lower bound on the value such as: + +```python +options.set_validator("shots", (1, 4096)) +``` + +In this case whenever the `"shots"` option is updated by the user it will enforce that the value is >=1 and \<=4096. A `ValueError` will be raised if it’s outside those bounds. If a validator is already present for the specified field it will be silently overridden. + +**Parameters** + +* **field** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The field name to set the validator on +* **validator\_value** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)")) – The value to use for the validator depending on the type indicates on how the value for a field is enforced. If a tuple is passed in it must have a length of two and will enforce the min and max value (inclusive) for an integer or float value option. If it’s a list it will list the valid values for a field. If it’s a `type` the validator will just enforce the value is of a certain type. + +**Raises** + +* [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – If field is not present in the options object +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the `validator_value` has an invalid value for a given type +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `validator_value` is not a valid type + +### update\_options + + + +`update_options(**fields)` + +Update options with kwargs + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.providers.Provider.md b/docs/api/qiskit/0.46/qiskit.providers.Provider.md new file mode 100644 index 00000000000..5fd5f851fa3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.Provider.md @@ -0,0 +1,28 @@ +--- +title: Provider +description: API reference for qiskit.providers.Provider +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.Provider +--- + +# Provider + + + +`qiskit.providers.Provider`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/provider.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Base common type for all versioned Provider abstract classes. + +Note this class should not be inherited from directly, it is intended to be used for type checking. When implementing a provider you should use the versioned abstract classes as the parent class and not this class directly. + +## Attributes + + + +### version + +`= 0` + diff --git a/docs/api/qiskit/0.46/qiskit.providers.ProviderV1.md b/docs/api/qiskit/0.46/qiskit.providers.ProviderV1.md new file mode 100644 index 00000000000..fe8f1f180f4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.ProviderV1.md @@ -0,0 +1,76 @@ +--- +title: ProviderV1 +description: API reference for qiskit.providers.ProviderV1 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.ProviderV1 +--- + +# ProviderV1 + + + +`qiskit.providers.ProviderV1`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/provider.py "view source code") + +Bases: [`Provider`](qiskit.providers.Provider "qiskit.providers.provider.Provider"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base class for a Backend Provider. + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backends + + + +`abstract backends(name=None, **kwargs)` + +Return a list of backends matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +**a list of Backends that match the filtering** + +criteria. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[Backend](qiskit.providers.Backend "qiskit.providers.Backend")] + +### get\_backend + + + +`get_backend(name=None, **kwargs)` + +Return a single backend matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +a backend matching the filtering. + +**Return type** + +[Backend](qiskit.providers.Backend "qiskit.providers.Backend") + +**Raises** + +[**QiskitBackendNotFoundError**](providers#qiskit.providers.QiskitBackendNotFoundError "qiskit.providers.QiskitBackendNotFoundError") – if no backend could be found or more than one backend matches the filtering criteria. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.QubitProperties.md b/docs/api/qiskit/0.46/qiskit.providers.QubitProperties.md new file mode 100644 index 00000000000..18e1359e16f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.QubitProperties.md @@ -0,0 +1,42 @@ +--- +title: QubitProperties +description: API reference for qiskit.providers.QubitProperties +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.QubitProperties +--- + +# QubitProperties + + + +`qiskit.providers.QubitProperties(t1=None, t2=None, frequency=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/backend.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A representation of the properties of a qubit on a backend. + +This class provides the optional properties that a backend can provide for a qubit. These represent the set of qubit properties that Qiskit can currently work with if present. However if your backend provides additional properties of qubits you should subclass this to add additional custom attributes for those custom/additional properties provided by the backend. + +Create a new [`QubitProperties`](#qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object. + +**Parameters** + +* **t1** – The T1 time for a qubit in seconds +* **t2** – The T2 time for a qubit in seconds +* **frequency** – The frequency of a qubit in Hz + +## Attributes + + + +### t1 + + + +### t2 + + + +### frequency + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProvider.md b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProvider.md new file mode 100644 index 00000000000..ca72ea48800 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProvider.md @@ -0,0 +1,76 @@ +--- +title: BasicProvider +description: API reference for qiskit.providers.basic_provider.BasicProvider +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basic_provider.BasicProvider +--- + +# BasicProvider + + + +`qiskit.providers.basic_provider.BasicProvider`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basic_provider/basic_provider.py "view source code") + +Bases: [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.provider.ProviderV1") + +Provider for test simulators. + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backends + + + +`backends(name=None, filters=None, **kwargs)` + +Return a list of backends matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +**a list of Backends that match the filtering** + +criteria. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[Backend](qiskit.providers.Backend "qiskit.providers.Backend")] + +### get\_backend + + + +`get_backend(name=None, **kwargs)` + +Return a single backend matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +a backend matching the filtering. + +**Return type** + +[Backend](qiskit.providers.Backend "qiskit.providers.Backend") + +**Raises** + +[**QiskitBackendNotFoundError**](providers#qiskit.providers.QiskitBackendNotFoundError "qiskit.providers.QiskitBackendNotFoundError") – if no backend could be found or more than one backend matches the filtering criteria. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderError.md b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderError.md new file mode 100644 index 00000000000..46cc6dc012c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderError.md @@ -0,0 +1,20 @@ +--- +title: BasicProviderError +description: API reference for qiskit.providers.basic_provider.BasicProviderError +in_page_toc_min_heading_level: 1 +python_api_type: exception +python_api_name: qiskit.providers.basic_provider.BasicProviderError +--- + + + +# qiskit.providers.basic\_provider.BasicProviderError + + + +`qiskit.providers.basic_provider.BasicProviderError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basic_provider/exceptions.py "view source code") + +Base class for errors raised by the Basic Provider. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderJob.md b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderJob.md new file mode 100644 index 00000000000..1a4b9701207 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicProviderJob.md @@ -0,0 +1,184 @@ +--- +title: BasicProviderJob +description: API reference for qiskit.providers.basic_provider.BasicProviderJob +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basic_provider.BasicProviderJob +--- + +# BasicProviderJob + + + +`qiskit.providers.basic_provider.BasicProviderJob(backend, job_id, result)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basic_provider/basic_provider_job.py "view source code") + +Bases: [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.job.JobV1") + +BasicProviderJob class. + +Initializes the asynchronous job. + +**Parameters** + +* **backend** – the backend used to run the job. +* **job\_id** – a unique id in the context of the backend used to run the job. +* **kwargs** – Any key value metadata to associate with this job. + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backend + + + +`backend()` + +Return the instance of the backend used for this job. + +### cancel + + + +`cancel()` + +Attempt to cancel the job. + +### cancelled + + + +`cancelled()` + +Return whether the job has been cancelled. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### done + + + +`done()` + +Return whether the job has successfully run. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### in\_final\_state + + + +`in_final_state()` + +Return whether the job is in a final job state such as `DONE` or `ERROR`. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### job\_id + + + +`job_id()` + +Return a unique id identifying the job. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### result + + + +`result(timeout=None)` + +Get job result . + +**Returns** + +Result object + +**Return type** + +[qiskit.result.Result](qiskit.result.Result "qiskit.result.Result") + +### running + + + +`running()` + +Return whether the job is actively running. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### status + + + +`status()` + +Gets the status of the job by querying the Python’s future + +**Returns** + +The current JobStatus + +**Return type** + +[qiskit.providers.JobStatus](qiskit.providers.JobStatus "qiskit.providers.JobStatus") + +### submit + + + +`submit()` + +Submit the job to the backend for execution. + +**Raises** + +[**JobError**](providers#qiskit.providers.JobError "qiskit.providers.JobError") – if trying to re-submit the job. + +### wait\_for\_final\_state + + + +`wait_for_final_state(timeout=None, wait=5, callback=None)` + +Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. + +**Parameters** + +* **timeout** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Seconds to wait for the job. If `None`, wait indefinitely. + +* **wait** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Seconds between queries. + +* **callback** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – + + Callback function invoked after each query. The following positional arguments are provided to the callback function: + + * job\_id: Job ID + * job\_status: Status of the job from the last query + * job: This BaseJob instance + + Note: different subclass might provide different arguments to the callback function. + +**Raises** + +[**JobTimeoutError**](providers#qiskit.providers.JobTimeoutError "qiskit.providers.JobTimeoutError") – If the job does not reach a final state before the specified timeout. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicSimulator.md b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicSimulator.md new file mode 100644 index 00000000000..14de5eb5476 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basic_provider.BasicSimulator.md @@ -0,0 +1,413 @@ +--- +title: BasicSimulator +description: API reference for qiskit.providers.basic_provider.BasicSimulator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basic_provider.BasicSimulator +--- + +# BasicSimulator + + + +`qiskit.providers.basic_provider.BasicSimulator(provider=None, target=None, **fields)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basic_provider/basic_simulator.py "view source code") + +Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") + +Python implementation of a basic (non-efficient) quantum simulator. + +**Parameters** + +* **provider** ([*Provider*](qiskit.providers.Provider "qiskit.providers.Provider") *| None*) – An optional backwards reference to the [`Provider`](qiskit.providers.Provider "qiskit.providers.Provider") object that the backend is from. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target") *| None*) – An optional target to configure the simulator. +* **fields** – kwargs for the values to use to override the default options. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If a field is specified that’s outside the backend’s options. + +## Attributes + + + +### MAX\_QUBITS\_MEMORY + +`= 24` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the output signal timestep + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.basic_provider.BasicSimulator.run "qiskit.providers.basic_provider.BasicSimulator.run") method. + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### configuration + + + +`configuration()` + +Return the simulator backend configuration. + +**Returns** + +The configuration for the backend. + +**Return type** + +[*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.backendconfiguration.BackendConfiguration") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **backend_options)` + +Run on the backend. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – payload of the experiment +* **backend\_options** – backend options + +**Returns** + +derived from BaseJob + +**Return type** + +[BasicProviderJob](qiskit.providers.basic_provider.BasicProviderJob "qiskit.providers.basic_provider.BasicProviderJob") + +**Additional Information:** + +**backend\_options: Is a dict of options for the backend. It may contain** + +* “initial\_statevector”: vector\_like + +The “initial\_statevector” option specifies a custom initial initial statevector for the simulator to be used instead of the all zero state. This size of this vector must be correct for the number of qubits in `run_input` parameter. + +Example: + +```python +backend_options = { + "initial_statevector": np.array([1, 0, 0, 1j]) / np.sqrt(2), +} +``` + +### run\_experiment + + + +`run_experiment(experiment)` + +Run an experiment (circuit) and return a single experiment result. + +**Parameters** + +**experiment** ([*QasmQobjExperiment*](qiskit.qobj.QasmQobjExperiment "qiskit.qobj.qasm_qobj.QasmQobjExperiment")) – experiment from qobj experiments list + +**Returns** + +A result dictionary which looks something like: + +```python +{ +"name": name of this experiment (obtained from qobj.experiment header) +"seed": random seed used for simulation +"shots": number of shots used in the simulation +"data": + { + "counts": {'0x9: 5, ...}, + "memory": ['0x9', '0xF', '0x1D', ..., '0x9'] + }, +"status": status string for the simulation +"success": boolean +"time_taken": simulation time of this single experiment +} +``` + +**Raises** + +[**BasicProviderError**](qiskit.providers.basic_provider.BasicProviderError "qiskit.providers.basic_provider.BasicProviderError") – if an error occurred. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), …] + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerError.md b/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerError.md new file mode 100644 index 00000000000..0e74ac66148 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerError.md @@ -0,0 +1,24 @@ +--- +title: BasicAerError +description: API reference for qiskit.providers.basicaer.BasicAerError +in_page_toc_min_heading_level: 1 +python_api_type: exception +python_api_name: qiskit.providers.basicaer.BasicAerError +--- + + + +# qiskit.providers.basicaer.BasicAerError + + + +`qiskit.providers.basicaer.BasicAerError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basicaer/exceptions.py "view source code") + +Base class for errors raised by Basic Aer. + +Set the error message. + + + The class `qiskit.providers.basicaer.exceptions.BasicAerError` is deprecated as of qiskit 0.46.0. It will be removed in Qiskit 1.0.0. The qiskit.providers.basicaer module has been superseded by qiskit.providers.basic\_provider. Use the new qiskit.providers.basic\_provider.BasicProviderError class instead. + + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerJob.md b/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerJob.md new file mode 100644 index 00000000000..f8372e79924 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerJob.md @@ -0,0 +1,180 @@ +--- +title: BasicAerJob +description: API reference for qiskit.providers.basicaer.BasicAerJob +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basicaer.BasicAerJob +--- + +# BasicAerJob + + + +`qiskit.providers.basicaer.BasicAerJob(backend, job_id, result)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basicaer/basicaerjob.py "view source code") + +Bases: [`JobV1`](qiskit.providers.JobV1 "qiskit.providers.job.JobV1") + +BasicAerJob class. + + + The class `qiskit.providers.basicaer.basicaerjob.BasicAerJob` is deprecated as of qiskit 0.46.0. It will be removed in Qiskit 1.0.0. The qiskit.providers.basicaer module has been superseded by qiskit.providers.basic\_provider, and all its classes have been renamed to follow a new naming convention. Use the new qiskit.providers.basic\_provider.BasicProviderJob class instead. + + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backend + + + +`backend()` + +Return the instance of the backend used for this job. + +### cancel + + + +`cancel()` + +Attempt to cancel the job. + +### cancelled + + + +`cancelled()` + +Return whether the job has been cancelled. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### done + + + +`done()` + +Return whether the job has successfully run. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### in\_final\_state + + + +`in_final_state()` + +Return whether the job is in a final job state such as `DONE` or `ERROR`. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### job\_id + + + +`job_id()` + +Return a unique id identifying the job. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### result + + + +`result(timeout=None)` + +Get job result . + +**Returns** + +Result object + +**Return type** + +[qiskit.result.Result](qiskit.result.Result "qiskit.result.Result") + +### running + + + +`running()` + +Return whether the job is actively running. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### status + + + +`status()` + +Gets the status of the job by querying the Python’s future + +**Returns** + +The current JobStatus + +**Return type** + +[qiskit.providers.JobStatus](qiskit.providers.JobStatus "qiskit.providers.JobStatus") + +### submit + + + +`submit()` + +Submit the job to the backend for execution. + +**Raises** + +[**JobError**](providers#qiskit.providers.JobError "qiskit.providers.JobError") – if trying to re-submit the job. + +### wait\_for\_final\_state + + + +`wait_for_final_state(timeout=None, wait=5, callback=None)` + +Poll the job status until it progresses to a final state such as `DONE` or `ERROR`. + +**Parameters** + +* **timeout** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Seconds to wait for the job. If `None`, wait indefinitely. + +* **wait** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Seconds between queries. + +* **callback** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – + + Callback function invoked after each query. The following positional arguments are provided to the callback function: + + * job\_id: Job ID + * job\_status: Status of the job from the last query + * job: This BaseJob instance + + Note: different subclass might provide different arguments to the callback function. + +**Raises** + +[**JobTimeoutError**](providers#qiskit.providers.JobTimeoutError "qiskit.providers.JobTimeoutError") – If the job does not reach a final state before the specified timeout. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerProvider.md b/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerProvider.md new file mode 100644 index 00000000000..1bdd93c0dd3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basicaer.BasicAerProvider.md @@ -0,0 +1,80 @@ +--- +title: BasicAerProvider +description: API reference for qiskit.providers.basicaer.BasicAerProvider +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basicaer.BasicAerProvider +--- + +# BasicAerProvider + + + +`qiskit.providers.basicaer.BasicAerProvider`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basicaer/basicaerprovider.py "view source code") + +Bases: [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.provider.ProviderV1") + +Provider for Basic Aer backends. + + + The class `qiskit.providers.basicaer.basicaerprovider.BasicAerProvider` is deprecated as of qiskit 0.46.0. It will be removed in Qiskit 1.0.0. The qiskit.providers.basicaer module has been superseded by qiskit.providers.basic\_provider, and all its classes have been renamed to follow a new naming convention. Use the new qiskit.providers.basic\_provider.BasicProvider class instead. + + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backends + + + +`backends(name=None, filters=None, **kwargs)` + +Return a list of backends matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +**a list of Backends that match the filtering** + +criteria. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[Backend](qiskit.providers.Backend "qiskit.providers.Backend")] + +### get\_backend + + + +`get_backend(name=None, **kwargs)` + +Return a single backend matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +a backend matching the filtering. + +**Return type** + +[Backend](qiskit.providers.Backend "qiskit.providers.Backend") + +**Raises** + +[**QiskitBackendNotFoundError**](providers#qiskit.providers.QiskitBackendNotFoundError "qiskit.providers.QiskitBackendNotFoundError") – if no backend could be found or more than one backend matches the filtering criteria. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basicaer.QasmSimulatorPy.md b/docs/api/qiskit/0.46/qiskit.providers.basicaer.QasmSimulatorPy.md new file mode 100644 index 00000000000..6cf79e8f056 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basicaer.QasmSimulatorPy.md @@ -0,0 +1,243 @@ +--- +title: QasmSimulatorPy +description: API reference for qiskit.providers.basicaer.QasmSimulatorPy +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basicaer.QasmSimulatorPy +--- + +# QasmSimulatorPy + + + +`qiskit.providers.basicaer.QasmSimulatorPy(configuration=None, provider=None, **fields)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basicaer/qasm_simulator.py "view source code") + +Bases: [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.backend.BackendV1") + +Python implementation of an OpenQASM 2 simulator. + + + The class `qiskit.providers.basicaer.qasm_simulator.QasmSimulatorPy` is deprecated as of qiskit 0.46.0. It will be removed in Qiskit 1.0.0. The qiskit.providers.basicaer module has been superseded by qiskit.providers.basic\_provider. Use the new qiskit.providers.basic\_provider.BasicSimulator class instead. + + +## Attributes + + + +### DEFAULT\_CONFIGURATION = \{'backend\_name' + +`= {'backend_name':` + +`= {'backend_name': 'qasm_simulator', 'backend_version': '2.1.0', 'basis_gates': ['h', 'u', 'p', 'u1', 'u2', 'u3', 'rz', 'sx', 'x', 'cx', 'id', 'unitary'], 'conditional': True, 'coupling_map': None, 'description': 'A python simulator for qasm experiments', 'gates': [{'name': 'h', 'parameters': [], 'qasm_def': 'gate h q { U(pi/2,0,pi) q; }'}, {'name': 'p', 'parameters': ['lambda'], 'qasm_def': 'gate p(lambda) q { U(0,0,lambda) q; }'}, {'name': 'u', 'parameters': ['theta', 'phi', 'lambda'], 'qasm_def': 'gate u(theta,phi,lambda) q { U(theta,phi,lambda) q; }'}, {'name': 'u1', 'parameters': ['lambda'], 'qasm_def': 'gate u1(lambda) q { U(0,0,lambda) q; }'}, {'name': 'u2', 'parameters': ['phi', 'lambda'], 'qasm_def': 'gate u2(phi,lambda) q { U(pi/2,phi,lambda) q; }'}, {'name': 'u3', 'parameters': ['theta', 'phi', 'lambda'], 'qasm_def': 'gate u3(theta,phi,lambda) q { U(theta,phi,lambda) q; }'}, {'name': 'rz', 'parameters': ['phi'], 'qasm_def': 'gate rz(phi) q { U(0,0,phi) q; }'}, {'name': 'sx', 'parameters': [], 'qasm_def': 'gate sx(phi) q { U(pi/2,7*pi/2,pi/2) q; }'}, {'name': 'x', 'parameters': [], 'qasm_def': 'gate x q { U(pi,7*pi/2,pi/2) q; }'}, {'name': 'cx', 'parameters': [], 'qasm_def': 'gate cx c,t { CX c,t; }'}, {'name': 'id', 'parameters': [], 'qasm_def': 'gate id a { U(0,0,0) a; }'}, {'name': 'unitary', 'parameters': ['matrix'], 'qasm_def': 'unitary(matrix) q1, q2,...'}], 'local': True, 'max_shots': 0, 'memory': True, 'n_qubits': 24, 'open_pulse': False, 'simulator': True, 'url': 'https://github.com/Qiskit/qiskit-terra'}` + + + +### DEFAULT\_OPTIONS = \{'chop\_threshold' + +`= {'chop_threshold':` + +`= {'chop_threshold': 1e-15, 'initial_statevector': None}` + + + +### MAX\_QUBITS\_MEMORY + +`= 29` + + + +### SHOW\_FINAL\_STATE + +`= False` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.basicaer.QasmSimulatorPy.run "qiskit.providers.basicaer.QasmSimulatorPy.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return the backend properties. + +**Returns** + +the configuration for the backend. If the backend does not support properties, it returns `None`. + +**Return type** + +[BackendProperties](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **backend_options)` + +Run on the backend. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – payload of the experiment +* **backend\_options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – backend options + +**Returns** + +derived from BaseJob + +**Return type** + +[BasicAerJob](qiskit.providers.basicaer.BasicAerJob "qiskit.providers.basicaer.BasicAerJob") + +**Additional Information:** + +**backend\_options: Is a dict of options for the backend. It may contain** + +* “initial\_statevector”: vector\_like + +The “initial\_statevector” option specifies a custom initial initial statevector for the simulator to be used instead of the all zero state. This size of this vector must be correct for the number of qubits in `run_input` parameter. + +Example: + +```python +backend_options = { + "initial_statevector": np.array([1, 0, 0, 1j]) / np.sqrt(2), +} +``` + +### run\_experiment + + + +`run_experiment(experiment)` + +Run an experiment (circuit) and return a single experiment result. + +**Parameters** + +**experiment** ([*QasmQobjExperiment*](qiskit.qobj.QasmQobjExperiment "qiskit.qobj.QasmQobjExperiment")) – experiment from qobj experiments list + +**Returns** + +A result dictionary which looks something like: + +```python +{ +"name": name of this experiment (obtained from qobj.experiment header) +"seed": random seed used for simulation +"shots": number of shots used in the simulation +"data": + { + "counts": {'0x9: 5, ...}, + "memory": ['0x9', '0xF', '0x1D', ..., '0x9'] + }, +"status": status string for the simulation +"success": boolean +"time_taken": simulation time of this single experiment +} +``` + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**BasicAerError**](qiskit.providers.basicaer.BasicAerError "qiskit.providers.basicaer.BasicAerError") – if an error occurred. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basicaer.StatevectorSimulatorPy.md b/docs/api/qiskit/0.46/qiskit.providers.basicaer.StatevectorSimulatorPy.md new file mode 100644 index 00000000000..d1c39d8fbbf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basicaer.StatevectorSimulatorPy.md @@ -0,0 +1,243 @@ +--- +title: StatevectorSimulatorPy +description: API reference for qiskit.providers.basicaer.StatevectorSimulatorPy +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basicaer.StatevectorSimulatorPy +--- + +# StatevectorSimulatorPy + + + +`qiskit.providers.basicaer.StatevectorSimulatorPy(configuration=None, provider=None, **fields)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basicaer/statevector_simulator.py "view source code") + +Bases: [`QasmSimulatorPy`](qiskit.providers.basicaer.QasmSimulatorPy "qiskit.providers.basicaer.qasm_simulator.QasmSimulatorPy") + +Python statevector simulator. + + + The class `qiskit.providers.basicaer.statevector_simulator.StatevectorSimulatorPy` is deprecated as of qiskit 0.46.0. It will be removed in Qiskit 1.0.0. The qiskit.providers.basicaer module has been superseded by qiskit.providers.basic\_provider. The new module has no replacement for this class. Use the qiskit.quantum\_info.Statevector class instead. + + +## Attributes + + + +### DEFAULT\_CONFIGURATION = \{'backend\_name' + +`= {'backend_name':` + +`= {'backend_name': 'statevector_simulator', 'backend_version': '1.1.0', 'basis_gates': ['u1', 'u2', 'u3', 'rz', 'sx', 'x', 'cx', 'id', 'unitary'], 'conditional': True, 'coupling_map': None, 'description': 'A Python statevector simulator for qobj files', 'gates': [{'name': 'u1', 'parameters': ['lambda'], 'qasm_def': 'gate u1(lambda) q { U(0,0,lambda) q; }'}, {'name': 'u2', 'parameters': ['phi', 'lambda'], 'qasm_def': 'gate u2(phi,lambda) q { U(pi/2,phi,lambda) q; }'}, {'name': 'u3', 'parameters': ['theta', 'phi', 'lambda'], 'qasm_def': 'gate u3(theta,phi,lambda) q { U(theta,phi,lambda) q; }'}, {'name': 'rz', 'parameters': ['phi'], 'qasm_def': 'gate rz(phi) q { U(0,0,phi) q; }'}, {'name': 'sx', 'parameters': [], 'qasm_def': 'gate sx(phi) q { U(pi/2,7*pi/2,pi/2) q; }'}, {'name': 'x', 'parameters': [], 'qasm_def': 'gate x q { U(pi,7*pi/2,pi/2) q; }'}, {'name': 'cx', 'parameters': [], 'qasm_def': 'gate cx c,t { CX c,t; }'}, {'name': 'id', 'parameters': [], 'qasm_def': 'gate id a { U(0,0,0) a; }'}, {'name': 'unitary', 'parameters': ['matrix'], 'qasm_def': 'unitary(matrix) q1, q2,...'}], 'local': True, 'max_shots': 0, 'memory': True, 'n_qubits': 24, 'open_pulse': False, 'simulator': True, 'url': 'https://github.com/Qiskit/qiskit-terra'}` + + + +### DEFAULT\_OPTIONS = \{'chop\_threshold' + +`= {'chop_threshold':` + +`= {'chop_threshold': 1e-15, 'initial_statevector': None}` + + + +### MAX\_QUBITS\_MEMORY + +`= 29` + + + +### SHOW\_FINAL\_STATE + +`= True` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.basicaer.StatevectorSimulatorPy.run "qiskit.providers.basicaer.StatevectorSimulatorPy.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return the backend properties. + +**Returns** + +the configuration for the backend. If the backend does not support properties, it returns `None`. + +**Return type** + +[BackendProperties](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **backend_options)` + +Run on the backend. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – payload of the experiment +* **backend\_options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – backend options + +**Returns** + +derived from BaseJob + +**Return type** + +[BasicAerJob](qiskit.providers.basicaer.BasicAerJob "qiskit.providers.basicaer.BasicAerJob") + +**Additional Information:** + +**backend\_options: Is a dict of options for the backend. It may contain** + +* “initial\_statevector”: vector\_like + +The “initial\_statevector” option specifies a custom initial initial statevector for the simulator to be used instead of the all zero state. This size of this vector must be correct for the number of qubits in `run_input` parameter. + +Example: + +```python +backend_options = { + "initial_statevector": np.array([1, 0, 0, 1j]) / np.sqrt(2), +} +``` + +### run\_experiment + + + +`run_experiment(experiment)` + +Run an experiment (circuit) and return a single experiment result. + +**Parameters** + +**experiment** ([*QasmQobjExperiment*](qiskit.qobj.QasmQobjExperiment "qiskit.qobj.QasmQobjExperiment")) – experiment from qobj experiments list + +**Returns** + +A result dictionary which looks something like: + +```python +{ +"name": name of this experiment (obtained from qobj.experiment header) +"seed": random seed used for simulation +"shots": number of shots used in the simulation +"data": + { + "counts": {'0x9: 5, ...}, + "memory": ['0x9', '0xF', '0x1D', ..., '0x9'] + }, +"status": status string for the simulation +"success": boolean +"time_taken": simulation time of this single experiment +} +``` + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**BasicAerError**](qiskit.providers.basicaer.BasicAerError "qiskit.providers.basicaer.BasicAerError") – if an error occurred. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.basicaer.UnitarySimulatorPy.md b/docs/api/qiskit/0.46/qiskit.providers.basicaer.UnitarySimulatorPy.md new file mode 100644 index 00000000000..6b81a8dfa67 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.basicaer.UnitarySimulatorPy.md @@ -0,0 +1,252 @@ +--- +title: UnitarySimulatorPy +description: API reference for qiskit.providers.basicaer.UnitarySimulatorPy +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.basicaer.UnitarySimulatorPy +--- + +# UnitarySimulatorPy + + + +`qiskit.providers.basicaer.UnitarySimulatorPy(configuration=None, provider=None, **fields)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/basicaer/unitary_simulator.py "view source code") + +Bases: [`BackendV1`](qiskit.providers.BackendV1 "qiskit.providers.backend.BackendV1") + +Python implementation of a unitary simulator. + + + The class `qiskit.providers.basicaer.unitary_simulator.UnitarySimulatorPy` is deprecated as of qiskit 0.46.0. It will be removed in Qiskit 1.0.0. The qiskit.providers.basicaer module has been superseded by qiskit.providers.basic\_provider. The new module has no replacement for this class. Use the qiskit.quantum\_info.Operator class instead. + + +## Attributes + + + +### DEFAULT\_CONFIGURATION = \{'backend\_name' + +`= {'backend_name':` + +`= {'backend_name': 'unitary_simulator', 'backend_version': '1.1.0', 'basis_gates': ['u1', 'u2', 'u3', 'rz', 'sx', 'x', 'cx', 'id', 'unitary'], 'conditional': False, 'coupling_map': None, 'description': 'A python simulator for unitary matrix corresponding to a circuit', 'gates': [{'name': 'u1', 'parameters': ['lambda'], 'qasm_def': 'gate u1(lambda) q { U(0,0,lambda) q; }'}, {'name': 'u2', 'parameters': ['phi', 'lambda'], 'qasm_def': 'gate u2(phi,lambda) q { U(pi/2,phi,lambda) q; }'}, {'name': 'u3', 'parameters': ['theta', 'phi', 'lambda'], 'qasm_def': 'gate u3(theta,phi,lambda) q { U(theta,phi,lambda) q; }'}, {'name': 'rz', 'parameters': ['phi'], 'qasm_def': 'gate rz(phi) q { U(0,0,phi) q; }'}, {'name': 'sx', 'parameters': [], 'qasm_def': 'gate sx(phi) q { U(pi/2,7*pi/2,pi/2) q; }'}, {'name': 'x', 'parameters': [], 'qasm_def': 'gate x q { U(pi,7*pi/2,pi/2) q; }'}, {'name': 'cx', 'parameters': [], 'qasm_def': 'gate cx c,t { CX c,t; }'}, {'name': 'id', 'parameters': [], 'qasm_def': 'gate id a { U(0,0,0) a; }'}, {'name': 'unitary', 'parameters': ['matrix'], 'qasm_def': 'unitary(matrix) q1, q2,...'}], 'local': True, 'max_shots': 0, 'memory': False, 'n_qubits': 14, 'open_pulse': False, 'simulator': True, 'url': 'https://github.com/Qiskit/qiskit-terra'}` + + + +### DEFAULT\_OPTIONS = \{'chop\_threshold' + +`= {'chop_threshold':` + +`= {'chop_threshold': 1e-15, 'initial_unitary': None}` + + + +### MAX\_QUBITS\_MEMORY + +`= 14` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.basicaer.UnitarySimulatorPy.run "qiskit.providers.basicaer.UnitarySimulatorPy.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return the backend properties. + +**Returns** + +the configuration for the backend. If the backend does not support properties, it returns `None`. + +**Return type** + +[BackendProperties](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **backend_options)` + +Run experiments in run\_input asynchronously. + + + Using a QasmQobj for the first argument to UnitarySimulatorPy.run() is deprecated as of qiskit 0.46.0. It will be removed no earlier than 3 months after the release date. + + +**Parameters** + +* **run\_input** (*Qobj,* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*,* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – payload of the experiment +* **backend\_options** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – backend options + +**Returns** + +derived from BaseJob + +**Return type** + +[BasicAerJob](qiskit.providers.basicaer.BasicAerJob "qiskit.providers.basicaer.BasicAerJob") + +Additional Information: + +```python +backend_options: Is a dict of options for the backend. It may contain + * "initial_unitary": matrix_like + * "chop_threshold": double + +The "initial_unitary" option specifies a custom initial unitary +matrix for the simulator to be used instead of the identity +matrix. This size of this matrix must be correct for the number +of qubits in all experiments in the run_input. + +The "chop_threshold" option specifies a truncation value for +setting small values to zero in the output unitary. The default +value is 1e-15. + +Example:: + + backend_options = { + "initial_unitary": np.array([[1, 0, 0, 0], + [0, 0, 0, 1], + [0, 0, 1, 0], + [0, 1, 0, 0]]) + "chop_threshold": 1e-15 + } +``` + +### run\_experiment + + + +`run_experiment(experiment)` + +Run an experiment (circuit) and return a single experiment result. + +**Parameters** + +**experiment** ([*QasmQobjExperiment*](qiskit.qobj.QasmQobjExperiment "qiskit.qobj.QasmQobjExperiment")) – experiment from qobj experiments list + +**Returns** + +A result dictionary which looks something like: + +```python +{ +"name": name of this experiment (obtained from qobj.experiment header) +"seed": random seed used for simulation +"shots": number of shots used in the simulation +"data": + { + "unitary": [[[0.0, 0.0], [1.0, 0.0]], + [[1.0, 0.0], [0.0, 0.0]]] + }, +"status": status string for the simulation +"success": boolean +"time taken": simulation time of this single experiment +} +``` + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**BasicAerError**](qiskit.providers.basicaer.BasicAerError "qiskit.providers.basicaer.BasicAerError") – if the number of qubits in the circuit is greater than 24. Note that the practical qubit limit is much lower than 24. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.convert_to_target.md b/docs/api/qiskit/0.46/qiskit.providers.convert_to_target.md new file mode 100644 index 00000000000..4aa5d43ca88 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.convert_to_target.md @@ -0,0 +1,26 @@ +--- +title: convert_to_target +description: API reference for qiskit.providers.convert_to_target +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.providers.convert_to_target +--- + + + +# qiskit.providers.convert\_to\_target + + + +`qiskit.providers.convert_to_target(configuration, properties=None, defaults=None, custom_name_mapping=None, add_delay=False, filter_faulty=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/backend_compat.py "view source code") + +Uses configuration, properties and pulse defaults to construct and return Target class. + +In order to convert with a `defaults.instruction_schedule_map`, which has a custom calibration for an operation, the operation name must be in `configuration.basis_gates` and `custom_name_mapping` must be supplied for the operation. Otherwise, the operation will be dropped in the resulting `Target` object. + +That suggests it is recommended to add custom calibrations **after** creating a target with this function instead of adding them to `defaults` in advance. For example: + +```python +target.add_instruction(custom_gate, {(0, 1): InstructionProperties(calibration=custom_sched)}) +``` + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.ConfigurableFakeBackend.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.ConfigurableFakeBackend.md new file mode 100644 index 00000000000..2b03224f790 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.ConfigurableFakeBackend.md @@ -0,0 +1,164 @@ +--- +title: ConfigurableFakeBackend +description: API reference for qiskit.providers.fake_provider.ConfigurableFakeBackend +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.ConfigurableFakeBackend +--- + +# ConfigurableFakeBackend + + + +`qiskit.providers.fake_provider.ConfigurableFakeBackend(name, n_qubits, version=None, coupling_map=None, basis_gates=None, qubit_t1=None, qubit_t2=None, qubit_frequency=None, qubit_readout_error=None, single_qubit_gates=None, dt=None, std=None, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/utils/configurable_backend.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +Configurable backend. + +Creates backend based on provided configuration. + + + The class `qiskit.providers.fake_provider.utils.configurable_backend.ConfigurableFakeBackend` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. Use a suitable FakeBackend instead. + + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of the backend. +* **n\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of qubits in the backend. +* **version** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Version of the fake backend. +* **coupling\_map** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – Coupling map. +* **basis\_gates** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – Basis gates of the backend. +* **qubit\_t1** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Longitudinal coherence times. +* **qubit\_t2** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Transverse coherence times. +* **qubit\_frequency** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Frequency of qubits. +* **qubit\_readout\_error** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Readout error of qubits. +* **single\_qubit\_gates** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – List of single qubit gates for backend properties. +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Discretization of the input time sequences. +* **std** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Standard deviation of the generated distributions. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Random seed. + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.ConfigurableFakeBackend.run "qiskit.providers.fake_provider.ConfigurableFakeBackend.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Return backend defaults. + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return backend properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.Fake1Q.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.Fake1Q.md new file mode 100644 index 00000000000..9ef881f6829 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.Fake1Q.md @@ -0,0 +1,136 @@ +--- +title: Fake1Q +description: API reference for qiskit.providers.fake_provider.Fake1Q +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.Fake1Q +--- + +# Fake1Q + + + +`qiskit.providers.fake_provider.Fake1Q`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_1q.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake 1Q backend. + +0 + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.Fake1Q.run "qiskit.providers.fake_provider.Fake1Q.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return backend properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmaden.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmaden.md new file mode 100644 index 00000000000..1385b9c5aab --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmaden.md @@ -0,0 +1,175 @@ +--- +title: FakeAlmaden +description: API reference for qiskit.providers.fake_provider.FakeAlmaden +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeAlmaden +--- + +# FakeAlmaden + + + +`qiskit.providers.fake_provider.FakeAlmaden`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/almaden/fake_almaden.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake Almaden backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_almaden'` + + + +### conf\_filename + +`= 'conf_almaden.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/almaden'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeAlmaden.run "qiskit.providers.fake_provider.FakeAlmaden.run") method. + + + +### props\_filename + +`= 'props_almaden.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmadenV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmadenV2.md new file mode 100644 index 00000000000..17f74a5a3f1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAlmadenV2.md @@ -0,0 +1,361 @@ +--- +title: FakeAlmadenV2 +description: API reference for qiskit.providers.fake_provider.FakeAlmadenV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeAlmadenV2 +--- + +# FakeAlmadenV2 + + + +`qiskit.providers.fake_provider.FakeAlmadenV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/almaden/fake_almaden.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Almaden V2 backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_almaden'` + + + +### conf\_filename + +`= 'conf_almaden.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/almaden'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeAlmadenV2.run "qiskit.providers.fake_provider.FakeAlmadenV2.run") method. + + + +### props\_filename + +`= 'props_almaden.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonk.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonk.md new file mode 100644 index 00000000000..70431733e45 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonk.md @@ -0,0 +1,183 @@ +--- +title: FakeArmonk +description: API reference for qiskit.providers.fake_provider.FakeArmonk +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeArmonk +--- + +# FakeArmonk + + + +`qiskit.providers.fake_provider.FakeArmonk`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/armonk/fake_armonk.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 1 qubit backend. + +```python +0 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_armonk'` + + + +### conf\_filename + +`= 'conf_armonk.json'` + + + +### defs\_filename + +`= 'defs_armonk.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/armonk'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeArmonk.run "qiskit.providers.fake_provider.FakeArmonk.run") method. + + + +### props\_filename + +`= 'props_armonk.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonkV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonkV2.md new file mode 100644 index 00000000000..1f44ae9d5d9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeArmonkV2.md @@ -0,0 +1,355 @@ +--- +title: FakeArmonkV2 +description: API reference for qiskit.providers.fake_provider.FakeArmonkV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeArmonkV2 +--- + +# FakeArmonkV2 + + + +`qiskit.providers.fake_provider.FakeArmonkV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/armonk/fake_armonk.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 1 qubit backend. + +```python +0 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_armonk'` + + + +### conf\_filename + +`= 'conf_armonk.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_armonk.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/armonk'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeArmonkV2.run "qiskit.providers.fake_provider.FakeArmonkV2.run") method. + + + +### props\_filename + +`= 'props_armonk.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthens.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthens.md new file mode 100644 index 00000000000..59d36f40174 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthens.md @@ -0,0 +1,179 @@ +--- +title: FakeAthens +description: API reference for qiskit.providers.fake_provider.FakeAthens +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeAthens +--- + +# FakeAthens + + + +`qiskit.providers.fake_provider.FakeAthens`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/athens/fake_athens.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_athens'` + + + +### conf\_filename + +`= 'conf_athens.json'` + + + +### defs\_filename + +`= 'defs_athens.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/athens'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeAthens.run "qiskit.providers.fake_provider.FakeAthens.run") method. + + + +### props\_filename + +`= 'props_athens.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthensV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthensV2.md new file mode 100644 index 00000000000..964b921ba2f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAthensV2.md @@ -0,0 +1,351 @@ +--- +title: FakeAthensV2 +description: API reference for qiskit.providers.fake_provider.FakeAthensV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeAthensV2 +--- + +# FakeAthensV2 + + + +`qiskit.providers.fake_provider.FakeAthensV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/athens/fake_athens.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_athens'` + + + +### conf\_filename + +`= 'conf_athens.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_athens.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/athens'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeAthensV2.run "qiskit.providers.fake_provider.FakeAthensV2.run") method. + + + +### props\_filename + +`= 'props_athens.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAuckland.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAuckland.md new file mode 100644 index 00000000000..1e13aa93a2b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeAuckland.md @@ -0,0 +1,351 @@ +--- +title: FakeAuckland +description: API reference for qiskit.providers.fake_provider.FakeAuckland +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeAuckland +--- + +# FakeAuckland + + + +`qiskit.providers.fake_provider.FakeAuckland`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/auckland/fake_auckland.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_auckland'` + + + +### conf\_filename + +`= 'conf_auckland.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_auckland.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/auckland'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeAuckland.run "qiskit.providers.fake_provider.FakeAuckland.run") method. + + + +### props\_filename + +`= 'props_auckland.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackend5QV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackend5QV2.md new file mode 100644 index 00000000000..93692e95f3d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackend5QV2.md @@ -0,0 +1,331 @@ +--- +title: FakeBackend5QV2 +description: API reference for qiskit.providers.fake_provider.FakeBackend5QV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBackend5QV2 +--- + +# FakeBackend5QV2 + + + +`qiskit.providers.fake_provider.FakeBackend5QV2(bidirectional=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_backend_v2.py "view source code") + +Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") + +A mock backend that doesn’t implement run() to test compatibility with Terra internals. + + + The class `qiskit.providers.fake_provider.fake_backend_v2.FakeBackend5QV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. Use the qiskit.providers.basic\_provider.GenericBackendV2 class instead. + + +## Attributes + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the output signal timestep + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBackend5QV2.run "qiskit.providers.fake_provider.FakeBackend5QV2.run") method. + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the backend. + +This method returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object that runs circuits. Depending on the backend this may be either an async or sync call. It is at the discretion of the provider to decide whether running should block until the execution is finished or not: the Job class can handle either situation. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackendV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackendV2.md new file mode 100644 index 00000000000..90dd892bc01 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBackendV2.md @@ -0,0 +1,331 @@ +--- +title: FakeBackendV2 +description: API reference for qiskit.providers.fake_provider.FakeBackendV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBackendV2 +--- + +# FakeBackendV2 + + + +`qiskit.providers.fake_provider.FakeBackendV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_backend_v2.py "view source code") + +Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") + +A mock backend that doesn’t implement run() to test compatibility with Terra internals. + + + The class `qiskit.providers.fake_provider.fake_backend_v2.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. Use the qiskit.providers.basic\_provider.GenericBackendV2 class instead. + + +## Attributes + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the output signal timestep + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBackendV2.run "qiskit.providers.fake_provider.FakeBackendV2.run") method. + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the backend. + +This method returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object that runs circuits. Depending on the backend this may be either an async or sync call. It is at the discretion of the provider to decide whether running should block until the execution is finished or not: the Job class can handle either situation. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelem.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelem.md new file mode 100644 index 00000000000..9e078dab5cd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelem.md @@ -0,0 +1,179 @@ +--- +title: FakeBelem +description: API reference for qiskit.providers.fake_provider.FakeBelem +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBelem +--- + +# FakeBelem + + + +`qiskit.providers.fake_provider.FakeBelem`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/belem/fake_belem.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_belem'` + + + +### conf\_filename + +`= 'conf_belem.json'` + + + +### defs\_filename + +`= 'defs_belem.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/belem'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBelem.run "qiskit.providers.fake_provider.FakeBelem.run") method. + + + +### props\_filename + +`= 'props_belem.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelemV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelemV2.md new file mode 100644 index 00000000000..698ed317683 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBelemV2.md @@ -0,0 +1,351 @@ +--- +title: FakeBelemV2 +description: API reference for qiskit.providers.fake_provider.FakeBelemV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBelemV2 +--- + +# FakeBelemV2 + + + +`qiskit.providers.fake_provider.FakeBelemV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/belem/fake_belem.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_belem'` + + + +### conf\_filename + +`= 'conf_belem.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_belem.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/belem'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBelemV2.run "qiskit.providers.fake_provider.FakeBelemV2.run") method. + + + +### props\_filename + +`= 'props_belem.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingen.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingen.md new file mode 100644 index 00000000000..cc48009f431 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingen.md @@ -0,0 +1,189 @@ +--- +title: FakeBoeblingen +description: API reference for qiskit.providers.fake_provider.FakeBoeblingen +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBoeblingen +--- + +# FakeBoeblingen + + + +`qiskit.providers.fake_provider.FakeBoeblingen`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/boeblingen/fake_boeblingen.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake Boeblingen backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_boeblingen'` + + + +### conf\_filename + +`= 'conf_boeblingen.json'` + + + +### defs\_filename + +`= 'defs_boeblingen.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/boeblingen'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBoeblingen.run "qiskit.providers.fake_provider.FakeBoeblingen.run") method. + + + +### props\_filename + +`= 'props_boeblingen.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingenV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingenV2.md new file mode 100644 index 00000000000..a48f4755d12 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBoeblingenV2.md @@ -0,0 +1,361 @@ +--- +title: FakeBoeblingenV2 +description: API reference for qiskit.providers.fake_provider.FakeBoeblingenV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBoeblingenV2 +--- + +# FakeBoeblingenV2 + + + +`qiskit.providers.fake_provider.FakeBoeblingenV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/boeblingen/fake_boeblingen.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Boeblingen V2 backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_boeblingen'` + + + +### conf\_filename + +`= 'conf_boeblingen.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_boeblingen.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/boeblingen'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBoeblingenV2.run "qiskit.providers.fake_provider.FakeBoeblingenV2.run") method. + + + +### props\_filename + +`= 'props_boeblingen.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogota.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogota.md new file mode 100644 index 00000000000..6ff305d3757 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogota.md @@ -0,0 +1,179 @@ +--- +title: FakeBogota +description: API reference for qiskit.providers.fake_provider.FakeBogota +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBogota +--- + +# FakeBogota + + + +`qiskit.providers.fake_provider.FakeBogota`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/bogota/fake_bogota.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_bogota'` + + + +### conf\_filename + +`= 'conf_bogota.json'` + + + +### defs\_filename + +`= 'defs_bogota.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/bogota'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBogota.run "qiskit.providers.fake_provider.FakeBogota.run") method. + + + +### props\_filename + +`= 'props_bogota.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogotaV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogotaV2.md new file mode 100644 index 00000000000..4eac6b1bd8a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBogotaV2.md @@ -0,0 +1,351 @@ +--- +title: FakeBogotaV2 +description: API reference for qiskit.providers.fake_provider.FakeBogotaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBogotaV2 +--- + +# FakeBogotaV2 + + + +`qiskit.providers.fake_provider.FakeBogotaV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/bogota/fake_bogota.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_bogota'` + + + +### conf\_filename + +`= 'conf_bogota.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_bogota.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/bogota'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBogotaV2.run "qiskit.providers.fake_provider.FakeBogotaV2.run") method. + + + +### props\_filename + +`= 'props_bogota.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklyn.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklyn.md new file mode 100644 index 00000000000..2daad89ac54 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklyn.md @@ -0,0 +1,179 @@ +--- +title: FakeBrooklyn +description: API reference for qiskit.providers.fake_provider.FakeBrooklyn +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBrooklyn +--- + +# FakeBrooklyn + + + +`qiskit.providers.fake_provider.FakeBrooklyn`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/brooklyn/fake_brooklyn.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake Brooklyn backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_brooklyn'` + + + +### conf\_filename + +`= 'conf_brooklyn.json'` + + + +### defs\_filename + +`= 'defs_brooklyn.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/brooklyn'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBrooklyn.run "qiskit.providers.fake_provider.FakeBrooklyn.run") method. + + + +### props\_filename + +`= 'props_brooklyn.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklynV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklynV2.md new file mode 100644 index 00000000000..a1361bfdc70 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBrooklynV2.md @@ -0,0 +1,351 @@ +--- +title: FakeBrooklynV2 +description: API reference for qiskit.providers.fake_provider.FakeBrooklynV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBrooklynV2 +--- + +# FakeBrooklynV2 + + + +`qiskit.providers.fake_provider.FakeBrooklynV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/brooklyn/fake_brooklyn.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Brooklyn V2 backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_brooklyn'` + + + +### conf\_filename + +`= 'conf_brooklyn.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_brooklyn.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/brooklyn'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBrooklynV2.run "qiskit.providers.fake_provider.FakeBrooklynV2.run") method. + + + +### props\_filename + +`= 'props_brooklyn.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlington.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlington.md new file mode 100644 index 00000000000..c25f28d6cff --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlington.md @@ -0,0 +1,171 @@ +--- +title: FakeBurlington +description: API reference for qiskit.providers.fake_provider.FakeBurlington +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBurlington +--- + +# FakeBurlington + + + +`qiskit.providers.fake_provider.FakeBurlington`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/burlington/fake_burlington.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_burlington'` + + + +### conf\_filename + +`= 'conf_burlington.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/burlington'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBurlington.run "qiskit.providers.fake_provider.FakeBurlington.run") method. + + + +### props\_filename + +`= 'props_burlington.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlingtonV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlingtonV2.md new file mode 100644 index 00000000000..0430794cfdf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeBurlingtonV2.md @@ -0,0 +1,357 @@ +--- +title: FakeBurlingtonV2 +description: API reference for qiskit.providers.fake_provider.FakeBurlingtonV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeBurlingtonV2 +--- + +# FakeBurlingtonV2 + + + +`qiskit.providers.fake_provider.FakeBurlingtonV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/burlington/fake_burlington.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_burlington'` + + + +### conf\_filename + +`= 'conf_burlington.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/burlington'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeBurlingtonV2.run "qiskit.providers.fake_provider.FakeBurlingtonV2.run") method. + + + +### props\_filename + +`= 'props_burlington.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairo.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairo.md new file mode 100644 index 00000000000..bd142ad5068 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairo.md @@ -0,0 +1,179 @@ +--- +title: FakeCairo +description: API reference for qiskit.providers.fake_provider.FakeCairo +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeCairo +--- + +# FakeCairo + + + +`qiskit.providers.fake_provider.FakeCairo`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/cairo/fake_cairo.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 27 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_cairo'` + + + +### conf\_filename + +`= 'conf_cairo.json'` + + + +### defs\_filename + +`= 'defs_cairo.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/cairo'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeCairo.run "qiskit.providers.fake_provider.FakeCairo.run") method. + + + +### props\_filename + +`= 'props_cairo.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairoV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairoV2.md new file mode 100644 index 00000000000..36a4d8d5069 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCairoV2.md @@ -0,0 +1,351 @@ +--- +title: FakeCairoV2 +description: API reference for qiskit.providers.fake_provider.FakeCairoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeCairoV2 +--- + +# FakeCairoV2 + + + +`qiskit.providers.fake_provider.FakeCairoV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/cairo/fake_cairo.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_cairo'` + + + +### conf\_filename + +`= 'conf_cairo.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_cairo.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/cairo'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeCairoV2.run "qiskit.providers.fake_provider.FakeCairoV2.run") method. + + + +### props\_filename + +`= 'props_cairo.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridge.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridge.md new file mode 100644 index 00000000000..5640ec9a5f9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridge.md @@ -0,0 +1,177 @@ +--- +title: FakeCambridge +description: API reference for qiskit.providers.fake_provider.FakeCambridge +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeCambridge +--- + +# FakeCambridge + + + +`qiskit.providers.fake_provider.FakeCambridge`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/cambridge/fake_cambridge.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake Cambridge backend. + +```python + 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ + 05 06 + ↕ ↕ +07 ↔ 08 ↔ 09 ↔ 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 ↔ 15 +↕ ↕ ↕ +16 17 18 +↕ ↕ ↕ +19 ↔ 20 ↔ 21 ↔ 22 ↔ 23 ↔ 24 ↔ 25 ↔ 26 ↔ 27 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_cambridge'` + + + +### conf\_filename + +`= 'conf_cambridge.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/cambridge'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeCambridge.run "qiskit.providers.fake_provider.FakeCambridge.run") method. + + + +### props\_filename + +`= 'props_cambridge.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridgeV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridgeV2.md new file mode 100644 index 00000000000..c0ab5a7d81b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCambridgeV2.md @@ -0,0 +1,363 @@ +--- +title: FakeCambridgeV2 +description: API reference for qiskit.providers.fake_provider.FakeCambridgeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeCambridgeV2 +--- + +# FakeCambridgeV2 + + + +`qiskit.providers.fake_provider.FakeCambridgeV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/cambridge/fake_cambridge.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Cambridge backend. + +```python + 00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ + 05 06 + ↕ ↕ +07 ↔ 08 ↔ 09 ↔ 10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 ↔ 15 +↕ ↕ ↕ +16 17 18 +↕ ↕ ↕ +19 ↔ 20 ↔ 21 ↔ 22 ↔ 23 ↔ 24 ↔ 25 ↔ 26 ↔ 27 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_cambridge'` + + + +### conf\_filename + +`= 'conf_cambridge.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/cambridge'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeCambridgeV2.run "qiskit.providers.fake_provider.FakeCambridgeV2.run") method. + + + +### props\_filename + +`= 'props_cambridge.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablanca.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablanca.md new file mode 100644 index 00000000000..d80410150a7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablanca.md @@ -0,0 +1,179 @@ +--- +title: FakeCasablanca +description: API reference for qiskit.providers.fake_provider.FakeCasablanca +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeCasablanca +--- + +# FakeCasablanca + + + +`qiskit.providers.fake_provider.FakeCasablanca`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/casablanca/fake_casablanca.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 7 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_casablanca'` + + + +### conf\_filename + +`= 'conf_casablanca.json'` + + + +### defs\_filename + +`= 'defs_casablanca.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/casablanca'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeCasablanca.run "qiskit.providers.fake_provider.FakeCasablanca.run") method. + + + +### props\_filename + +`= 'props_casablanca.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablancaV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablancaV2.md new file mode 100644 index 00000000000..58025f7fd6e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeCasablancaV2.md @@ -0,0 +1,351 @@ +--- +title: FakeCasablancaV2 +description: API reference for qiskit.providers.fake_provider.FakeCasablancaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeCasablancaV2 +--- + +# FakeCasablancaV2 + + + +`qiskit.providers.fake_provider.FakeCasablancaV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/casablanca/fake_casablanca.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 7 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_casablanca'` + + + +### conf\_filename + +`= 'conf_casablanca.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_casablanca.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/casablanca'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeCasablancaV2.run "qiskit.providers.fake_provider.FakeCasablancaV2.run") method. + + + +### props\_filename + +`= 'props_casablanca.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssex.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssex.md new file mode 100644 index 00000000000..21fa2f931f9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssex.md @@ -0,0 +1,173 @@ +--- +title: FakeEssex +description: API reference for qiskit.providers.fake_provider.FakeEssex +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeEssex +--- + +# FakeEssex + + + +`qiskit.providers.fake_provider.FakeEssex`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/essex/fake_essex.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 2 + ↕ + 3 + ↕ + 4 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_essex'` + + + +### conf\_filename + +`= 'conf_essex.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/essex'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeEssex.run "qiskit.providers.fake_provider.FakeEssex.run") method. + + + +### props\_filename + +`= 'props_essex.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssexV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssexV2.md new file mode 100644 index 00000000000..a9438bad9a8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeEssexV2.md @@ -0,0 +1,359 @@ +--- +title: FakeEssexV2 +description: API reference for qiskit.providers.fake_provider.FakeEssexV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeEssexV2 +--- + +# FakeEssexV2 + + + +`qiskit.providers.fake_provider.FakeEssexV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/essex/fake_essex.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 2 + ↕ + 3 + ↕ + 4 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_essex'` + + + +### conf\_filename + +`= 'conf_essex.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/essex'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeEssexV2.run "qiskit.providers.fake_provider.FakeEssexV2.run") method. + + + +### props\_filename + +`= 'props_essex.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGeneva.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGeneva.md new file mode 100644 index 00000000000..980ec95e6b4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGeneva.md @@ -0,0 +1,351 @@ +--- +title: FakeGeneva +description: API reference for qiskit.providers.fake_provider.FakeGeneva +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeGeneva +--- + +# FakeGeneva + + + +`qiskit.providers.fake_provider.FakeGeneva`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/geneva/fake_geneva.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_geneva'` + + + +### conf\_filename + +`= 'conf_geneva.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_geneva.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/geneva'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeGeneva.run "qiskit.providers.fake_provider.FakeGeneva.run") method. + + + +### props\_filename + +`= 'props_geneva.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupe.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupe.md new file mode 100644 index 00000000000..130768b8213 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupe.md @@ -0,0 +1,179 @@ +--- +title: FakeGuadalupe +description: API reference for qiskit.providers.fake_provider.FakeGuadalupe +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeGuadalupe +--- + +# FakeGuadalupe + + + +`qiskit.providers.fake_provider.FakeGuadalupe`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/guadalupe/fake_guadalupe.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 16 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_guadalupe'` + + + +### conf\_filename + +`= 'conf_guadalupe.json'` + + + +### defs\_filename + +`= 'defs_guadalupe.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/guadalupe'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeGuadalupe.run "qiskit.providers.fake_provider.FakeGuadalupe.run") method. + + + +### props\_filename + +`= 'props_guadalupe.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupeV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupeV2.md new file mode 100644 index 00000000000..33b4015eb5f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeGuadalupeV2.md @@ -0,0 +1,351 @@ +--- +title: FakeGuadalupeV2 +description: API reference for qiskit.providers.fake_provider.FakeGuadalupeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeGuadalupeV2 +--- + +# FakeGuadalupeV2 + + + +`qiskit.providers.fake_provider.FakeGuadalupeV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/guadalupe/fake_guadalupe.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 16 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_guadalupe'` + + + +### conf\_filename + +`= 'conf_guadalupe.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_guadalupe.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/guadalupe'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeGuadalupeV2.run "qiskit.providers.fake_provider.FakeGuadalupeV2.run") method. + + + +### props\_filename + +`= 'props_guadalupe.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoi.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoi.md new file mode 100644 index 00000000000..9d90f359eb3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoi.md @@ -0,0 +1,179 @@ +--- +title: FakeHanoi +description: API reference for qiskit.providers.fake_provider.FakeHanoi +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeHanoi +--- + +# FakeHanoi + + + +`qiskit.providers.fake_provider.FakeHanoi`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/hanoi/fake_hanoi.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 27 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_hanoi'` + + + +### conf\_filename + +`= 'conf_hanoi.json'` + + + +### defs\_filename + +`= 'defs_hanoi.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/hanoi'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeHanoi.run "qiskit.providers.fake_provider.FakeHanoi.run") method. + + + +### props\_filename + +`= 'props_hanoi.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoiV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoiV2.md new file mode 100644 index 00000000000..539551b2173 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeHanoiV2.md @@ -0,0 +1,351 @@ +--- +title: FakeHanoiV2 +description: API reference for qiskit.providers.fake_provider.FakeHanoiV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeHanoiV2 +--- + +# FakeHanoiV2 + + + +`qiskit.providers.fake_provider.FakeHanoiV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/hanoi/fake_hanoi.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_hanoi'` + + + +### conf\_filename + +`= 'conf_hanoi.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_hanoi.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/hanoi'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeHanoiV2.run "qiskit.providers.fake_provider.FakeHanoiV2.run") method. + + + +### props\_filename + +`= 'props_hanoi.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakarta.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakarta.md new file mode 100644 index 00000000000..420185985bc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakarta.md @@ -0,0 +1,179 @@ +--- +title: FakeJakarta +description: API reference for qiskit.providers.fake_provider.FakeJakarta +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeJakarta +--- + +# FakeJakarta + + + +`qiskit.providers.fake_provider.FakeJakarta`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/jakarta/fake_jakarta.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 7 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_jakarta'` + + + +### conf\_filename + +`= 'conf_jakarta.json'` + + + +### defs\_filename + +`= 'defs_jakarta.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/jakarta'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeJakarta.run "qiskit.providers.fake_provider.FakeJakarta.run") method. + + + +### props\_filename + +`= 'props_jakarta.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakartaV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakartaV2.md new file mode 100644 index 00000000000..0729c1f5e2d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJakartaV2.md @@ -0,0 +1,351 @@ +--- +title: FakeJakartaV2 +description: API reference for qiskit.providers.fake_provider.FakeJakartaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeJakartaV2 +--- + +# FakeJakartaV2 + + + +`qiskit.providers.fake_provider.FakeJakartaV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/jakarta/fake_jakarta.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 7 qubit V2 backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_jakarta'` + + + +### conf\_filename + +`= 'conf_jakarta.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_jakarta.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/jakarta'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeJakartaV2.run "qiskit.providers.fake_provider.FakeJakartaV2.run") method. + + + +### props\_filename + +`= 'props_jakarta.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburg.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburg.md new file mode 100644 index 00000000000..7fb9dc3027a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburg.md @@ -0,0 +1,175 @@ +--- +title: FakeJohannesburg +description: API reference for qiskit.providers.fake_provider.FakeJohannesburg +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeJohannesburg +--- + +# FakeJohannesburg + + + +`qiskit.providers.fake_provider.FakeJohannesburg`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/johannesburg/fake_johannesburg.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake Johannesburg backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_johannesburg'` + + + +### conf\_filename + +`= 'conf_johannesburg.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/johannesburg'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeJohannesburg.run "qiskit.providers.fake_provider.FakeJohannesburg.run") method. + + + +### props\_filename + +`= 'props_johannesburg.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburgV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburgV2.md new file mode 100644 index 00000000000..dc7d1d3b773 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeJohannesburgV2.md @@ -0,0 +1,361 @@ +--- +title: FakeJohannesburgV2 +description: API reference for qiskit.providers.fake_provider.FakeJohannesburgV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeJohannesburgV2 +--- + +# FakeJohannesburgV2 + + + +`qiskit.providers.fake_provider.FakeJohannesburgV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/johannesburg/fake_johannesburg.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Johannesburg V2 backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_johannesburg'` + + + +### conf\_filename + +`= 'conf_johannesburg.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/johannesburg'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeJohannesburgV2.run "qiskit.providers.fake_provider.FakeJohannesburgV2.run") method. + + + +### props\_filename + +`= 'props_johannesburg.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkata.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkata.md new file mode 100644 index 00000000000..f3e357bc796 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkata.md @@ -0,0 +1,179 @@ +--- +title: FakeKolkata +description: API reference for qiskit.providers.fake_provider.FakeKolkata +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeKolkata +--- + +# FakeKolkata + + + +`qiskit.providers.fake_provider.FakeKolkata`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/kolkata/fake_kolkata.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 27 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_kolkata'` + + + +### conf\_filename + +`= 'conf_kolkata.json'` + + + +### defs\_filename + +`= 'defs_kolkata.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/kolkata'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeKolkata.run "qiskit.providers.fake_provider.FakeKolkata.run") method. + + + +### props\_filename + +`= 'props_kolkata.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkataV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkataV2.md new file mode 100644 index 00000000000..42593e480b5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeKolkataV2.md @@ -0,0 +1,351 @@ +--- +title: FakeKolkataV2 +description: API reference for qiskit.providers.fake_provider.FakeKolkataV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeKolkataV2 +--- + +# FakeKolkataV2 + + + +`qiskit.providers.fake_provider.FakeKolkataV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/kolkata/fake_kolkata.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_kolkata'` + + + +### conf\_filename + +`= 'conf_kolkata.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_kolkata.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/kolkata'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeKolkataV2.run "qiskit.providers.fake_provider.FakeKolkataV2.run") method. + + + +### props\_filename + +`= 'props_kolkata.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagos.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagos.md new file mode 100644 index 00000000000..f729a96ed89 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagos.md @@ -0,0 +1,179 @@ +--- +title: FakeLagos +description: API reference for qiskit.providers.fake_provider.FakeLagos +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeLagos +--- + +# FakeLagos + + + +`qiskit.providers.fake_provider.FakeLagos`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/lagos/fake_lagos.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 7 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_lagos'` + + + +### conf\_filename + +`= 'conf_lagos.json'` + + + +### defs\_filename + +`= 'defs_lagos.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/lagos'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeLagos.run "qiskit.providers.fake_provider.FakeLagos.run") method. + + + +### props\_filename + +`= 'props_lagos.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagosV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagosV2.md new file mode 100644 index 00000000000..bdb89acb1be --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLagosV2.md @@ -0,0 +1,351 @@ +--- +title: FakeLagosV2 +description: API reference for qiskit.providers.fake_provider.FakeLagosV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeLagosV2 +--- + +# FakeLagosV2 + + + +`qiskit.providers.fake_provider.FakeLagosV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/lagos/fake_lagos.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 7 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_lagos'` + + + +### conf\_filename + +`= 'conf_lagos.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_lagos.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/lagos'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeLagosV2.run "qiskit.providers.fake_provider.FakeLagosV2.run") method. + + + +### props\_filename + +`= 'props_lagos.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLima.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLima.md new file mode 100644 index 00000000000..8aa123e9440 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLima.md @@ -0,0 +1,179 @@ +--- +title: FakeLima +description: API reference for qiskit.providers.fake_provider.FakeLima +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeLima +--- + +# FakeLima + + + +`qiskit.providers.fake_provider.FakeLima`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/lima/fake_lima.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_lima'` + + + +### conf\_filename + +`= 'conf_lima.json'` + + + +### defs\_filename + +`= 'defs_lima.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/lima'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeLima.run "qiskit.providers.fake_provider.FakeLima.run") method. + + + +### props\_filename + +`= 'props_lima.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLimaV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLimaV2.md new file mode 100644 index 00000000000..eea49f07e50 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLimaV2.md @@ -0,0 +1,351 @@ +--- +title: FakeLimaV2 +description: API reference for qiskit.providers.fake_provider.FakeLimaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeLimaV2 +--- + +# FakeLimaV2 + + + +`qiskit.providers.fake_provider.FakeLimaV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/lima/fake_lima.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_lima'` + + + +### conf\_filename + +`= 'conf_lima.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_lima.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/lima'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeLimaV2.run "qiskit.providers.fake_provider.FakeLimaV2.run") method. + + + +### props\_filename + +`= 'props_lima.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondon.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondon.md new file mode 100644 index 00000000000..60a91aedcb2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondon.md @@ -0,0 +1,173 @@ +--- +title: FakeLondon +description: API reference for qiskit.providers.fake_provider.FakeLondon +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeLondon +--- + +# FakeLondon + + + +`qiskit.providers.fake_provider.FakeLondon`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/london/fake_london.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 2 + ↕ + 3 + ↕ + 4 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_london'` + + + +### conf\_filename + +`= 'conf_london.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/london'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeLondon.run "qiskit.providers.fake_provider.FakeLondon.run") method. + + + +### props\_filename + +`= 'props_london.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondonV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondonV2.md new file mode 100644 index 00000000000..fcfc6e7f841 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeLondonV2.md @@ -0,0 +1,359 @@ +--- +title: FakeLondonV2 +description: API reference for qiskit.providers.fake_provider.FakeLondonV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeLondonV2 +--- + +# FakeLondonV2 + + + +`qiskit.providers.fake_provider.FakeLondonV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/london/fake_london.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 2 + ↕ + 3 + ↕ + 4 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_london'` + + + +### conf\_filename + +`= 'conf_london.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/london'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeLondonV2.run "qiskit.providers.fake_provider.FakeLondonV2.run") method. + + + +### props\_filename + +`= 'props_london.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattan.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattan.md new file mode 100644 index 00000000000..9a32e0955b1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattan.md @@ -0,0 +1,179 @@ +--- +title: FakeManhattan +description: API reference for qiskit.providers.fake_provider.FakeManhattan +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeManhattan +--- + +# FakeManhattan + + + +`qiskit.providers.fake_provider.FakeManhattan`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/manhattan/fake_manhattan.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake Manhattan backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_manhattan'` + + + +### conf\_filename + +`= 'conf_manhattan.json'` + + + +### defs\_filename + +`= 'defs_manhattan.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/manhattan'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeManhattan.run "qiskit.providers.fake_provider.FakeManhattan.run") method. + + + +### props\_filename + +`= 'props_manhattan.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattanV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattanV2.md new file mode 100644 index 00000000000..134433b9922 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManhattanV2.md @@ -0,0 +1,351 @@ +--- +title: FakeManhattanV2 +description: API reference for qiskit.providers.fake_provider.FakeManhattanV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeManhattanV2 +--- + +# FakeManhattanV2 + + + +`qiskit.providers.fake_provider.FakeManhattanV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/manhattan/fake_manhattan.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Manhattan backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_manhattan'` + + + +### conf\_filename + +`= 'conf_manhattan.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_manhattan.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/manhattan'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeManhattanV2.run "qiskit.providers.fake_provider.FakeManhattanV2.run") method. + + + +### props\_filename + +`= 'props_manhattan.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManila.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManila.md new file mode 100644 index 00000000000..06cb7ea89e5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManila.md @@ -0,0 +1,179 @@ +--- +title: FakeManila +description: API reference for qiskit.providers.fake_provider.FakeManila +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeManila +--- + +# FakeManila + + + +`qiskit.providers.fake_provider.FakeManila`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/manila/fake_manila.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_manila'` + + + +### conf\_filename + +`= 'conf_manila.json'` + + + +### defs\_filename + +`= 'defs_manila.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/manila'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeManila.run "qiskit.providers.fake_provider.FakeManila.run") method. + + + +### props\_filename + +`= 'props_manila.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManilaV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManilaV2.md new file mode 100644 index 00000000000..9e044312a50 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeManilaV2.md @@ -0,0 +1,351 @@ +--- +title: FakeManilaV2 +description: API reference for qiskit.providers.fake_provider.FakeManilaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeManilaV2 +--- + +# FakeManilaV2 + + + +`qiskit.providers.fake_provider.FakeManilaV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/manila/fake_manila.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_manila'` + + + +### conf\_filename + +`= 'conf_manila.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_manila.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/manila'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeManilaV2.run "qiskit.providers.fake_provider.FakeManilaV2.run") method. + + + +### props\_filename + +`= 'props_manila.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourne.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourne.md new file mode 100644 index 00000000000..b4d052ae9f9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourne.md @@ -0,0 +1,140 @@ +--- +title: FakeMelbourne +description: API reference for qiskit.providers.fake_provider.FakeMelbourne +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeMelbourne +--- + +# FakeMelbourne + + + +`qiskit.providers.fake_provider.FakeMelbourne`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/melbourne/fake_melbourne.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake 14 qubit backend. + +```python +0 ← 1 → 2 → 3 ← 4 ← 5 → 6 + ↑ ↑ ↑ ↓ ↓ ↓ + 13 → 12 ← 11 → 10 ← 9 → 8 ← 7 +``` + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeMelbourne.run "qiskit.providers.fake_provider.FakeMelbourne.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourneV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourneV2.md new file mode 100644 index 00000000000..11b800978cb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMelbourneV2.md @@ -0,0 +1,351 @@ +--- +title: FakeMelbourneV2 +description: API reference for qiskit.providers.fake_provider.FakeMelbourneV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeMelbourneV2 +--- + +# FakeMelbourneV2 + + + +`qiskit.providers.fake_provider.FakeMelbourneV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/melbourne/fake_melbourne.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 14 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_melbourne'` + + + +### conf\_filename + +`= 'conf_melbourne.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/melbourne'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeMelbourneV2.run "qiskit.providers.fake_provider.FakeMelbourneV2.run") method. + + + +### props\_filename + +`= 'props_melbourne.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontreal.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontreal.md new file mode 100644 index 00000000000..c9bdc9f6fea --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontreal.md @@ -0,0 +1,179 @@ +--- +title: FakeMontreal +description: API reference for qiskit.providers.fake_provider.FakeMontreal +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeMontreal +--- + +# FakeMontreal + + + +`qiskit.providers.fake_provider.FakeMontreal`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/montreal/fake_montreal.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 27 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_montreal'` + + + +### conf\_filename + +`= 'conf_montreal.json'` + + + +### defs\_filename + +`= 'defs_montreal.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/montreal'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeMontreal.run "qiskit.providers.fake_provider.FakeMontreal.run") method. + + + +### props\_filename + +`= 'props_montreal.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontrealV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontrealV2.md new file mode 100644 index 00000000000..bdcad22bb37 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMontrealV2.md @@ -0,0 +1,351 @@ +--- +title: FakeMontrealV2 +description: API reference for qiskit.providers.fake_provider.FakeMontrealV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeMontrealV2 +--- + +# FakeMontrealV2 + + + +`qiskit.providers.fake_provider.FakeMontrealV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/montreal/fake_montreal.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_montreal'` + + + +### conf\_filename + +`= 'conf_montreal.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_montreal.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/montreal'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeMontrealV2.run "qiskit.providers.fake_provider.FakeMontrealV2.run") method. + + + +### props\_filename + +`= 'props_montreal.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbai.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbai.md new file mode 100644 index 00000000000..81126024ae9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbai.md @@ -0,0 +1,179 @@ +--- +title: FakeMumbai +description: API reference for qiskit.providers.fake_provider.FakeMumbai +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeMumbai +--- + +# FakeMumbai + + + +`qiskit.providers.fake_provider.FakeMumbai`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/mumbai/fake_mumbai.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 27 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_mumbai'` + + + +### conf\_filename + +`= 'conf_mumbai.json'` + + + +### defs\_filename + +`= 'defs_mumbai.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/mumbai'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeMumbai.run "qiskit.providers.fake_provider.FakeMumbai.run") method. + + + +### props\_filename + +`= 'props_mumbai.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiFractionalCX.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiFractionalCX.md new file mode 100644 index 00000000000..cde6caefb53 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiFractionalCX.md @@ -0,0 +1,327 @@ +--- +title: FakeMumbaiFractionalCX +description: API reference for qiskit.providers.fake_provider.FakeMumbaiFractionalCX +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeMumbaiFractionalCX +--- + +# FakeMumbaiFractionalCX + + + +`qiskit.providers.fake_provider.FakeMumbaiFractionalCX`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_mumbai_v2.py "view source code") + +Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") + +A fake mumbai backend. + + + The class `qiskit.providers.fake_provider.fake_mumbai_v2.FakeMumbaiFractionalCX` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. Use the qiskit.providers.basic\_provider.GenericBackendV2 class instead. + + +## Attributes + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the output signal timestep + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeMumbaiFractionalCX.run "qiskit.providers.fake_provider.FakeMumbaiFractionalCX.run") method. + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +### run + + + +`run(run_input, **options)` + +Run on the backend. + +This method returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object that runs circuits. Depending on the backend this may be either an async or sync call. It is at the discretion of the provider to decide whether running should block until the execution is finished or not: the Job class can handle either situation. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiV2.md new file mode 100644 index 00000000000..ea0c4ac6fed --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeMumbaiV2.md @@ -0,0 +1,351 @@ +--- +title: FakeMumbaiV2 +description: API reference for qiskit.providers.fake_provider.FakeMumbaiV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeMumbaiV2 +--- + +# FakeMumbaiV2 + + + +`qiskit.providers.fake_provider.FakeMumbaiV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/mumbai/fake_mumbai.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_mumbai'` + + + +### conf\_filename + +`= 'conf_mumbai.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_mumbai.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/mumbai'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeMumbaiV2.run "qiskit.providers.fake_provider.FakeMumbaiV2.run") method. + + + +### props\_filename + +`= 'props_mumbai.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobi.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobi.md new file mode 100644 index 00000000000..86b26188dd9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobi.md @@ -0,0 +1,179 @@ +--- +title: FakeNairobi +description: API reference for qiskit.providers.fake_provider.FakeNairobi +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeNairobi +--- + +# FakeNairobi + + + +`qiskit.providers.fake_provider.FakeNairobi`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/nairobi/fake_nairobi.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 7 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_nairobi'` + + + +### conf\_filename + +`= 'conf_nairobi.json'` + + + +### defs\_filename + +`= 'defs_nairobi.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/nairobi'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeNairobi.run "qiskit.providers.fake_provider.FakeNairobi.run") method. + + + +### props\_filename + +`= 'props_nairobi.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobiV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobiV2.md new file mode 100644 index 00000000000..03ae5c94179 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeNairobiV2.md @@ -0,0 +1,351 @@ +--- +title: FakeNairobiV2 +description: API reference for qiskit.providers.fake_provider.FakeNairobiV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeNairobiV2 +--- + +# FakeNairobiV2 + + + +`qiskit.providers.fake_provider.FakeNairobiV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/nairobi/fake_nairobi.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 7 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_nairobi'` + + + +### conf\_filename + +`= 'conf_nairobi.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_nairobi.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/nairobi'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeNairobiV2.run "qiskit.providers.fake_provider.FakeNairobiV2.run") method. + + + +### props\_filename + +`= 'props_nairobi.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse2Q.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse2Q.md new file mode 100644 index 00000000000..6ab944e6a7d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse2Q.md @@ -0,0 +1,149 @@ +--- +title: FakeOpenPulse2Q +description: API reference for qiskit.providers.fake_provider.FakeOpenPulse2Q +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeOpenPulse2Q +--- + +# FakeOpenPulse2Q + + + +`qiskit.providers.fake_provider.FakeOpenPulse2Q`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_openpulse_2q.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake 2 qubit backend for pulse test. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeOpenPulse2Q.run "qiskit.providers.fake_provider.FakeOpenPulse2Q.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Return the default pulse-related settings provided by the backend (such as gate to Schedule mappings). + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return the measured characteristics of the backend. + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse3Q.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse3Q.md new file mode 100644 index 00000000000..bcc6a63fe3e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOpenPulse3Q.md @@ -0,0 +1,147 @@ +--- +title: FakeOpenPulse3Q +description: API reference for qiskit.providers.fake_provider.FakeOpenPulse3Q +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeOpenPulse3Q +--- + +# FakeOpenPulse3Q + + + +`qiskit.providers.fake_provider.FakeOpenPulse3Q`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_openpulse_3q.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +Trivial extension of the FakeOpenPulse2Q. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeOpenPulse3Q.run "qiskit.providers.fake_provider.FakeOpenPulse3Q.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return backend properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOslo.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOslo.md new file mode 100644 index 00000000000..df4b4cde628 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOslo.md @@ -0,0 +1,351 @@ +--- +title: FakeOslo +description: API reference for qiskit.providers.fake_provider.FakeOslo +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeOslo +--- + +# FakeOslo + + + +`qiskit.providers.fake_provider.FakeOslo`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/oslo/fake_oslo.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 7 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_oslo'` + + + +### conf\_filename + +`= 'conf_oslo.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_oslo.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/oslo'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeOslo.run "qiskit.providers.fake_provider.FakeOslo.run") method. + + + +### props\_filename + +`= 'props_oslo.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurense.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurense.md new file mode 100644 index 00000000000..f535ff5aeb3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurense.md @@ -0,0 +1,171 @@ +--- +title: FakeOurense +description: API reference for qiskit.providers.fake_provider.FakeOurense +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeOurense +--- + +# FakeOurense + + + +`qiskit.providers.fake_provider.FakeOurense`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/ourense/fake_ourense.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_ourense'` + + + +### conf\_filename + +`= 'conf_ourense.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/ourense'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeOurense.run "qiskit.providers.fake_provider.FakeOurense.run") method. + + + +### props\_filename + +`= 'props_ourense.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurenseV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurenseV2.md new file mode 100644 index 00000000000..6730e7e50e4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeOurenseV2.md @@ -0,0 +1,357 @@ +--- +title: FakeOurenseV2 +description: API reference for qiskit.providers.fake_provider.FakeOurenseV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeOurenseV2 +--- + +# FakeOurenseV2 + + + +`qiskit.providers.fake_provider.FakeOurenseV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/ourense/fake_ourense.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_ourense'` + + + +### conf\_filename + +`= 'conf_ourense.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/ourense'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeOurenseV2.run "qiskit.providers.fake_provider.FakeOurenseV2.run") method. + + + +### props\_filename + +`= 'props_ourense.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParis.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParis.md new file mode 100644 index 00000000000..20ccdcdc055 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParis.md @@ -0,0 +1,191 @@ +--- +title: FakeParis +description: API reference for qiskit.providers.fake_provider.FakeParis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeParis +--- + +# FakeParis + + + +`qiskit.providers.fake_provider.FakeParis`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/paris/fake_paris.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake Paris backend. + +```python + 06 17 + ↕ ↕ +00 ↔ 01 ↔ 04 ↔ 07 ↔ 10 ↔ 12 ↔ 15 ↔ 18 ↔ 20 ↔ 23 + ↕ ↕ ↕ + 02 13 24 + ↕ ↕ ↕ + 03 ↔ 05 ↔ 08 ↔ 11 ↔ 14 ↔ 16 ↔ 19 ↔ 22 ↔ 25 ↔ 26 + ↕ ↕ + 09 20 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_paris'` + + + +### conf\_filename + +`= 'conf_paris.json'` + + + +### defs\_filename + +`= 'defs_paris.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/paris'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeParis.run "qiskit.providers.fake_provider.FakeParis.run") method. + + + +### props\_filename + +`= 'props_paris.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParisV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParisV2.md new file mode 100644 index 00000000000..8b0eb62da97 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeParisV2.md @@ -0,0 +1,363 @@ +--- +title: FakeParisV2 +description: API reference for qiskit.providers.fake_provider.FakeParisV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeParisV2 +--- + +# FakeParisV2 + + + +`qiskit.providers.fake_provider.FakeParisV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/paris/fake_paris.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Paris backend. + +```python + 06 17 + ↕ ↕ +00 ↔ 01 ↔ 04 ↔ 07 ↔ 10 ↔ 12 ↔ 15 ↔ 18 ↔ 20 ↔ 23 + ↕ ↕ ↕ + 02 13 24 + ↕ ↕ ↕ + 03 ↔ 05 ↔ 08 ↔ 11 ↔ 14 ↔ 16 ↔ 19 ↔ 22 ↔ 25 ↔ 26 + ↕ ↕ + 09 20 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_paris'` + + + +### conf\_filename + +`= 'conf_paris.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_paris.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/paris'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeParisV2.run "qiskit.providers.fake_provider.FakeParisV2.run") method. + + + +### props\_filename + +`= 'props_paris.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePerth.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePerth.md new file mode 100644 index 00000000000..ca06118ac85 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePerth.md @@ -0,0 +1,351 @@ +--- +title: FakePerth +description: API reference for qiskit.providers.fake_provider.FakePerth +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakePerth +--- + +# FakePerth + + + +`qiskit.providers.fake_provider.FakePerth`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/perth/fake_perth.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 7 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_perth'` + + + +### conf\_filename + +`= 'conf_perth.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_perth.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/perth'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakePerth.run "qiskit.providers.fake_provider.FakePerth.run") method. + + + +### props\_filename + +`= 'props_perth.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsie.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsie.md new file mode 100644 index 00000000000..91befe7582d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsie.md @@ -0,0 +1,144 @@ +--- +title: FakePoughkeepsie +description: API reference for qiskit.providers.fake_provider.FakePoughkeepsie +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakePoughkeepsie +--- + +# FakePoughkeepsie + + + +`qiskit.providers.fake_provider.FakePoughkeepsie`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/poughkeepsie/fake_poughkeepsie.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake Poughkeepsie backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakePoughkeepsie.run "qiskit.providers.fake_provider.FakePoughkeepsie.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsieV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsieV2.md new file mode 100644 index 00000000000..779bf664d49 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePoughkeepsieV2.md @@ -0,0 +1,351 @@ +--- +title: FakePoughkeepsieV2 +description: API reference for qiskit.providers.fake_provider.FakePoughkeepsieV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakePoughkeepsieV2 +--- + +# FakePoughkeepsieV2 + + + +`qiskit.providers.fake_provider.FakePoughkeepsieV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/poughkeepsie/fake_poughkeepsie.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Poughkeepsie backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_poughkeepsie'` + + + +### conf\_filename + +`= 'conf_poughkeepsie.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_poughkeepsie.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/poughkeepsie'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakePoughkeepsieV2.run "qiskit.providers.fake_provider.FakePoughkeepsieV2.run") method. + + + +### props\_filename + +`= 'props_poughkeepsie.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePrague.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePrague.md new file mode 100644 index 00000000000..22450b68075 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakePrague.md @@ -0,0 +1,351 @@ +--- +title: FakePrague +description: API reference for qiskit.providers.fake_provider.FakePrague +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakePrague +--- + +# FakePrague + + + +`qiskit.providers.fake_provider.FakePrague`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/prague/fake_prague.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 33 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_prague'` + + + +### conf\_filename + +`= 'conf_prague.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/prague'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakePrague.run "qiskit.providers.fake_provider.FakePrague.run") method. + + + +### props\_filename + +`= 'props_prague.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProvider.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProvider.md new file mode 100644 index 00000000000..47b41df93e9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProvider.md @@ -0,0 +1,82 @@ +--- +title: FakeProvider +description: API reference for qiskit.providers.fake_provider.FakeProvider +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeProvider +--- + +# FakeProvider + + + +`qiskit.providers.fake_provider.FakeProvider`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_provider.py "view source code") + +Bases: [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.provider.ProviderV1") + +Fake provider containing fake V1 backends. + +Only filtering backends by name is implemented. This class contains all fake V1 backends available in the [`qiskit.providers.fake_provider`](providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider"). + + + The class `qiskit.providers.fake_provider.fake_provider.FakeProvider` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. This class has been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeProviderExample instead of from qiskit.providers.fake\_provider import FakeProviderExample. + + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backends + + + +`backends(name=None, **kwargs)` + +Return a list of backends matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +**a list of Backends that match the filtering** + +criteria. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[Backend](qiskit.providers.Backend "qiskit.providers.Backend")] + +### get\_backend + + + +`get_backend(name=None, **kwargs)` + +Return a single backend matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +a backend matching the filtering. + +**Return type** + +[Backend](qiskit.providers.Backend "qiskit.providers.Backend") + +**Raises** + +[**QiskitBackendNotFoundError**](providers#qiskit.providers.QiskitBackendNotFoundError "qiskit.providers.QiskitBackendNotFoundError") – if no backend could be found or more than one backend matches the filtering criteria. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProviderForBackendV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProviderForBackendV2.md new file mode 100644 index 00000000000..1bbe6ba104b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeProviderForBackendV2.md @@ -0,0 +1,82 @@ +--- +title: FakeProviderForBackendV2 +description: API reference for qiskit.providers.fake_provider.FakeProviderForBackendV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeProviderForBackendV2 +--- + +# FakeProviderForBackendV2 + + + +`qiskit.providers.fake_provider.FakeProviderForBackendV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_provider.py "view source code") + +Bases: [`ProviderV1`](qiskit.providers.ProviderV1 "qiskit.providers.provider.ProviderV1") + +Fake provider containing fake V2 backends. + +Only filtering backends by name is implemented. This class contains all fake V2 backends available in the [`qiskit.providers.fake_provider`](providers_fake_provider#module-qiskit.providers.fake_provider "qiskit.providers.fake_provider"). + + + The class `qiskit.providers.fake_provider.fake_provider.FakeProviderForBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. This class has been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeProviderExample instead of from qiskit.providers.fake\_provider import FakeProviderExample. + + +## Attributes + + + +### version + +`= 1` + +## Methods + +### backends + + + +`backends(name=None, **kwargs)` + +Return a list of backends matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +**a list of Backends that match the filtering** + +criteria. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[Backend](qiskit.providers.Backend "qiskit.providers.Backend")] + +### get\_backend + + + +`get_backend(name=None, **kwargs)` + +Return a single backend matching the specified filtering. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – name of the backend. +* **\*\*kwargs** – dict used for filtering. + +**Returns** + +a backend matching the filtering. + +**Return type** + +[Backend](qiskit.providers.Backend "qiskit.providers.Backend") + +**Raises** + +[**QiskitBackendNotFoundError**](providers#qiskit.providers.QiskitBackendNotFoundError "qiskit.providers.QiskitBackendNotFoundError") – if no backend could be found or more than one backend matches the filtering criteria. + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQasmSimulator.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQasmSimulator.md new file mode 100644 index 00000000000..511d6fe0daf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQasmSimulator.md @@ -0,0 +1,138 @@ +--- +title: FakeQasmSimulator +description: API reference for qiskit.providers.fake_provider.FakeQasmSimulator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeQasmSimulator +--- + +# FakeQasmSimulator + + + +`qiskit.providers.fake_provider.FakeQasmSimulator`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/fake_qasm_simulator.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake simulator backend. + + + The class `qiskit.providers.fake_provider.fake_qasm_simulator.FakeQasmSimulator` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. Use the qiskit.providers.basic\_provider.BasicSimulator class instead. + + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeQasmSimulator.run "qiskit.providers.fake_provider.FakeQasmSimulator.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return backend properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuito.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuito.md new file mode 100644 index 00000000000..e953171ce47 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuito.md @@ -0,0 +1,179 @@ +--- +title: FakeQuito +description: API reference for qiskit.providers.fake_provider.FakeQuito +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeQuito +--- + +# FakeQuito + + + +`qiskit.providers.fake_provider.FakeQuito`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/quito/fake_quito.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_quito'` + + + +### conf\_filename + +`= 'conf_quito.json'` + + + +### defs\_filename + +`= 'defs_quito.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/quito'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeQuito.run "qiskit.providers.fake_provider.FakeQuito.run") method. + + + +### props\_filename + +`= 'props_quito.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuitoV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuitoV2.md new file mode 100644 index 00000000000..85ec0362f1d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeQuitoV2.md @@ -0,0 +1,351 @@ +--- +title: FakeQuitoV2 +description: API reference for qiskit.providers.fake_provider.FakeQuitoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeQuitoV2 +--- + +# FakeQuitoV2 + + + +`qiskit.providers.fake_provider.FakeQuitoV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/quito/fake_quito.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_quito'` + + + +### conf\_filename + +`= 'conf_quito.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_quito.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/quito'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeQuitoV2.run "qiskit.providers.fake_provider.FakeQuitoV2.run") method. + + + +### props\_filename + +`= 'props_quito.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochester.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochester.md new file mode 100644 index 00000000000..684a4621b06 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochester.md @@ -0,0 +1,165 @@ +--- +title: FakeRochester +description: API reference for qiskit.providers.fake_provider.FakeRochester +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeRochester +--- + +# FakeRochester + + + +`qiskit.providers.fake_provider.FakeRochester`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/rochester/fake_rochester.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake Rochester backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_rochester'` + + + +### conf\_filename + +`= 'conf_rochester.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/rochester'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeRochester.run "qiskit.providers.fake_provider.FakeRochester.run") method. + + + +### props\_filename + +`= 'props_rochester.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochesterV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochesterV2.md new file mode 100644 index 00000000000..99310cceab1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRochesterV2.md @@ -0,0 +1,351 @@ +--- +title: FakeRochesterV2 +description: API reference for qiskit.providers.fake_provider.FakeRochesterV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeRochesterV2 +--- + +# FakeRochesterV2 + + + +`qiskit.providers.fake_provider.FakeRochesterV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/rochester/fake_rochester.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Rochester backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_rochester'` + + + +### conf\_filename + +`= 'conf_rochester.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/rochester'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeRochesterV2.run "qiskit.providers.fake_provider.FakeRochesterV2.run") method. + + + +### props\_filename + +`= 'props_rochester.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRome.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRome.md new file mode 100644 index 00000000000..e5324286dc8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRome.md @@ -0,0 +1,179 @@ +--- +title: FakeRome +description: API reference for qiskit.providers.fake_provider.FakeRome +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeRome +--- + +# FakeRome + + + +`qiskit.providers.fake_provider.FakeRome`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/rome/fake_rome.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_rome'` + + + +### conf\_filename + +`= 'conf_rome.json'` + + + +### defs\_filename + +`= 'defs_rome.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/rome'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeRome.run "qiskit.providers.fake_provider.FakeRome.run") method. + + + +### props\_filename + +`= 'props_rome.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRomeV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRomeV2.md new file mode 100644 index 00000000000..62569343ac7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRomeV2.md @@ -0,0 +1,351 @@ +--- +title: FakeRomeV2 +description: API reference for qiskit.providers.fake_provider.FakeRomeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeRomeV2 +--- + +# FakeRomeV2 + + + +`qiskit.providers.fake_provider.FakeRomeV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/rome/fake_rome.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_rome'` + + + +### conf\_filename + +`= 'conf_rome.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_rome.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/rome'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeRomeV2.run "qiskit.providers.fake_provider.FakeRomeV2.run") method. + + + +### props\_filename + +`= 'props_rome.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRueschlikon.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRueschlikon.md new file mode 100644 index 00000000000..28d30da9586 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeRueschlikon.md @@ -0,0 +1,140 @@ +--- +title: FakeRueschlikon +description: API reference for qiskit.providers.fake_provider.FakeRueschlikon +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeRueschlikon +--- + +# FakeRueschlikon + + + +`qiskit.providers.fake_provider.FakeRueschlikon`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/rueschlikon/fake_rueschlikon.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake 16 qubit backend. + +```python +1 → 2 → 3 → 4 ← 5 ← 6 → 7 ← 8 +↓ ↑ ↓ ↓ ↑ ↓ ↓ ↑ +0 ← 15 → 14 ← 13 ← 12 → 11 → 10 ← 9 +``` + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeRueschlikon.run "qiskit.providers.fake_provider.FakeRueschlikon.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Return backend properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiago.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiago.md new file mode 100644 index 00000000000..f373872433c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiago.md @@ -0,0 +1,179 @@ +--- +title: FakeSantiago +description: API reference for qiskit.providers.fake_provider.FakeSantiago +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeSantiago +--- + +# FakeSantiago + + + +`qiskit.providers.fake_provider.FakeSantiago`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/santiago/fake_santiago.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake Santiago backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_santiago'` + + + +### conf\_filename + +`= 'conf_santiago.json'` + + + +### defs\_filename + +`= 'defs_santiago.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/santiago'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeSantiago.run "qiskit.providers.fake_provider.FakeSantiago.run") method. + + + +### props\_filename + +`= 'props_santiago.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiagoV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiagoV2.md new file mode 100644 index 00000000000..c08f0dd9a2d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSantiagoV2.md @@ -0,0 +1,351 @@ +--- +title: FakeSantiagoV2 +description: API reference for qiskit.providers.fake_provider.FakeSantiagoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeSantiagoV2 +--- + +# FakeSantiagoV2 + + + +`qiskit.providers.fake_provider.FakeSantiagoV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/santiago/fake_santiago.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Santiago backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_santiago'` + + + +### conf\_filename + +`= 'conf_santiago.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_santiago.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/santiago'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeSantiagoV2.run "qiskit.providers.fake_provider.FakeSantiagoV2.run") method. + + + +### props\_filename + +`= 'props_santiago.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSherbrooke.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSherbrooke.md new file mode 100644 index 00000000000..901be28c8fa --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSherbrooke.md @@ -0,0 +1,351 @@ +--- +title: FakeSherbrooke +description: API reference for qiskit.providers.fake_provider.FakeSherbrooke +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeSherbrooke +--- + +# FakeSherbrooke + + + +`qiskit.providers.fake_provider.FakeSherbrooke`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/sherbrooke/fake_sherbrooke.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 127 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_sherbrooke'` + + + +### conf\_filename + +`= 'conf_sherbrooke.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_sherbrooke.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/sherbrooke'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeSherbrooke.run "qiskit.providers.fake_provider.FakeSherbrooke.run") method. + + + +### props\_filename + +`= 'props_sherbrooke.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingapore.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingapore.md new file mode 100644 index 00000000000..dfa5cd48049 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingapore.md @@ -0,0 +1,175 @@ +--- +title: FakeSingapore +description: API reference for qiskit.providers.fake_provider.FakeSingapore +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeSingapore +--- + +# FakeSingapore + + + +`qiskit.providers.fake_provider.FakeSingapore`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/singapore/fake_singapore.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake Singapore backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_singapore'` + + + +### conf\_filename + +`= 'conf_singapore.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/singapore'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeSingapore.run "qiskit.providers.fake_provider.FakeSingapore.run") method. + + + +### props\_filename + +`= 'props_singapore.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingaporeV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingaporeV2.md new file mode 100644 index 00000000000..4b4aad914fe --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSingaporeV2.md @@ -0,0 +1,361 @@ +--- +title: FakeSingaporeV2 +description: API reference for qiskit.providers.fake_provider.FakeSingaporeV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeSingaporeV2 +--- + +# FakeSingaporeV2 + + + +`qiskit.providers.fake_provider.FakeSingaporeV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/singapore/fake_singapore.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake Singapore backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ↕ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ +15 ↔ 16 ↔ 17 ↔ 18 ↔ 19 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_singapore'` + + + +### conf\_filename + +`= 'conf_singapore.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/singapore'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeSingaporeV2.run "qiskit.providers.fake_provider.FakeSingaporeV2.run") method. + + + +### props\_filename + +`= 'props_singapore.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydney.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydney.md new file mode 100644 index 00000000000..2532377b573 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydney.md @@ -0,0 +1,179 @@ +--- +title: FakeSydney +description: API reference for qiskit.providers.fake_provider.FakeSydney +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeSydney +--- + +# FakeSydney + + + +`qiskit.providers.fake_provider.FakeSydney`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/sydney/fake_sydney.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 27 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_sydney'` + + + +### conf\_filename + +`= 'conf_sydney.json'` + + + +### defs\_filename + +`= 'defs_sydney.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/sydney'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeSydney.run "qiskit.providers.fake_provider.FakeSydney.run") method. + + + +### props\_filename + +`= 'props_sydney.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydneyV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydneyV2.md new file mode 100644 index 00000000000..0c828f8a2d7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeSydneyV2.md @@ -0,0 +1,351 @@ +--- +title: FakeSydneyV2 +description: API reference for qiskit.providers.fake_provider.FakeSydneyV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeSydneyV2 +--- + +# FakeSydneyV2 + + + +`qiskit.providers.fake_provider.FakeSydneyV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/sydney/fake_sydney.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_sydney'` + + + +### conf\_filename + +`= 'conf_sydney.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_sydney.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/sydney'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeSydneyV2.run "qiskit.providers.fake_provider.FakeSydneyV2.run") method. + + + +### props\_filename + +`= 'props_sydney.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTenerife.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTenerife.md new file mode 100644 index 00000000000..e025630f306 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTenerife.md @@ -0,0 +1,142 @@ +--- +title: FakeTenerife +description: API reference for qiskit.providers.fake_provider.FakeTenerife +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeTenerife +--- + +# FakeTenerife + + + +`qiskit.providers.fake_provider.FakeTenerife`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/tenerife/fake_tenerife.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake 5 qubit backend. + +```python + 1 + ↙ ↑ +0 ← 2 ← 3 + ↑ ↙ + 4 +``` + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeTenerife.run "qiskit.providers.fake_provider.FakeTenerife.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties as recorded on 8/30/19. + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTokyo.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTokyo.md new file mode 100644 index 00000000000..ee77b3b6054 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTokyo.md @@ -0,0 +1,144 @@ +--- +title: FakeTokyo +description: API reference for qiskit.providers.fake_provider.FakeTokyo +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeTokyo +--- + +# FakeTokyo + + + +`qiskit.providers.fake_provider.FakeTokyo`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/tokyo/fake_tokyo.py "view source code") + +Bases: [`FakeBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeBackend "qiskit.providers.fake_provider.fake_backend.FakeBackend") + +A fake 20 qubit backend. + +```python +00 ↔ 01 ↔ 02 ↔ 03 ↔ 04 + ↕ ↕ ↕ ↕ ⤫ ↕ +05 ↔ 06 ↔ 07 ↔ 08 ↔ 09 + ↕ ⤫ ↕ ↕ ⤫ ↕ +10 ↔ 11 ↔ 12 ↔ 13 ↔ 14 + ↕ ↕ ⤫ ↕ ⤫ ↕ +15 ↔ 16 ↔ 17 18 19 +``` + +## Attributes + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeTokyo.run "qiskit.providers.fake_provider.FakeTokyo.run") method. + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties as recorded on 8/30/19. + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeToronto.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeToronto.md new file mode 100644 index 00000000000..ae7fdf5a175 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeToronto.md @@ -0,0 +1,179 @@ +--- +title: FakeToronto +description: API reference for qiskit.providers.fake_provider.FakeToronto +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeToronto +--- + +# FakeToronto + + + +`qiskit.providers.fake_provider.FakeToronto`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/toronto/fake_toronto.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 27 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_toronto'` + + + +### conf\_filename + +`= 'conf_toronto.json'` + + + +### defs\_filename + +`= 'defs_toronto.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/toronto'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeToronto.run "qiskit.providers.fake_provider.FakeToronto.run") method. + + + +### props\_filename + +`= 'props_toronto.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTorontoV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTorontoV2.md new file mode 100644 index 00000000000..67871fc518c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeTorontoV2.md @@ -0,0 +1,351 @@ +--- +title: FakeTorontoV2 +description: API reference for qiskit.providers.fake_provider.FakeTorontoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeTorontoV2 +--- + +# FakeTorontoV2 + + + +`qiskit.providers.fake_provider.FakeTorontoV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/toronto/fake_toronto.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 27 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_toronto'` + + + +### conf\_filename + +`= 'conf_toronto.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_toronto.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/toronto'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeTorontoV2.run "qiskit.providers.fake_provider.FakeTorontoV2.run") method. + + + +### props\_filename + +`= 'props_toronto.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValencia.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValencia.md new file mode 100644 index 00000000000..9bf65823108 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValencia.md @@ -0,0 +1,179 @@ +--- +title: FakeValencia +description: API reference for qiskit.providers.fake_provider.FakeValencia +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeValencia +--- + +# FakeValencia + + + +`qiskit.providers.fake_provider.FakeValencia`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/valencia/fake_valencia.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 5 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_valencia'` + + + +### conf\_filename + +`= 'conf_valencia.json'` + + + +### defs\_filename + +`= 'defs_valencia.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/valencia'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeValencia.run "qiskit.providers.fake_provider.FakeValencia.run") method. + + + +### props\_filename + +`= 'props_valencia.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValenciaV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValenciaV2.md new file mode 100644 index 00000000000..571138ae955 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeValenciaV2.md @@ -0,0 +1,351 @@ +--- +title: FakeValenciaV2 +description: API reference for qiskit.providers.fake_provider.FakeValenciaV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeValenciaV2 +--- + +# FakeValenciaV2 + + + +`qiskit.providers.fake_provider.FakeValenciaV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/valencia/fake_valencia.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_valencia'` + + + +### conf\_filename + +`= 'conf_valencia.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_valencia.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/valencia'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeValenciaV2.run "qiskit.providers.fake_provider.FakeValenciaV2.run") method. + + + +### props\_filename + +`= 'props_valencia.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigo.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigo.md new file mode 100644 index 00000000000..08f64890972 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigo.md @@ -0,0 +1,171 @@ +--- +title: FakeVigo +description: API reference for qiskit.providers.fake_provider.FakeVigo +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeVigo +--- + +# FakeVigo + + + +`qiskit.providers.fake_provider.FakeVigo`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/vigo/fake_vigo.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_vigo'` + + + +### conf\_filename + +`= 'conf_vigo.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/vigo'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeVigo.run "qiskit.providers.fake_provider.FakeVigo.run") method. + + + +### props\_filename + +`= 'props_vigo.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigoV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigoV2.md new file mode 100644 index 00000000000..e19d42947ad --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeVigoV2.md @@ -0,0 +1,357 @@ +--- +title: FakeVigoV2 +description: API reference for qiskit.providers.fake_provider.FakeVigoV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeVigoV2 +--- + +# FakeVigoV2 + + + +`qiskit.providers.fake_provider.FakeVigoV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/vigo/fake_vigo.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +```python +0 ↔ 1 ↔ 3 ↔ 4 + ↕ + 2 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_vigo'` + + + +### conf\_filename + +`= 'conf_vigo.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/vigo'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeVigoV2.run "qiskit.providers.fake_provider.FakeVigoV2.run") method. + + + +### props\_filename + +`= 'props_vigo.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashington.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashington.md new file mode 100644 index 00000000000..692a131d72b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashington.md @@ -0,0 +1,179 @@ +--- +title: FakeWashington +description: API reference for qiskit.providers.fake_provider.FakeWashington +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeWashington +--- + +# FakeWashington + + + +`qiskit.providers.fake_provider.FakeWashington`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/washington/fake_washington.py "view source code") + +Bases: [`FakePulseBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakePulseBackend "qiskit.providers.fake_provider.fake_pulse_backend.FakePulseBackend") + +A fake 127 qubit backend. + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_washington'` + + + +### conf\_filename + +`= 'conf_washington.json'` + + + +### defs\_filename + +`= 'defs_washington.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/washington'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeWashington.run "qiskit.providers.fake_provider.FakeWashington.run") method. + + + +### props\_filename + +`= 'props_washington.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### defaults + + + +`defaults()` + +Returns a snapshot of device defaults + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashingtonV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashingtonV2.md new file mode 100644 index 00000000000..bb1b48fc453 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeWashingtonV2.md @@ -0,0 +1,351 @@ +--- +title: FakeWashingtonV2 +description: API reference for qiskit.providers.fake_provider.FakeWashingtonV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeWashingtonV2 +--- + +# FakeWashingtonV2 + + + +`qiskit.providers.fake_provider.FakeWashingtonV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/washington/fake_washington.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 127 qubit backend. + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_washington'` + + + +### conf\_filename + +`= 'conf_washington.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= 'defs_washington.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/washington'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeWashingtonV2.run "qiskit.providers.fake_provider.FakeWashingtonV2.run") method. + + + +### props\_filename + +`= 'props_washington.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktown.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktown.md new file mode 100644 index 00000000000..3806c7e9427 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktown.md @@ -0,0 +1,173 @@ +--- +title: FakeYorktown +description: API reference for qiskit.providers.fake_provider.FakeYorktown +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeYorktown +--- + +# FakeYorktown + + + +`qiskit.providers.fake_provider.FakeYorktown`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/yorktown/fake_yorktown.py "view source code") + +Bases: [`FakeQasmBackend`](providers_fake_provider#qiskit.providers.fake_provider.FakeQasmBackend "qiskit.providers.fake_provider.fake_qasm_backend.FakeQasmBackend") + +A fake 5 qubit backend. + +```python + 1 + / | +0 - 2 - 3 + | / + 4 +``` + +FakeBackend initializer. + +**Parameters** + +* **configuration** ([*BackendConfiguration*](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration")) – backend configuration +* **time\_alive** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – time to wait before returning result + +## Attributes + + + +### backend\_name + +`= 'fake_yorktown'` + + + +### conf\_filename + +`= 'conf_yorktown.json'` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/yorktown'` + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeYorktown.run "qiskit.providers.fake_provider.FakeYorktown.run") method. + + + +### props\_filename + +`= 'props_yorktown.json'` + + + +### version + +`= 1` + +## Methods + +### configuration + + + +`configuration()` + +Return the backend configuration. + +**Returns** + +the configuration for the backend. + +**Return type** + +[BackendConfiguration](qiskit.providers.models.BackendConfiguration "qiskit.providers.models.BackendConfiguration") + +### name + + + +`name()` + +Return the backend name. + +**Returns** + +the name of the backend. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### properties + + + +`properties()` + +Returns a snapshot of device properties + +### provider + + + +`provider()` + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + +### run + + + +`run(run_input, **kwargs)` + +Main job in simulator + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + +### status + + + +`status()` + +Return the backend status. + +**Returns** + +the status of the backend. + +**Return type** + +[BackendStatus](qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktownV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktownV2.md new file mode 100644 index 00000000000..631b917e9df --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.FakeYorktownV2.md @@ -0,0 +1,359 @@ +--- +title: FakeYorktownV2 +description: API reference for qiskit.providers.fake_provider.FakeYorktownV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.FakeYorktownV2 +--- + +# FakeYorktownV2 + + + +`qiskit.providers.fake_provider.FakeYorktownV2`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/backends/yorktown/fake_yorktown.py "view source code") + +Bases: [`FakeBackendV2`](providers_fake_provider#qiskit.providers.fake_provider.fake_backend.FakeBackendV2 "qiskit.providers.fake_provider.fake_backend.FakeBackendV2") + +A fake 5 qubit backend. + +```python + 1 + / | +0 - 2 - 3 + | / + 4 +``` + +FakeBackendV2 initializer. + + + The class `qiskit.providers.fake_provider.fake_backend.FakeBackendV2` is deprecated as of qiskit 0.46.0. It will be removed in qiskit 1.0. All fake backend instances based on real device snapshots (FakeVigo,\`FakeSherbrooke\`,…) have been migrated to the qiskit\_ibm\_runtime package. To migrate your code, run pip install qiskit-ibm-runtime and use from qiskit\_ibm\_runtime.fake\_provider import FakeExample instead of from qiskit.providers.fake\_provider import FakeExample. + + +## Attributes + + + +### backend\_name + +`= 'fake_yorktown'` + + + +### conf\_filename + +`= 'conf_yorktown.json'` + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### defs\_filename + +`= None` + + + +### dirname + +`= '/home/runner/work/qiskit/qiskit/qiskit/providers/fake_provider/backends/yorktown'` + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + +**Returns** + +The output signal timestep in seconds. + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + +Return the grouping of measurements which are multiplexed This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The grouping of measurements which are multiplexed + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.FakeYorktownV2.run "qiskit.providers.fake_provider.FakeYorktownV2.run") method. + + + +### props\_filename + +`= 'props_yorktown.json'` + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + +A [`qiskit.transpiler.Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object for the backend. + +**Return type** + +[Target](qiskit.transpiler.Target "qiskit.transpiler.Target") + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the fake backend using a simulator. + +This method runs circuit jobs (an individual or a list of QuantumCircuit ) and pulse jobs (an individual or a list of Schedule or ScheduleBlock) using a [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using AerSimulator with noise model of the fake backend. Otherwise, jobs will be run using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") without noise. + +Currently noisy simulation of a pulse job is not supported yet in FakeBackendV2. + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit-aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.fake_provider.GenericBackendV2.md b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.GenericBackendV2.md new file mode 100644 index 00000000000..afa45f5f975 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.fake_provider.GenericBackendV2.md @@ -0,0 +1,354 @@ +--- +title: GenericBackendV2 +description: API reference for qiskit.providers.fake_provider.GenericBackendV2 +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.fake_provider.GenericBackendV2 +--- + +# GenericBackendV2 + + + +`qiskit.providers.fake_provider.GenericBackendV2(num_qubits, basis_gates=None, *, coupling_map=None, control_flow=False, calibrate_instructions=None, dtm=None, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/fake_provider/generic_backend_v2.py "view source code") + +Bases: [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") + +Generic [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") implementation with a configurable constructor. This class will return a [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") instance that runs on a local simulator (in the spirit of fake backends) and contains all the necessary information to test backend-interfacing components, such as the transpiler. A [`GenericBackendV2`](#qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2") instance can be constructed from as little as a specified `num_qubits`, but users can additionally configure the basis gates, coupling map, ability to run dynamic circuits (control flow instructions), instruction calibrations and dtm. The remainder of the backend properties are generated by randomly sampling from default ranges extracted from historical IBM backend data. The seed for this random generation can be fixed to ensure the reproducibility of the backend output. This backend only supports gates in the standard library, if you need a more flexible backend, there is always the option to directly instantiate a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object to use for transpilation. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of qubits that will be used to construct the backend’s target. Note that, while there is no limit in the size of the target that can be constructed, this backend runs on local noisy simulators, and these might present limitations in the number of qubits that can be simulated. + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – List of basis gate names to be supported by the target. These must be part of the standard qiskit circuit library. The default set of basis gates is `["id", "rz", "sx", "x", "cx"]` The `"reset"`, `"delay"`, and `"measure"` instructions are always supported by default, even if not specified via `basis_gates`. + +* **coupling\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] |* [*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") *| None*) – + + Optional coupling map for the backend. Multiple formats are supported: + + 1. [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") instance + 2. List, must be given as an edge list representing the two qubit interactions supported by the backend, for example: `[[0, 1], [0, 3], [1, 2], [1, 5], [2, 5], [4, 1], [5, 3]]` + + If `coupling_map` is specified, it must match the number of qubits specified in `num_qubits`. If `coupling_map` is not specified, a fully connected coupling map will be generated with `num_qubits` qubits. + +* **control\_flow** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Flag to enable control flow directives on the target (defaults to False). + +* **calibrate\_instructions** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *|*[*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") *| None*) – + + Instruction calibration settings, this argument supports both boolean and [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") as input types, and is `None` by default: + + 1. If `calibrate_instructions==None`, no calibrations will be added to the target. + + 2. **If `calibrate_instructions==True`, all gates will be calibrated for all** + + qubits using the default pulse schedules generated internally. + + 3. **If `calibrate_instructions==False`, all gates will be “calibrated” for** + + all qubits with an empty pulse schedule. + + 4. **If an [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") instance is given, the calibrations** + + in this instruction schedule map will be appended to the target instead of the default pulse schedules (this allows for custom calibrations). + +* **dtm** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – System time resolution of output signals in nanoseconds. None by default. + +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional seed for generation of default values. + +## Attributes + + + +### coupling\_map + +Return the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object + + + +### dt + +Return the system time resolution of input signals + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The input signal timestep in seconds. If the backend doesn’t define `dt`, `None` will be returned. + + + +### dtm + +Return the system time resolution of output signals + + + +### instruction\_durations + +Return the [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object. + + + +### instruction\_schedule\_map + +Return the [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions defined in this backend’s target. + + + +### instructions + +A list of Instruction tuples on the backend of the form `(instruction, (qubits)` + + + +### max\_circuits + + + +### meas\_map + + + +### num\_qubits + +Return the number of qubits the backend has. + + + +### operation\_names + +A list of instruction names that the backend supports. + + + +### operations + +A list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that the backend supports. + + + +### options + +Return the options for the backend + +The options of a backend are the dynamic parameters defining how the backend is used. These are used to control the [`run()`](#qiskit.providers.fake_provider.GenericBackendV2.run "qiskit.providers.fake_provider.GenericBackendV2.run") method. + + + +### provider + +Return the backend Provider. + +**Returns** + +the Provider responsible for the backend. + +**Return type** + +[Provider](qiskit.providers.Provider "qiskit.providers.Provider") + + + +### target + + + +### version + +`= 2` + + + +### name + +Name of the backend. + + + +### description + +Optional human-readable description. + + + +### online\_date + +Date that the backend came online. + + + +### backend\_version + +Version of the backend being provided. This is not the same as [`BackendV2.version`](qiskit.providers.BackendV2#version "qiskit.providers.BackendV2.version"), which is the version of the [`Backend`](qiskit.providers.Backend "qiskit.providers.Backend") abstract interface. + +## Methods + +### acquire\_channel + + + +`acquire_channel(qubit)` + +Return the acquisition channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement acquisition line. + +**Return type** + +[AcquireChannel](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### control\_channel + + + +`control_channel(qubits)` + +Return the secondary drive channel for the given qubit + +This is typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Tuple or list of qubits of the form `(control_qubit, target_qubit)`. + +**Returns** + +The multi qubit control line. + +**Return type** + +List\[[ControlChannel](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### drive\_channel + + + +`drive_channel(qubit)` + +Return the drive channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit drive channel + +**Return type** + +[DriveChannel](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### measure\_channel + + + +`measure_channel(qubit)` + +Return the measure stimulus channel for the given qubit. + +This is required to be implemented if the backend supports Pulse scheduling. + +**Returns** + +The Qubit measurement stimulus line + +**Return type** + +[MeasureChannel](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the measurement mapping + +### qubit\_properties + + + +`qubit_properties(qubit)` + +Return QubitProperties for a given qubit. + +If there are no defined or the backend doesn’t support querying these details this method does not need to be implemented. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubit to get the [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for. This can be a single integer for 1 qubit or a list of qubits and a list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects will be returned in the same order + +**Returns** + +The [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") object for the specified qubit. If a list of qubits is provided a list will be returned. If properties are missing for a qubit this can be `None`. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – if the backend doesn’t support querying the qubit properties + +**Return type** + +[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties") | [*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QubitProperties*](qiskit.providers.QubitProperties "qiskit.providers.backend.QubitProperties")] + +### run + + + +`run(run_input, **options)` + +Run on the backend using a simulator. + +This method runs circuit jobs (an individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") ) and pulse jobs (an individual or a list of [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") or [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")) using [`BasicSimulator`](qiskit.providers.basic_provider.BasicSimulator "qiskit.providers.basic_provider.BasicSimulator") or Aer simulator and returns a [`Job`](qiskit.providers.Job "qiskit.providers.Job") object. + +If qiskit-aer is installed, jobs will be run using the `AerSimulator` with noise model of the backend. Otherwise, jobs will be run using the `BasicSimulator` simulator without noise. + +Noisy simulations of pulse jobs are not yet supported in [`GenericBackendV2`](#qiskit.providers.fake_provider.GenericBackendV2 "qiskit.providers.fake_provider.GenericBackendV2"). + +**Parameters** + +* **run\_input** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An individual or a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"), or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") objects to run on the backend. +* **options** – Any kwarg options to pass to the backend for running the config. If a key is also present in the options attribute/object, then the expectation is that the value specified will be used instead of what’s set in the options object. + +**Returns** + +The job object for the run + +**Return type** + +[Job](qiskit.providers.Job "qiskit.providers.Job") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a pulse job is supplied and qiskit\_aer is not installed. + +### set\_options + + + +`set_options(**fields)` + +Set the options fields for the backend + +This method is used to update the options of a backend. If you need to change any of the options prior to running just pass in the kwarg with the new value for the options. + +**Parameters** + +**fields** – The fields to update the options + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the field passed in is not part of the options + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.BackendConfiguration.md b/docs/api/qiskit/0.46/qiskit.providers.models.BackendConfiguration.md new file mode 100644 index 00000000000..b63ab408201 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.BackendConfiguration.md @@ -0,0 +1,138 @@ +--- +title: BackendConfiguration +description: API reference for qiskit.providers.models.BackendConfiguration +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.BackendConfiguration +--- + +# BackendConfiguration + + + +`qiskit.providers.models.BackendConfiguration(backend_name, backend_version, n_qubits, basis_gates, gates, local, simulator, conditional, open_pulse, memory, max_shots, coupling_map, supported_instructions=None, dynamic_reprate_enabled=False, rep_delay_range=None, default_rep_delay=None, max_experiments=None, sample_name=None, n_registers=None, register_map=None, configurable=None, credits_required=None, online_date=None, display_name=None, description=None, tags=None, dt=None, dtm=None, processor_type=None, parametric_pulses=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendconfiguration.py "view source code") + +Bases: [`QasmBackendConfiguration`](qiskit.providers.models.QasmBackendConfiguration "qiskit.providers.models.backendconfiguration.QasmBackendConfiguration") + +Backwards compat shim representing an abstract backend configuration. + +Initialize a QasmBackendConfiguration Object + +**Parameters** + +* **backend\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The backend name + +* **backend\_version** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The backend version in the form X.Y.Z + +* **n\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits for the backend + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The list of strings for the basis gates of the backends + +* **gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The list of GateConfig objects for the basis gates of the backend + +* **local** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is local or False if remote + +* **simulator** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is a simulator + +* **conditional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend supports conditional operations + +* **open\_pulse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend supports OpenPulse + +* **memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend supports memory + +* **max\_shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of shots allowed on the backend + +* **coupling\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The coupling map for the device + +* **supported\_instructions** (*List\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Instructions supported by the backend. + +* **dynamic\_reprate\_enabled** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether delay between programs can be set dynamically (ie via `rep_delay`). Defaults to False. + +* **rep\_delay\_range** (*List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – 2d list defining supported range of repetition delays for backend in μs. First entry is lower end of the range, second entry is higher end of the range. Optional, but will be specified when `dynamic_reprate_enabled=True`. + +* **default\_rep\_delay** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value of `rep_delay` if not specified by user and `dynamic_reprate_enabled=True`. + +* **max\_experiments** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of experiments per job + +* **sample\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Sample name for the backend + +* **n\_registers** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of register slots available for feedback (if conditional is True) + +* **register\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An array of dimension n\_qubits X n\_registers that specifies whether a qubit can store a measurement in a certain register slot. + +* **configurable** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is configurable, if the backend is a simulator + +* **credits\_required** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if backend requires credits to run a job. + +* **online\_date** ([*datetime.datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)")) – The date that the device went online + +* **display\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Alternate name field for the backend + +* **description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A description for the backend + +* **tags** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of string tags to describe the backend + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Qubit drive channel timestep in nanoseconds. + +* **dtm** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Measurement drive channel timestep in nanoseconds. + +* **processor\_type** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + + Processor type for this backend. A dictionary of the form `{"family": , "revision": , segment: }` such as `{"family": "Canary", "revision": "1.0", segment: "A"}`. + + * family: Processor family of this backend. + * revision: Revision version of this processor. + * segment: Segment this processor belongs to within a larger chip. + +* **parametric\_pulses** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of pulse shapes which are supported on the backend. For example: `['gaussian', 'constant']` + +* **\*\*kwargs** – optional fields + +## Attributes + + + +### num\_qubits + +Returns the number of qubits. + +In future, n\_qubits should be replaced in favor of num\_qubits for consistent use throughout Qiskit. Until this is properly refactored, this property serves as intermediate solution. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new GateConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the GateConfig to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.BackendConfiguration.to_dict "qiskit.providers.models.BackendConfiguration.to_dict"). + +**Returns** + +The GateConfig from the input dictionary. + +**Return type** + +[GateConfig](qiskit.providers.models.GateConfig "qiskit.providers.models.GateConfig") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the GateConfig. + +**Returns** + +The dictionary form of the GateConfig. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.BackendProperties.md b/docs/api/qiskit/0.46/qiskit.providers.models.BackendProperties.md new file mode 100644 index 00000000000..b29342ef9bd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.BackendProperties.md @@ -0,0 +1,320 @@ +--- +title: BackendProperties +description: API reference for qiskit.providers.models.BackendProperties +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.BackendProperties +--- + +# BackendProperties + + + +`qiskit.providers.models.BackendProperties(backend_name, backend_version, last_update_date, qubits, gates, general, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendproperties.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing backend properties + +This holds backend properties measured by the provider. All properties which are provided optionally. These properties may describe qubits, gates, or other general properties of the backend. + +Initialize a BackendProperties instance. + +**Parameters** + +* **backend\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Backend name. +* **backend\_version** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Backend version in the form X.Y.Z. +* **last\_update\_date** ([*datetime.datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Last date/time that a property was updated. If specified as a `str`, it must be in ISO format. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – System qubit parameters as a list of lists of [`Nduv`](qiskit.providers.models.Nduv "qiskit.providers.models.Nduv") objects +* **gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – System gate parameters as a list of [`GateProperties`](qiskit.providers.models.GateProperties "qiskit.providers.models.GateProperties") objects +* **general** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – General parameters as a list of [`Nduv`](qiskit.providers.models.Nduv "qiskit.providers.models.Nduv") objects +* **kwargs** – optional additional fields + +## Methods + +### faulty\_gates + + + +`faulty_gates()` + +Return a list of faulty gates. + +### faulty\_qubits + + + +`faulty_qubits()` + +Return a list of faulty qubits. + +### frequency + + + +`frequency(qubit)` + +Return the frequency of the given qubit. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubit for which to return frequency of. + +**Returns** + +Frequency of the given qubit. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new BackendProperties object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the BackendProperties to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.BackendProperties.to_dict "qiskit.providers.models.BackendProperties.to_dict"). + +**Returns** + +The BackendProperties from the input dictionary. + +**Return type** + +[BackendProperties](#qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") + +### gate\_error + + + +`gate_error(gate, qubits)` + +Return gate error estimates from backend properties. + +**Parameters** + +* **gate** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The gate for which to get the error. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The specific qubits for the gate. + +**Returns** + +Gate error of the given gate and qubit(s). + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### gate\_length + + + +`gate_length(gate, qubits)` + +Return the duration of the gate in units of seconds. + +**Parameters** + +* **gate** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The gate for which to get the duration. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The specific qubits for the gate. + +**Returns** + +Gate length of the given gate and qubit(s). + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### gate\_property + + + +`gate_property(gate, qubits=None, name=None)` + +Return the property of the given gate. + +**Parameters** + +* **gate** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of the gate. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – The qubit to find the property for. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Optionally used to specify which gate property to return. + +**Returns** + +Gate property as a tuple of the value and the time it was measured. + +**Raises** + +[**BackendPropertyError**](providers#qiskit.providers.BackendPropertyError "qiskit.providers.BackendPropertyError") – If the property is not found or name is specified but qubit is not. + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [*datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)")] + +### is\_gate\_operational + + + +`is_gate_operational(gate, qubits=None)` + +Return the operational status of the given gate. + +**Parameters** + +* **gate** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of the gate. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – The qubit to find the operational status for. + +**Returns** + +Operational status of the given gate. True if the gate is operational, False otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_qubit\_operational + + + +`is_qubit_operational(qubit)` + +Return the operational status of the given qubit. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubit for which to return operational status of. + +**Returns** + +Operational status of the given qubit. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### qubit\_property + + + +`qubit_property(qubit, name=None)` + +Return the property of the given qubit. + +**Parameters** + +* **qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The property to look for. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Optionally used to specify within the hierarchy which property to return. + +**Returns** + +Qubit property as a tuple of the value and the time it was measured. + +**Raises** + +[**BackendPropertyError**](providers#qiskit.providers.BackendPropertyError "qiskit.providers.BackendPropertyError") – If the property is not found. + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [*datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)")] + +### readout\_error + + + +`readout_error(qubit)` + +Return the readout error of the given qubit. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubit for which to return the readout error of. + +**Returns** + +Readout error of the given qubit. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### readout\_length + + + +`readout_length(qubit)` + +Return the readout length \[sec] of the given qubit. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubit for which to return the readout length of. + +**Returns** + +Readout length of the given qubit. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### t1 + + + +`t1(qubit)` + +Return the T1 time of the given qubit. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubit for which to return the T1 time of. + +**Returns** + +T1 time of the given qubit. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### t2 + + + +`t2(qubit)` + +Return the T2 time of the given qubit. + +**Parameters** + +**qubit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubit for which to return the T2 time of. + +**Returns** + +T2 time of the given qubit. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the BackendProperties. + +**Returns** + +The dictionary form of the BackendProperties. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.BackendStatus.md b/docs/api/qiskit/0.46/qiskit.providers.models.BackendStatus.md new file mode 100644 index 00000000000..7cbf0fa6907 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.BackendStatus.md @@ -0,0 +1,70 @@ +--- +title: BackendStatus +description: API reference for qiskit.providers.models.BackendStatus +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.BackendStatus +--- + +# BackendStatus + + + +`qiskit.providers.models.BackendStatus(backend_name, backend_version, operational, pending_jobs, status_msg)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendstatus.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing Backend Status. + +Initialize a BackendStatus object + +**Parameters** + +* **backend\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The backend’s name +* **backend\_version** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The backend’s version of the form X.Y.Z +* **operational** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is operational +* **pending\_jobs** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of pending jobs on the backend +* **status\_msg** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The status msg for the backend + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the backend version is in an invalid format + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new BackendStatus object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the BaseBakend to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.BackendStatus.to_dict "qiskit.providers.models.BackendStatus.to_dict"). + +**Returns** + +The BackendStatus from the input dictionary. + +**Return type** + +[BackendStatus](#qiskit.providers.models.BackendStatus "qiskit.providers.models.BackendStatus") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the BackendStatus. + +**Returns** + +The dictionary form of the QobjHeader. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.Command.md b/docs/api/qiskit/0.46/qiskit.providers.models.Command.md new file mode 100644 index 00000000000..50a6ba8a580 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.Command.md @@ -0,0 +1,71 @@ +--- +title: Command +description: API reference for qiskit.providers.models.Command +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.Command +--- + +# Command + + + +`qiskit.providers.models.Command(name, qubits=None, sequence=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/pulsedefaults.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing a Command. + + + +### name + +Pulse command name. + +Initialize a Command object + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the command +* **qubits** – The qubits for the command +* **sequence** ([*PulseQobjInstruction*](qiskit.qobj.PulseQobjInstruction "qiskit.qobj.PulseQobjInstruction")) – The sequence for the Command +* **kwargs** – Optional additional fields + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new Command object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the `Command` to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.Command.to_dict "qiskit.providers.models.Command.to_dict"). + +**Returns** + +The `Command` from the input dictionary. + +**Return type** + +[Command](#qiskit.providers.models.Command "qiskit.providers.models.Command") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Command. + +**Returns** + +The dictionary form of the Command. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.GateConfig.md b/docs/api/qiskit/0.46/qiskit.providers.models.GateConfig.md new file mode 100644 index 00000000000..4ddad930d1d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.GateConfig.md @@ -0,0 +1,86 @@ +--- +title: GateConfig +description: API reference for qiskit.providers.models.GateConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.GateConfig +--- + +# GateConfig + + + +`qiskit.providers.models.GateConfig(name, parameters, qasm_def, coupling_map=None, latency_map=None, conditional=None, description=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendconfiguration.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing a Gate Configuration + + + +### name + +the gate name as it will be referred to in OpenQASM. + + + +### parameters + +variable names for the gate parameters (if any). + + + +### qasm\_def + +definition of this gate in terms of OpenQASM 2 primitives U and CX. + +Initialize a GateConfig object + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the gate name as it will be referred to in OpenQASM. +* **parameters** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – variable names for the gate parameters (if any) as a list of strings. +* **qasm\_def** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – definition of this gate in terms of OpenQASM 2 primitives U and CX. +* **coupling\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An optional coupling map for the gate. In the form of a list of lists of integers representing the qubit groupings which are coupled by this gate. +* **latency\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An optional map of latency for the gate. In the the form of a list of lists of integers of either 0 or 1 representing an array of dimension len(coupling\_map) X n\_registers that specifies the register latency (1: fast, 0: slow) conditional operations on the gate +* **conditional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optionally specify whether this gate supports conditional operations (true/false). If this is not specified, then the gate inherits the conditional property of the backend. +* **description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Description of the gate operation + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new GateConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the GateConfig to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.GateConfig.to_dict "qiskit.providers.models.GateConfig.to_dict"). + +**Returns** + +The GateConfig from the input dictionary. + +**Return type** + +[GateConfig](#qiskit.providers.models.GateConfig "qiskit.providers.models.GateConfig") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the GateConfig. + +**Returns** + +The dictionary form of the GateConfig. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.GateProperties.md b/docs/api/qiskit/0.46/qiskit.providers.models.GateProperties.md new file mode 100644 index 00000000000..3fa85cb86c5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.GateProperties.md @@ -0,0 +1,83 @@ +--- +title: GateProperties +description: API reference for qiskit.providers.models.GateProperties +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.GateProperties +--- + +# GateProperties + + + +`qiskit.providers.models.GateProperties(qubits, gate, parameters, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendproperties.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing a gate’s properties + + + +### qubits + +qubits. + + + +### gate + +gate. + + + +### parameters + +parameters. + +Initialize a new [`GateProperties`](#qiskit.providers.models.GateProperties "qiskit.providers.models.GateProperties") object + +**Parameters** + +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of integers representing qubits +* **gate** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The gates name +* **parameters** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of [`Nduv`](qiskit.providers.models.Nduv "qiskit.providers.models.Nduv") objects for the name-date-unit-value for the gate +* **kwargs** – Optional additional fields + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new Gate object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the Gate to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.GateProperties.to_dict "qiskit.providers.models.GateProperties.to_dict"). + +**Returns** + +The Nduv from the input dictionary. + +**Return type** + +[GateProperties](#qiskit.providers.models.GateProperties "qiskit.providers.models.GateProperties") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the BackendStatus. + +**Returns** + +The dictionary form of the Gate. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.JobStatus.md b/docs/api/qiskit/0.46/qiskit.providers.models.JobStatus.md new file mode 100644 index 00000000000..55c464b936b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.JobStatus.md @@ -0,0 +1,86 @@ +--- +title: JobStatus +description: API reference for qiskit.providers.models.JobStatus +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.JobStatus +--- + +# JobStatus + + + +`qiskit.providers.models.JobStatus(job_id, status, status_msg, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/jobstatus.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Model for JobStatus. + + + +### job\_id + +backend job\_id. + +**Type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + +### status + +status of the job. + +**Type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + +### status\_msg + +status message. + +**Type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new JobStatus object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the JobStatus to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.JobStatus.to_dict "qiskit.providers.models.JobStatus.to_dict"). + +**Returns** + +The `JobStatus` from the input dictionary. + +**Return type** + +[JobStatus](#qiskit.providers.models.JobStatus "qiskit.providers.models.JobStatus") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the JobStatus. + +**Returns** + +The dictionary form of the JobStatus. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.Nduv.md b/docs/api/qiskit/0.46/qiskit.providers.models.Nduv.md new file mode 100644 index 00000000000..2465fedf57e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.Nduv.md @@ -0,0 +1,89 @@ +--- +title: Nduv +description: API reference for qiskit.providers.models.Nduv +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.Nduv +--- + +# Nduv + + + +`qiskit.providers.models.Nduv(date, name, unit, value)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendproperties.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing name-date-unit-value + + + +### date + +date. + + + +### name + +name. + + + +### unit + +unit. + + + +### value + +value. + +Initialize a new name-date-unit-value object + +**Parameters** + +* **date** ([*datetime.datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)")) – Date field +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name field +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Nduv unit +* **value** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The value of the Nduv + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new Nduv object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the Nduv to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.Nduv.to_dict "qiskit.providers.models.Nduv.to_dict"). + +**Returns** + +The Nduv from the input dictionary. + +**Return type** + +[Nduv](#qiskit.providers.models.Nduv "qiskit.providers.models.Nduv") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the object. + +**Returns** + +The dictionary form of the Nduv. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.PulseBackendConfiguration.md b/docs/api/qiskit/0.46/qiskit.providers.models.PulseBackendConfiguration.md new file mode 100644 index 00000000000..545750b3068 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.PulseBackendConfiguration.md @@ -0,0 +1,284 @@ +--- +title: PulseBackendConfiguration +description: API reference for qiskit.providers.models.PulseBackendConfiguration +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.PulseBackendConfiguration +--- + +# PulseBackendConfiguration + + + +`qiskit.providers.models.PulseBackendConfiguration(backend_name, backend_version, n_qubits, basis_gates, gates, local, simulator, conditional, open_pulse, memory, max_shots, coupling_map, n_uchannels, u_channel_lo, meas_levels, qubit_lo_range, meas_lo_range, dt, dtm, rep_times, meas_kernels, discriminators, hamiltonian=None, channel_bandwidth=None, acquisition_latency=None, conditional_latency=None, meas_map=None, max_experiments=None, sample_name=None, n_registers=None, register_map=None, configurable=None, credits_required=None, online_date=None, display_name=None, description=None, tags=None, channels=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendconfiguration.py "view source code") + +Bases: [`QasmBackendConfiguration`](qiskit.providers.models.QasmBackendConfiguration "qiskit.providers.models.backendconfiguration.QasmBackendConfiguration") + +Static configuration state for an OpenPulse enabled backend. This contains information about the set up of the device which can be useful for building Pulse programs. + +Initialize a backend configuration that contains all the extra configuration that is made available for OpenPulse backends. + +**Parameters** + +* **backend\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – backend name. +* **backend\_version** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – backend version in the form X.Y.Z. +* **n\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **basis\_gates** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – list of basis gates names on the backend. +* **gates** ([*GateConfig*](qiskit.providers.models.GateConfig "qiskit.providers.models.backendconfiguration.GateConfig")) – list of basis gates on the backend. +* **local** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – backend is local or remote. +* **simulator** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – backend is a simulator. +* **conditional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – backend supports conditional operations. +* **open\_pulse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – backend supports open pulse. +* **memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – backend supports memory. +* **max\_shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – maximum number of shots supported. +* **coupling\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The coupling map for the device +* **n\_uchannels** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of u-channels. +* **u\_channel\_lo** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*UchannelLO*](qiskit.providers.models.UchannelLO "qiskit.providers.models.backendconfiguration.UchannelLO")*]]*) – U-channel relationship on device los. +* **meas\_levels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Supported measurement levels. +* **qubit\_lo\_range** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – Qubit lo ranges for each qubit with form (min, max) in GHz. +* **meas\_lo\_range** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]]*) – Measurement lo ranges for each qubit with form (min, max) in GHz. +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Qubit drive channel timestep in nanoseconds. +* **dtm** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Measurement drive channel timestep in nanoseconds. +* **rep\_times** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – Supported repetition times (program execution time) for backend in μs. +* **meas\_kernels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Supported measurement kernels. +* **discriminators** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Supported discriminators. +* **hamiltonian** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*]*) – An optional dictionary with fields characterizing the system hamiltonian. +* **channel\_bandwidth** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Bandwidth of all channels (qubit, measurement, and U) +* **acquisition\_latency** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Array of dimension n\_qubits x n\_registers. Latency (in units of dt) to write a measurement result from qubit n into register slot m. +* **conditional\_latency** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Array of dimension n\_channels \[d->u->m] x n\_registers. Latency (in units of dt) to do a conditional operation on channel n from register slot m +* **meas\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Grouping of measurement which are multiplexed +* **max\_experiments** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of experiments per job +* **sample\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Sample name for the backend +* **n\_registers** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of register slots available for feedback (if conditional is True) +* **register\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An array of dimension n\_qubits X n\_registers that specifies whether a qubit can store a measurement in a certain register slot. +* **configurable** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is configurable, if the backend is a simulator +* **credits\_required** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if backend requires credits to run a job. +* **online\_date** ([*datetime.datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)")) – The date that the device went online +* **display\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Alternate name field for the backend +* **description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A description for the backend +* **tags** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of string tags to describe the backend +* **channels** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*]*) – An optional dictionary containing information of each channel – their purpose, type, and qubits operated on. +* **\*\*kwargs** – Optional fields. + +## Attributes + + + +### control\_channels + +Return the control channels + + + +### num\_qubits + +Returns the number of qubits. + +In future, n\_qubits should be replaced in favor of num\_qubits for consistent use throughout Qiskit. Until this is properly refactored, this property serves as intermediate solution. + + + +### sample\_rate + +Sample rate of the signal channels in Hz (1/dt). + +## Methods + +### acquire + + + +`acquire(qubit)` + +Return the acquisition channel for the given qubit. + +**Raises** + +[**BackendConfigurationError**](providers#qiskit.providers.BackendConfigurationError "qiskit.providers.BackendConfigurationError") – If the qubit is not a part of the system. + +**Returns** + +Qubit measurement acquisition line. + +**Return type** + +[*AcquireChannel*](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") + +### control + + + +`control(qubits=None)` + +Return the secondary drive channel for the given qubit – typically utilized for controlling multiqubit interactions. This channel is derived from other channels. + +**Parameters** + +**qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Tuple or list of qubits of the form (control\_qubit, target\_qubit). + +**Raises** + +[**BackendConfigurationError**](providers#qiskit.providers.BackendConfigurationError "qiskit.providers.BackendConfigurationError") – If the `qubits` is not a part of the system or if the backend does not provide channels information in its configuration. + +**Returns** + +List of control channels. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*ControlChannel*](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")] + +### describe + + + +`describe(channel)` + +Return a basic description of the channel dependency. Derived channels are given weights which describe how their frames are linked to other frames. For instance, the backend could be configured with this setting: + +```python +u_channel_lo = [ + [UchannelLO(q=0, scale=1. + 0.j)], + [UchannelLO(q=0, scale=-1. + 0.j), UchannelLO(q=1, scale=1. + 0.j)] +] +``` + +Then, this method can be used as follows: + +```python +backend.configuration().describe(ControlChannel(1)) +>>> {DriveChannel(0): -1, DriveChannel(1): 1} +``` + +**Parameters** + +**channel** ([*ControlChannel*](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel")) – The derived channel to describe. + +**Raises** + +[**BackendConfigurationError**](providers#qiskit.providers.BackendConfigurationError "qiskit.providers.BackendConfigurationError") – If channel is not a ControlChannel. + +**Returns** + +Control channel derivations. + +**Return type** + +[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")\[[*DriveChannel*](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel"), [complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")] + +### drive + + + +`drive(qubit)` + +Return the drive channel for the given qubit. + +**Raises** + +[**BackendConfigurationError**](providers#qiskit.providers.BackendConfigurationError "qiskit.providers.BackendConfigurationError") – If the qubit is not a part of the system. + +**Returns** + +Qubit drive channel. + +**Return type** + +[*DriveChannel*](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new GateConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the GateConfig to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.PulseBackendConfiguration.to_dict "qiskit.providers.models.PulseBackendConfiguration.to_dict"). + +**Returns** + +The GateConfig from the input dictionary. + +**Return type** + +[GateConfig](qiskit.providers.models.GateConfig "qiskit.providers.models.GateConfig") + +### get\_channel\_qubits + + + +`get_channel_qubits(channel)` + +Return a list of indices for qubits which are operated on directly by the given `channel`. + +**Raises** + +[**BackendConfigurationError**](providers#qiskit.providers.BackendConfigurationError "qiskit.providers.BackendConfigurationError") – If `channel` is not a found or if the backend does not provide channels information in its configuration. + +**Returns** + +List of qubits operated on my the given `channel`. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + +### get\_qubit\_channels + + + +`get_qubit_channels(qubit)` + +Return a list of channels which operate on the given `qubit`. + +**Raises** + +[**BackendConfigurationError**](providers#qiskit.providers.BackendConfigurationError "qiskit.providers.BackendConfigurationError") – If `qubit` is not a found or if the backend does not provide channels information in its configuration. + +**Returns** + +List of `Channel`s operated on my the given `qubit`. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")] + +### measure + + + +`measure(qubit)` + +Return the measure stimulus channel for the given qubit. + +**Raises** + +[**BackendConfigurationError**](providers#qiskit.providers.BackendConfigurationError "qiskit.providers.BackendConfigurationError") – If the qubit is not a part of the system. + +**Returns** + +Qubit measurement stimulus line. + +**Return type** + +[*MeasureChannel*](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the GateConfig. + +**Returns** + +The dictionary form of the GateConfig. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.PulseDefaults.md b/docs/api/qiskit/0.46/qiskit.providers.models.PulseDefaults.md new file mode 100644 index 00000000000..f17521e10fa --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.PulseDefaults.md @@ -0,0 +1,64 @@ +--- +title: PulseDefaults +description: API reference for qiskit.providers.models.PulseDefaults +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.PulseDefaults +--- + +# PulseDefaults + + + +`qiskit.providers.models.PulseDefaults(qubit_freq_est, meas_freq_est, buffer, pulse_library, cmd_def, meas_kernel=None, discriminator=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/pulsedefaults.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Description of default settings for Pulse systems. These are instructions or settings that may be good starting points for the Pulse user. The user may modify these defaults for custom scheduling. + +Validate and reformat transport layer inputs to initialize. :param qubit\_freq\_est: Estimated qubit frequencies in GHz. :param meas\_freq\_est: Estimated measurement cavity frequencies in GHz. :param buffer: Default buffer time (in units of dt) between pulses. :param pulse\_library: Pulse name and sample definitions. :param cmd\_def: Operation name and definition in terms of Commands. :param meas\_kernel: The measurement kernels :param discriminator: The discriminators :param \*\*kwargs: Other attributes for the super class. + +## Attributes + + + +### qubit\_freq\_est + +Qubit frequencies in Hertz. + + + +### meas\_freq\_est + +Measurement frequencies in Hertz. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new PulseDefaults object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the PulseDefaults to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.PulseDefaults.to_dict "qiskit.providers.models.PulseDefaults.to_dict"). + +**Returns** + +The PulseDefaults from the input dictionary. + +**Return type** + +[PulseDefaults](#qiskit.providers.models.PulseDefaults "qiskit.providers.models.PulseDefaults") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the PulseDefaults. :returns: The dictionary form of the PulseDefaults. :rtype: dict + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.QasmBackendConfiguration.md b/docs/api/qiskit/0.46/qiskit.providers.models.QasmBackendConfiguration.md new file mode 100644 index 00000000000..83aa9a1c171 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.QasmBackendConfiguration.md @@ -0,0 +1,204 @@ +--- +title: QasmBackendConfiguration +description: API reference for qiskit.providers.models.QasmBackendConfiguration +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.QasmBackendConfiguration +--- + +# QasmBackendConfiguration + + + +`qiskit.providers.models.QasmBackendConfiguration(backend_name, backend_version, n_qubits, basis_gates, gates, local, simulator, conditional, open_pulse, memory, max_shots, coupling_map, supported_instructions=None, dynamic_reprate_enabled=False, rep_delay_range=None, default_rep_delay=None, max_experiments=None, sample_name=None, n_registers=None, register_map=None, configurable=None, credits_required=None, online_date=None, display_name=None, description=None, tags=None, dt=None, dtm=None, processor_type=None, parametric_pulses=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendconfiguration.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing an OpenQASM 2.0 Backend Configuration. + + + +### backend\_name + +backend name. + + + +### backend\_version + +backend version in the form X.Y.Z. + + + +### n\_qubits + +number of qubits. + + + +### basis\_gates + +list of basis gates names on the backend. + + + +### gates + +list of basis gates on the backend. + + + +### local + +backend is local or remote. + + + +### simulator + +backend is a simulator. + + + +### conditional + +backend supports conditional operations. + + + +### open\_pulse + +backend supports open pulse. + + + +### memory + +backend supports memory. + + + +### max\_shots + +maximum number of shots supported. + +Initialize a QasmBackendConfiguration Object + +**Parameters** + +* **backend\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The backend name + +* **backend\_version** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The backend version in the form X.Y.Z + +* **n\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits for the backend + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The list of strings for the basis gates of the backends + +* **gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The list of GateConfig objects for the basis gates of the backend + +* **local** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is local or False if remote + +* **simulator** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is a simulator + +* **conditional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend supports conditional operations + +* **open\_pulse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend supports OpenPulse + +* **memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend supports memory + +* **max\_shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of shots allowed on the backend + +* **coupling\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The coupling map for the device + +* **supported\_instructions** (*List\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Instructions supported by the backend. + +* **dynamic\_reprate\_enabled** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether delay between programs can be set dynamically (ie via `rep_delay`). Defaults to False. + +* **rep\_delay\_range** (*List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – 2d list defining supported range of repetition delays for backend in μs. First entry is lower end of the range, second entry is higher end of the range. Optional, but will be specified when `dynamic_reprate_enabled=True`. + +* **default\_rep\_delay** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Value of `rep_delay` if not specified by user and `dynamic_reprate_enabled=True`. + +* **max\_experiments** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of experiments per job + +* **sample\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Sample name for the backend + +* **n\_registers** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of register slots available for feedback (if conditional is True) + +* **register\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – An array of dimension n\_qubits X n\_registers that specifies whether a qubit can store a measurement in a certain register slot. + +* **configurable** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if the backend is configurable, if the backend is a simulator + +* **credits\_required** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – True if backend requires credits to run a job. + +* **online\_date** ([*datetime.datetime*](https://docs.python.org/3/library/datetime.html#datetime.datetime "(in Python v3.12)")) – The date that the device went online + +* **display\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Alternate name field for the backend + +* **description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A description for the backend + +* **tags** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of string tags to describe the backend + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Qubit drive channel timestep in nanoseconds. + +* **dtm** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Measurement drive channel timestep in nanoseconds. + +* **processor\_type** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + + Processor type for this backend. A dictionary of the form `{"family": , "revision": , segment: }` such as `{"family": "Canary", "revision": "1.0", segment: "A"}`. + + * family: Processor family of this backend. + * revision: Revision version of this processor. + * segment: Segment this processor belongs to within a larger chip. + +* **parametric\_pulses** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of pulse shapes which are supported on the backend. For example: `['gaussian', 'constant']` + +* **\*\*kwargs** – optional fields + +## Attributes + + + +### num\_qubits + +Returns the number of qubits. + +In future, n\_qubits should be replaced in favor of num\_qubits for consistent use throughout Qiskit. Until this is properly refactored, this property serves as intermediate solution. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new GateConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the GateConfig to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.QasmBackendConfiguration.to_dict "qiskit.providers.models.QasmBackendConfiguration.to_dict"). + +**Returns** + +The GateConfig from the input dictionary. + +**Return type** + +[GateConfig](qiskit.providers.models.GateConfig "qiskit.providers.models.GateConfig") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the GateConfig. + +**Returns** + +The dictionary form of the GateConfig. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.providers.models.UchannelLO.md b/docs/api/qiskit/0.46/qiskit.providers.models.UchannelLO.md new file mode 100644 index 00000000000..a3cca3b3fd0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.providers.models.UchannelLO.md @@ -0,0 +1,79 @@ +--- +title: UchannelLO +description: API reference for qiskit.providers.models.UchannelLO +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.providers.models.UchannelLO +--- + +# UchannelLO + + + +`qiskit.providers.models.UchannelLO(q, scale)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/providers/models/backendconfiguration.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class representing a U Channel LO + + + +### q + +Qubit that scale corresponds too. + + + +### scale + +Scale factor for qubit frequency. + +Initialize a UchannelLOSchema object + +**Parameters** + +* **q** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Qubit that scale corresponds too. Must be >= 0. +* **scale** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Scale factor for qubit frequency. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If q is \< 0 + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new UchannelLO object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the UChannelLO to create. It will be in the same format as output by [`to_dict()`](#qiskit.providers.models.UchannelLO.to_dict "qiskit.providers.models.UchannelLO.to_dict"). + +**Returns** + +The UchannelLO from the input dictionary. + +**Return type** + +[UchannelLO](#qiskit.providers.models.UchannelLO "qiskit.providers.models.UchannelLO") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the UChannelLO. + +**Returns** + +The dictionary form of the UChannelLO. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.InstructionScheduleMap.md b/docs/api/qiskit/0.46/qiskit.pulse.InstructionScheduleMap.md new file mode 100644 index 00000000000..3653fa35d41 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.InstructionScheduleMap.md @@ -0,0 +1,241 @@ +--- +title: InstructionScheduleMap +description: API reference for qiskit.pulse.InstructionScheduleMap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.InstructionScheduleMap +--- + +# InstructionScheduleMap + + + +`qiskit.pulse.InstructionScheduleMap`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instruction_schedule_map.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Mapping from [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") [`qiskit.circuit.Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") names and qubits to [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") s. In particular, the mapping is formatted as type: + +```python +Dict[str, Dict[Tuple[int], Schedule]] +``` + +where the first key is the name of a circuit instruction (e.g. `'u1'`, `'measure'`), the second key is a tuple of qubit indices, and the final value is a Schedule implementing the requested instruction. + +These can usually be seen as gate calibrations. + +Initialize a circuit instruction to schedule mapper instance. + +## Attributes + + + +### instructions + +Return all instructions which have definitions. + +By default, these are typically the basis gates along with other instructions such as measure and reset. + +**Returns** + +The names of all the circuit instructions which have Schedule definitions in this. + +## Methods + +### add + + + +`add(instruction, qubits, schedule, arguments=None)` + +Add a new known instruction for the given qubits and its mapping to a pulse schedule. + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – The name of the instruction to add. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits which the instruction applies to. +* **schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *|*[*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[...],* [*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")*]*) – The Schedule that implements the given instruction. +* **arguments** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – List of parameter names to create a parameter-bound schedule from the associated gate instruction. If [`get()`](#qiskit.pulse.InstructionScheduleMap.get "qiskit.pulse.InstructionScheduleMap.get") is called with arguments rather than keyword arguments, this parameter list is used to map the input arguments to parameter objects stored in the target schedule. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the qubits are provided as an empty iterable. + +### assert\_has + + + +`assert_has(instruction, qubits)` + +Error if the given instruction is not defined. + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – The instruction for which to look. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The specific qubits for the instruction. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the instruction is not defined on the qubits. + +### get + + + +`get(instruction, qubits, *params, **kwparams)` + +Return the defined [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") or [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") for the given instruction on the given qubits. + +If all keys are not specified this method returns schedule with unbound parameters. + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – Name of the instruction or the instruction itself. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits for the instruction. +* **\*params** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Command parameters for generating the output schedule. +* **\*\*kwparams** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Keyworded command parameters for generating the schedule. + +**Returns** + +The Schedule defined for the input. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") | [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### get\_parameters + + + +`get_parameters(instruction, qubits)` + +Return the list of parameters taken by the given instruction on the given qubits. + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – Name of the instruction. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits for the instruction. + +**Returns** + +The names of the parameters required by the instruction. + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### has + + + +`has(instruction, qubits)` + +Is the instruction defined for the given qubits? + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – The instruction for which to look. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The specific qubits for the instruction. + +**Returns** + +True iff the instruction is defined. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### has\_custom\_gate + + + +`has_custom_gate()` + +Return `True` if the map has user provided instruction. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### pop + + + +`pop(instruction, qubits, *params, **kwparams)` + +Remove and return the defined schedule for the given instruction on the given qubits. + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – Name of the instruction. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits for the instruction. +* **\*params** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Command parameters for generating the output schedule. +* **\*\*kwparams** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Keyworded command parameters for generating the schedule. + +**Returns** + +The Schedule defined for the input. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") | [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### qubit\_instructions + + + +`qubit_instructions(qubits)` + +Return a list of the instruction names that are defined by the backend for the given qubit or qubits. + +**Parameters** + +**qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – A qubit index, or a list or tuple of indices. + +**Returns** + +All the instructions which are defined on the qubits. + +For 1 qubit, all the 1Q instructions defined. For multiple qubits, all the instructions which apply to that whole set of qubits (e.g. `qubits=[0, 1]` may return `['cx']`). + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### qubits\_with\_instruction + + + +`qubits_with_instruction(instruction)` + +Return a list of the qubits for which the given instruction is defined. Single qubit instructions return a flat list, and multiqubit instructions return a list of ordered tuples. + +**Parameters** + +**instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – The name of the circuit instruction. + +**Returns** + +Qubit indices which have the given instruction defined. This is a list of tuples if the instruction has an arity greater than 1, or a flat list of ints otherwise. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the instruction is not found. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") | [*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")]] + +### remove + + + +`remove(instruction, qubits)` + +Remove the given instruction from the listing of instructions defined in self. + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – The name of the instruction to add. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The qubits which the instruction applies to. + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.Schedule.md b/docs/api/qiskit/0.46/qiskit.pulse.Schedule.md new file mode 100644 index 00000000000..f7282caf622 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.Schedule.md @@ -0,0 +1,498 @@ +--- +title: Schedule +description: API reference for qiskit.pulse.Schedule +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.Schedule +--- + +# Schedule + + + +`qiskit.pulse.Schedule(*schedules, name=None, metadata=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/schedule.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A quantum program *schedule* with exact time constraints for its instructions, operating over all input signal *channels* and supporting special syntaxes for building. + +Pulse program representation for the original Qiskit Pulse model \[1]. Instructions are not allowed to overlap in time on the same channel. This overlap constraint is immediately evaluated when a new instruction is added to the `Schedule` object. + +It is necessary to specify the absolute start time and duration for each instruction so as to deterministically fix its execution time. + +The `Schedule` program supports some syntax sugar for easier programming. + +* Appending an instruction to the end of a channel + + ```python + sched = Schedule() + sched += Play(Gaussian(160, 0.1, 40), DriveChannel(0)) + ``` + +* Appending an instruction shifted in time by a given amount + + ```python + sched = Schedule() + sched += Play(Gaussian(160, 0.1, 40), DriveChannel(0)) << 30 + ``` + +* Merge two schedules + + ```python + sched1 = Schedule() + sched1 += Play(Gaussian(160, 0.1, 40), DriveChannel(0)) + + sched2 = Schedule() + sched2 += Play(Gaussian(160, 0.1, 40), DriveChannel(1)) + sched2 = sched1 | sched2 + ``` + +A [`PulseError`](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") is immediately raised when the overlap constraint is violated. + +In the schedule representation, we cannot parametrize the duration of instructions. Thus we need to create a new schedule object for each duration. To parametrize an instruction’s duration, the [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") representation may be used instead. + +**References** + +\[1]: [https://arxiv.org/abs/2004.06755](https://arxiv.org/abs/2004.06755) + +Create an empty schedule. + +**Parameters** + +* **\*schedules** (*ScheduleComponent |* [*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, ScheduleComponent]*) – Child Schedules of this parent Schedule. May either be passed as the list of schedules, or a list of `(start_time, schedule)` pairs. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of this schedule. Defaults to an autogenerated string if not provided. +* **metadata** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Arbitrary key value metadata to associate with the schedule. This gets stored as free-form data in a dict in the [`metadata`](#qiskit.pulse.Schedule.metadata "qiskit.pulse.Schedule.metadata") attribute. It will not be directly used in the schedule. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – if metadata is not a dict. + +## Attributes + + + +### channels + +Returns channels that this schedule uses. + + + +### children + +Return the child schedule components of this `Schedule` in the order they were added to the schedule. + +**Notes** + +Nested schedules are returned as-is. If you want to collect only instructions, use py:meth:\~Schedule.instructions instead. + +**Returns** + +A tuple, where each element is a two-tuple containing the initial scheduled time of each `NamedValue` and the component itself. + + + +### duration + +Duration of this schedule. + + + +### instances\_counter + +`= count(0)` + + + +### instructions + +Get the time-ordered instructions from self. + + + +### metadata + +The user provided metadata associated with the schedule. + +User provided `dict` of metadata for the schedule. The metadata contents do not affect the semantics of the program but are used to influence the execution of the schedule. It is expected to be passed between all transforms of the schedule and that providers will associate any schedule metadata with the results it returns from the execution of that schedule. + + + +### name + +Name of this Schedule + + + +### parameters + +Parameters which determine the schedule behavior. + + + +### prefix + +`= 'sched'` + + + +### start\_time + +Starting time of this schedule. + + + +### stop\_time + +Stopping time of this schedule. + + + +### timeslots + +Time keeping attribute. + +## Methods + +### append + + + +`append(schedule, name=None, inplace=False)` + +Return a new schedule with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +$$ +t = \textrm{max}(\texttt{x.stop_time} |\texttt{x} \in + \texttt{self.channels} \cap \texttt{schedule.channels}) +$$ + +**Parameters** + +* **schedule** ([*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – Schedule to be appended. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new `Schedule`. Defaults to name of `self`. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Perform operation inplace on this schedule. Otherwise return a new `Schedule`. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### assign\_parameters + + + +`assign_parameters(value_dict, inplace=True)` + +Assign the parameters in this schedule according to the input. + +**Parameters** + +* **value\_dict** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – A mapping from Parameters to either numeric values or another Parameter expression. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set `True` to override this instance with new parameter. + +**Returns** + +Schedule with updated parameters. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return the time of the end of the last instruction over the supplied channels. + +**Parameters** + +**\*channels** ([*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – Channels within `self` to include. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return the time of the start of the first instruction over the supplied channels. + +**Parameters** + +**\*channels** ([*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – Channels within `self` to include. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time over supplied channels. + +**Parameters** + +**\*channels** ([*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – Channels within `self` to include. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(style=None, backend=None, time_range=None, time_unit='dt', disable_channels=None, show_snapshot=True, show_framechange=True, show_waveform_info=True, show_barrier=True, plotter='mpl2d', axis=None)` + +Plot the schedule. + +**Parameters** + +* **style** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Stylesheet options. This can be dictionary or preset stylesheet classes. See `IQXStandard`, `IQXSimple`, and `IQXDebugging` for details of preset stylesheets. + +* **backend** (*Optional\[BaseBackend]*) – Backend object to play the input pulse program. If provided, the plotter may use to make the visualization hardware aware. + +* **time\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Set horizontal axis limit. Tuple (tmin, tmax). + +* **time\_unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unit of specified time range either dt or ns. The unit of ns is available only when backend object is provided. + +* **disable\_channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A control property to show specific pulse channel. Pulse channel instances provided as a list are not shown in the output image. + +* **show\_snapshot** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show snapshot instructions. + +* **show\_framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show frame change instructions. The frame change represents instructions that modulate phase or frequency of pulse channels. + +* **show\_waveform\_info** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show additional information about waveforms such as their name. + +* **show\_barrier** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show barrier lines. + +* **plotter** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – + + Name of plotter API to generate an output image. One of following APIs should be specified: + + ```python + mpl2d: Matplotlib API for 2D image generation. + Matplotlib API to generate 2D image. Charts are placed along y axis with + vertical offset. This API takes matplotlib.axes.Axes as ``axis`` input. + ``` + + `axis` and `style` kwargs may depend on the plotter. + +* **axis** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") *| None*) – Arbitrary object passed to the plotter. If this object is provided, the plotters use a given `axis` instead of internally initializing a figure object. This object format depends on the plotter. See plotter argument for details. + +**Returns** + +Visualization output data. The returned data type depends on the `plotter`. If matplotlib family is specified, this will be a `matplotlib.pyplot.Figure` data. + +### exclude + + + +`exclude(*filter_funcs, channels=None, instruction_types=None, time_ranges=None, intervals=None, check_subroutine=True)` + +Return a `Schedule` with only the instructions from this Schedule *failing* at least one of the provided filters. This method is the complement of py:meth:\~self.filter, so that: + +```python +self.filter(args) | self.exclude(args) == self +``` + +**Parameters** + +* **filter\_funcs** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")) – A list of Callables which take a (int, Union\[‘Schedule’, Instruction]) tuple and return a bool. +* **channels** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. +* **instruction\_types** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)") *| None*) – For example, `[PulseInstruction, AcquireInstruction]`. +* **time\_ranges** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – For example, `[(0, 5), (6, 10)]`. +* **intervals** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – For example, `[(0, 5), (6, 10)]`. +* **check\_subroutine** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set True to individually filter instructions inside of a subroutine defined by the [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call") instruction. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### filter + + + +`filter(*filter_funcs, channels=None, instruction_types=None, time_ranges=None, intervals=None, check_subroutine=True)` + +Return a new `Schedule` with only the instructions from this `Schedule` which pass though the provided filters; i.e. an instruction will be retained iff every function in `filter_funcs` returns `True`, the instruction occurs on a channel type contained in `channels`, the instruction type is contained in `instruction_types`, and the period over which the instruction operates is *fully* contained in one specified in `time_ranges` or `intervals`. + +If no arguments are provided, `self` is returned. + +**Parameters** + +* **filter\_funcs** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")) – A list of Callables which take a (int, Union\[‘Schedule’, Instruction]) tuple and return a bool. +* **channels** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. +* **instruction\_types** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)") *| None*) – For example, `[PulseInstruction, AcquireInstruction]`. +* **time\_ranges** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – For example, `[(0, 5), (6, 10)]`. +* **intervals** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – For example, `[(0, 5), (6, 10)]`. +* **check\_subroutine** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set True to individually filter instructions inside of a subroutine defined by the [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call") instruction. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### get\_parameters + + + +`get_parameters(parameter_name)` + +Get parameter object bound to this schedule by string name. + +Because different `Parameter` objects can have the same name, this method returns a list of `Parameter` s for the provided name. + +**Parameters** + +**parameter\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of parameter. + +**Returns** + +Parameter objects that have corresponding name. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")] + +### initialize\_from + + + +`classmethod initialize_from(other_program, name=None)` + +Create new schedule object with metadata of another schedule object. + +**Parameters** + +* **other\_program** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit program that provides metadata to new object. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of new schedule. Name of `schedule` is used by default. + +**Returns** + +New schedule object with name and metadata. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When other\_program does not provide necessary information. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### insert + + + +`insert(start_time, schedule, name=None, inplace=False)` + +Return a new schedule with `schedule` inserted into `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule. +* **schedule** ([*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – Schedule to insert. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to the name of self. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Perform operation inplace on this schedule. Otherwise return a new `Schedule`. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### replace + + + +`replace(old, new, inplace=False)` + +Return a `Schedule` with the `old` instruction replaced with a `new` instruction. + +The replacement matching is based on an instruction equality check. + +```python +from qiskit import pulse + +d0 = pulse.DriveChannel(0) + +sched = pulse.Schedule() + +old = pulse.Play(pulse.Constant(100, 1.0), d0) +new = pulse.Play(pulse.Constant(100, 0.1), d0) + +sched += old + +sched = sched.replace(old, new) + +assert sched == pulse.Schedule(new) +``` + +Only matches at the top-level of the schedule tree. If you wish to perform this replacement over all instructions in the schedule tree. Flatten the schedule prior to running: + +```python +.. code-block:: +``` + +> sched = pulse.Schedule() +> +> sched += pulse.Schedule(old) +> +> sched = sched.flatten() +> +> sched = sched.replace(old, new) +> +> assert sched == pulse.Schedule(new) + +**Parameters** + +* **old** ([*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – Instruction to replace. +* **new** ([*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – Instruction to replace with. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Replace instruction by mutably modifying this `Schedule`. + +**Returns** + +The modified schedule with `old` replaced by `new`. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the `Schedule` after replacements will has a timing overlap. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### shift + + + +`shift(time, name=None, inplace=False)` + +Return a schedule shifted forward by `time`. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to the name of self. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Perform operation inplace on this schedule. Otherwise return a new `Schedule`. + +**Return type** + +[*Schedule*](#qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.ScheduleBlock.md b/docs/api/qiskit/0.46/qiskit.pulse.ScheduleBlock.md new file mode 100644 index 00000000000..4308af5ceb9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.ScheduleBlock.md @@ -0,0 +1,662 @@ +--- +title: ScheduleBlock +description: API reference for qiskit.pulse.ScheduleBlock +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.ScheduleBlock +--- + +# ScheduleBlock + + + +`qiskit.pulse.ScheduleBlock(name=None, metadata=None, alignment_context=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/schedule.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Time-ordered sequence of instructions with alignment context. + +[`ScheduleBlock`](#qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") supports lazy scheduling of context instructions, i.e. their timeslots is always generated at runtime. This indicates we can parametrize instruction durations as well as other parameters. In contrast to [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") being somewhat static, [`ScheduleBlock`](#qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") is a dynamic representation of a pulse program. + +**Pulse Builder** + +The Qiskit pulse builder is a domain specific language that is developed on top of the schedule block. Use of the builder syntax will improve the workflow of pulse programming. See [Pulse Builder](pulse#pulse-builder) for a user guide. + +**Alignment contexts** + +A schedule block is always relatively scheduled. Instead of taking individual instructions with absolute execution time `t0`, the schedule block defines a context of scheduling and instructions under the same context are scheduled in the same manner (alignment). Several contexts are available in [Alignments](pulse#pulse-alignments). A schedule block is instantiated with one of these alignment contexts. The default context is `AlignLeft`, for which all instructions are left-justified, in other words, meaning they use as-soon-as-possible scheduling. + +If you need an absolute-time interval in between instructions, you can explicitly insert [`Delay`](qiskit.pulse.instructions.Delay "qiskit.pulse.instructions.Delay") instructions. + +**Nested blocks** + +A schedule block can contain other nested blocks with different alignment contexts. This enables advanced scheduling, where a subset of instructions is locally scheduled in a different manner. Note that a [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") instance cannot be directly added to a schedule block. To add a [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") instance, wrap it in a [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call") instruction. This is implicitly performed when a schedule is added through the [Pulse Builder](pulse#pulse-builder). + +**Unsupported operations** + +Because the schedule block representation lacks timeslots, it cannot perform particular [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") operations such as `insert()` or `shift()` that require instruction start time `t0`. In addition, [`exclude()`](#qiskit.pulse.ScheduleBlock.exclude "qiskit.pulse.ScheduleBlock.exclude") and [`filter()`](#qiskit.pulse.ScheduleBlock.filter "qiskit.pulse.ScheduleBlock.filter") methods are not supported because these operations may identify the target instruction with `t0`. Except for these operations, [`ScheduleBlock`](#qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") provides full compatibility with [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"). + +**Subroutine** + +The timeslots-free representation offers much greater flexibility for writing pulse programs. Because [`ScheduleBlock`](#qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") only cares about the ordering of the child blocks we can add an undefined pulse sequence as a subroutine of the main program. If your program contains the same sequence multiple times, this representation may reduce the memory footprint required by the program construction. Such a subroutine is realized by the special compiler directive [`Reference`](qiskit.pulse.instructions.Reference "qiskit.pulse.instructions.Reference") that is defined by a unique set of reference key strings to the subroutine. The (executable) subroutine is separately stored in the main program. Appended reference directives are resolved when the main program is executed. Subroutines must be assigned through [`assign_references()`](#qiskit.pulse.ScheduleBlock.assign_references "qiskit.pulse.ScheduleBlock.assign_references") before execution. + +**Program Scoping** + + + The [`scoped_parameters()`](#qiskit.pulse.ScheduleBlock.scoped_parameters "qiskit.pulse.ScheduleBlock.scoped_parameters") and [`search_parameters()`](#qiskit.pulse.ScheduleBlock.search_parameters "qiskit.pulse.ScheduleBlock.search_parameters") methods described in this section are deprecated. + + +When you call a subroutine from another subroutine, or append a schedule block to another schedule block, the management of references and parameters can be a hard task. Schedule block offers a convenient feature to help with this by automatically scoping the parameters and subroutines. + +```python +from qiskit import pulse +from qiskit.circuit.parameter import Parameter + +amp1 = Parameter("amp") + +with pulse.build() as sched1: + pulse.play(pulse.Constant(100, amp1), pulse.DriveChannel(0)) + +print(sched1.scoped_parameters()) +``` + +```python +(Parameter(root::amp),) +``` + +The [`scoped_parameters()`](#qiskit.pulse.ScheduleBlock.scoped_parameters "qiskit.pulse.ScheduleBlock.scoped_parameters") method returns all [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects defined in the schedule block. The parameter name is updated to reflect its scope information, i.e. where it is defined. The outer scope is called “root”. Since the “amp” parameter is directly used in the current builder context, it is prefixed with “root”. Note that the `Parameter` object returned by [`scoped_parameters()`](#qiskit.pulse.ScheduleBlock.scoped_parameters "qiskit.pulse.ScheduleBlock.scoped_parameters") preserves the hidden [UUID](https://docs.python.org/3/library/uuid.html#module-uuid) key, and thus the scoped name doesn’t break references to the original `Parameter`. + +You may want to call this program from another program. In this example, the program is called with the reference key “grand\_child”. You can call a subroutine without specifying a substantial program (like `sched1` above which we will assign later). + +```python +amp2 = Parameter("amp") + +with pulse.build() as sched2: + with pulse.align_right(): + pulse.reference("grand_child") + pulse.play(pulse.Constant(200, amp2), pulse.DriveChannel(0)) + +print(sched2.scoped_parameters()) +``` + +```python +(Parameter(root::amp),) +``` + +This only returns “root::amp” because the “grand\_child” reference is unknown. Now you assign the actual pulse program to this reference. + +```python +sched2.assign_references({("grand_child", ): sched1}) +print(sched2.scoped_parameters()) +``` + +```python +(Parameter(root::amp), Parameter(root::grand_child::amp)) +``` + +Now you get two parameters “root::amp” and “root::grand\_child::amp”. The second parameter name indicates it is defined within the referred program “grand\_child”. The program calling the “grand\_child” has a reference program description which is accessed through [`ScheduleBlock.references`](#qiskit.pulse.ScheduleBlock.references "qiskit.pulse.ScheduleBlock.references"). + +```python +print(sched2.references) +``` + +```python +ReferenceManager: + - ('grand_child',): ScheduleBlock(Play(Constant(duration=100, amp=amp,... +``` + +Finally, you may want to call this program from another program. Here we try a different approach to define subroutine. Namely, we call a subroutine from the root program with the actual program `sched2`. + +```python +amp3 = Parameter("amp") + +with pulse.build() as main: + pulse.play(pulse.Constant(300, amp3), pulse.DriveChannel(0)) + pulse.call(sched2, name="child") + +print(main.scoped_parameters()) +``` + +```python +(Parameter(root::amp), Parameter(root::child::amp), Parameter(root::child::grand_child::amp)) +``` + +This implicitly creates a reference named “child” within the root program and assigns `sched2` to it. You get three parameters “root::amp”, “root::child::amp”, and “root::child::grand\_child::amp”. As you can see, each parameter name reflects the layer of calls from the root program. If you know the scope of a parameter, you can directly get the parameter object using [`ScheduleBlock.search_parameters()`](#qiskit.pulse.ScheduleBlock.search_parameters "qiskit.pulse.ScheduleBlock.search_parameters") as follows. + +```python +main.search_parameters("root::child::grand_child::amp") +``` + +You can use a regular expression to specify the scope. The following returns the parameters defined within the scope of “ground\_child” regardless of its parent scope. This is sometimes convenient if you want to extract parameters from a deeply nested program. + +```python +main.search_parameters("\S::grand_child::amp") +``` + +Note that the root program is only aware of its direct references. + +```python +print(main.references) +``` + +```python +ReferenceManager: + - ('child',): ScheduleBlock(ScheduleBlock(ScheduleBlock(Play(Con... +``` + +As you can see the main program cannot directly assign a subroutine to the “grand\_child” because this subroutine is not called within the root program, i.e. it is indirectly called by “child”. However, the returned `ReferenceManager` is a dict-like object, and you can still reach to “grand\_child” via the “child” program with the following chained dict access. + +```python +main.references[("child", )].references[("grand_child", )] +``` + +Note that [`ScheduleBlock.parameters`](#qiskit.pulse.ScheduleBlock.parameters "qiskit.pulse.ScheduleBlock.parameters") and [`ScheduleBlock.scoped_parameters()`](#qiskit.pulse.ScheduleBlock.scoped_parameters "qiskit.pulse.ScheduleBlock.scoped_parameters") still collect all parameters also from the subroutine once it’s assigned. + +Create an empty schedule block. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of this schedule. Defaults to an autogenerated string if not provided. +* **metadata** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *| None*) – Arbitrary key value metadata to associate with the schedule. This gets stored as free-form data in a dict in the [`metadata`](#qiskit.pulse.ScheduleBlock.metadata "qiskit.pulse.ScheduleBlock.metadata") attribute. It will not be directly used in the schedule. +* **alignment\_context** ([*AlignmentKind*](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.AlignmentKind")) – `AlignmentKind` instance that manages scheduling of instructions in this block. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – if metadata is not a dict. + +## Attributes + + + +### alignment\_context + +Return alignment instance that allocates block component to generate schedule. + + + +### blocks + +Get the block elements added to self. + + + The sequence of elements is returned in order of addition. Because the first element is schedule first, e.g. FIFO, the returned sequence is roughly time-ordered. However, in the parallel alignment context, especially in the as-late-as-possible scheduling, or [`AlignRight`](qiskit.pulse.transforms.AlignRight "qiskit.pulse.transforms.AlignRight") context, the actual timing of when the instructions are issued is unknown until the [`ScheduleBlock`](#qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") is scheduled and converted into a [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"). + + + + +### channels + +Returns channels that this schedule block uses. + + + +### duration + +Duration of this schedule block. + + + +### instances\_counter + +`= count(0)` + + + +### instructions + +Get the time-ordered instructions from self. + + + +### metadata + +The user provided metadata associated with the schedule. + +User provided `dict` of metadata for the schedule. The metadata contents do not affect the semantics of the program but are used to influence the execution of the schedule. It is expected to be passed between all transforms of the schedule and that providers will associate any schedule metadata with the results it returns from the execution of that schedule. + + + +### name + +Return name of this schedule + + + +### parameters + +Return unassigned parameters with raw names. + + + +### prefix + +`= 'block'` + + + +### references + +Return a reference manager of the current scope. + +## Methods + +### append + + + +`append(block, name=None, inplace=True)` + +Return a new schedule block with `block` appended to the context block. The execution time is automatically assigned when the block is converted into schedule. + +**Parameters** + +* **block** ([*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – ScheduleBlock to be appended. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new `Schedule`. Defaults to name of `self`. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Perform operation inplace on this schedule. Otherwise, return a new `Schedule`. + +**Returns** + +Schedule block with appended schedule. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When invalid schedule type is specified. + +**Return type** + +[*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### assign\_parameters + + + +`assign_parameters(value_dict, inplace=True)` + +Assign the parameters in this schedule according to the input. + +**Parameters** + +* **value\_dict** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – A mapping from Parameters to either numeric values or another Parameter expression. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set `True` to override this instance with new parameter. + +**Returns** + +Schedule with updated parameters. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When the block is nested into another block. + +**Return type** + +[*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### assign\_references + + + +`assign_references(subroutine_dict, inplace=True)` + +Assign schedules to references. + +It is only capable of assigning a schedule block to immediate references which are directly referred within the current scope. Let’s see following example: + +```python +from qiskit import pulse + +with pulse.build() as subroutine: + pulse.delay(10, pulse.DriveChannel(0)) + +with pulse.build() as sub_prog: + pulse.reference("A") + +with pulse.build() as main_prog: + pulse.reference("B") +``` + +In above example, the `main_prog` can refer to the subroutine “root::B” and the reference of “B” to program “A”, i.e., “B::A”, is not defined in the root namespace. This prevents breaking the reference “root::B::A” by the assignment of “root::B”. For example, if a user could indirectly assign “root::B::A” from the root program, one can later assign another program to “root::B” that doesn’t contain “A” within it. In this situation, a reference “root::B::A” would still live in the reference manager of the root. However, the subroutine “root::B::A” would no longer be used in the actual pulse program. To assign subroutine “A” to `nested_prog` as a nested subprogram of `main_prog`, you must first assign “A” of the `sub_prog`, and then assign the `sub_prog` to the `main_prog`. + +```python +sub_prog.assign_references({("A", ): nested_prog}, inplace=True) +main_prog.assign_references({("B", ): sub_prog}, inplace=True) +``` + +Alternatively, you can also write + +```python +main_prog.assign_references({("B", ): sub_prog}, inplace=True) +main_prog.references[("B", )].assign_references({"A": nested_prog}, inplace=True) +``` + +Here [`references`](#qiskit.pulse.ScheduleBlock.references "qiskit.pulse.ScheduleBlock.references") returns a dict-like object, and you can mutably update the nested reference of the particular subroutine. + + + Assigned programs are deep-copied to prevent an unexpected update. + + +**Parameters** + +* **subroutine\_dict** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, ...],* [*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")*]*) – A mapping from reference key to schedule block of the subroutine. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set `True` to override this instance with new subroutine. + +**Returns** + +Schedule block with assigned subroutine. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When reference key is not defined in the current scope. + +**Return type** + +[*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return the time of the end of the last instruction over the supplied channels. + +**Parameters** + +**\*channels** ([*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – Channels within `self` to include. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(style=None, backend=None, time_range=None, time_unit='dt', disable_channels=None, show_snapshot=True, show_framechange=True, show_waveform_info=True, show_barrier=True, plotter='mpl2d', axis=None)` + +Plot the schedule. + +**Parameters** + +* **style** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Stylesheet options. This can be dictionary or preset stylesheet classes. See `IQXStandard`, `IQXSimple`, and `IQXDebugging` for details of preset stylesheets. + +* **backend** (*Optional\[BaseBackend]*) – Backend object to play the input pulse program. If provided, the plotter may use to make the visualization hardware aware. + +* **time\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Set horizontal axis limit. Tuple (tmin, tmax). + +* **time\_unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unit of specified time range either dt or ns. The unit of ns is available only when backend object is provided. + +* **disable\_channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A control property to show specific pulse channel. Pulse channel instances provided as a list are not shown in the output image. + +* **show\_snapshot** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show snapshot instructions. + +* **show\_framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show frame change instructions. The frame change represents instructions that modulate phase or frequency of pulse channels. + +* **show\_waveform\_info** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show additional information about waveforms such as their name. + +* **show\_barrier** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show barrier lines. + +* **plotter** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – + + Name of plotter API to generate an output image. One of following APIs should be specified: + + ```python + mpl2d: Matplotlib API for 2D image generation. + Matplotlib API to generate 2D image. Charts are placed along y axis with + vertical offset. This API takes matplotlib.axes.Axes as ``axis`` input. + ``` + + `axis` and `style` kwargs may depend on the plotter. + +* **axis** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") *| None*) – Arbitrary object passed to the plotter. If this object is provided, the plotters use a given `axis` instead of internally initializing a figure object. This object format depends on the plotter. See plotter argument for details. + +**Returns** + +Visualization output data. The returned data type depends on the `plotter`. If matplotlib family is specified, this will be a `matplotlib.pyplot.Figure` data. + +### exclude + + + +`exclude(*filter_funcs, channels=None, instruction_types=None, check_subroutine=True)` + +Return a new `ScheduleBlock` with only the instructions from this `ScheduleBlock` *failing* at least one of the provided filters. This method is the complement of py:meth:\~self.filter, so that: + +```python +self.filter(args) + self.exclude(args) == self in terms of instructions included. +``` + + + Because `ScheduleBlock` is not aware of the execution time of the context instructions, excluding some instructions may change the execution time of the remaining instructions. + + +**Parameters** + +* **filter\_funcs** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*]*) – A list of Callables which take a `Instruction` and return a bool. +* **channels** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. +* **instruction\_types** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)") *| None*) – For example, `[PulseInstruction, AcquireInstruction]`. +* **check\_subroutine** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set True to individually filter instructions inside of a subroutine defined by the [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call") instruction. + +**Returns** + +`ScheduleBlock` consisting of instructions that do not match with at least one of filtering conditions. + +### filter + + + +`filter(*filter_funcs, channels=None, instruction_types=None, check_subroutine=True)` + +Return a new `ScheduleBlock` with only the instructions from this `ScheduleBlock` which pass though the provided filters; i.e. an instruction will be retained if every function in `filter_funcs` returns `True`, the instruction occurs on a channel type contained in `channels`, and the instruction type is contained in `instruction_types`. + + + Because `ScheduleBlock` is not aware of the execution time of the context instructions, filtering out some instructions may change the execution time of the remaining instructions. + + +If no arguments are provided, `self` is returned. + +**Parameters** + +* **filter\_funcs** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*]*) – A list of Callables which take a `Instruction` and return a bool. +* **channels** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – For example, `[DriveChannel(0), AcquireChannel(0)]`. +* **instruction\_types** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)")*] |* [*ABCMeta*](https://docs.python.org/3/library/abc.html#abc.ABCMeta "(in Python v3.12)") *| None*) – For example, `[PulseInstruction, AcquireInstruction]`. +* **check\_subroutine** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set True to individually filter instructions inside a subroutine defined by the [`Call`](qiskit.pulse.instructions.Call "qiskit.pulse.instructions.Call") instruction. + +**Returns** + +`ScheduleBlock` consisting of instructions that matches with filtering condition. + +### get\_parameters + + + +`get_parameters(parameter_name)` + +Get parameter object bound to this schedule by string name. + +Note that we can define different parameter objects with the same name, because these different objects are identified by their unique uuid. For example, + +```python +from qiskit import pulse, circuit + +amp1 = circuit.Parameter("amp") +amp2 = circuit.Parameter("amp") + +with pulse.build() as sub_prog: + pulse.play(pulse.Constant(100, amp1), pulse.DriveChannel(0)) + +with pulse.build() as main_prog: + pulse.call(sub_prog, name="sub") + pulse.play(pulse.Constant(100, amp2), pulse.DriveChannel(0)) + +main_prog.get_parameters("amp") +``` + +This returns a list of two parameters `amp1` and `amp2`. + +**Parameters** + +**parameter\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of parameter. + +**Returns** + +Parameter objects that have corresponding name. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")] + +### initialize\_from + + + +`classmethod initialize_from(other_program, name=None)` + +Create new schedule object with metadata of another schedule object. + +**Parameters** + +* **other\_program** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit program that provides metadata to new object. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of new schedule. Name of `block` is used by default. + +**Returns** + +New block object with name and metadata. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When `other_program` does not provide necessary information. + +**Return type** + +[*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_referenced + + + +`is_referenced()` + +Return True iff the current schedule block contains reference to subroutine. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_schedulable + + + +`is_schedulable()` + +Return `True` if all durations are assigned. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### replace + + + +`replace(old, new, inplace=True)` + +Return a `ScheduleBlock` with the `old` component replaced with a `new` component. + +**Parameters** + +* **old** ([*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – Schedule block component to replace. +* **new** ([*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") *|*[*Instruction*](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction")) – Schedule block component to replace with. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Replace instruction by mutably modifying this `ScheduleBlock`. + +**Returns** + +The modified schedule block with `old` replaced by `new`. + +**Return type** + +[*ScheduleBlock*](#qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### scoped\_parameters + + + +`scoped_parameters()` + +Return unassigned parameters with scoped names. + + + Scoped parameters do not work correctly with Qiskit’s data model for parameter assignment. This implementation is consequently being removed in Qiskit 1.0. + + + + If a parameter is defined within a nested scope, it is prefixed with all parent-scope names with the delimiter string, which is “::”. If a reference key of the scope consists of multiple key strings, it will be represented by a single string joined with “,”. For example, “root::xgate,q0::amp” for the parameter “amp” defined in the reference specified by the key strings (“xgate”, “q0”). + + + + The method `qiskit.pulse.schedule.ScheduleBlock.scoped_parameters()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. There is no alternative to this method. Parameters must be mapped to references by checking the reference schedules directly. + + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")] + +### search\_parameters + + + +`search_parameters(parameter_regex)` + +Search parameter with regular expression. + + + Scoped parameters do not work correctly with Qiskit’s data model for parameter assignment. This implementation is consequently being removed in Qiskit 1.0. + + +This method looks for the scope-aware parameters. For example, + +```python +from qiskit import pulse, circuit + +amp1 = circuit.Parameter("amp") +amp2 = circuit.Parameter("amp") + +with pulse.build() as sub_prog: + pulse.play(pulse.Constant(100, amp1), pulse.DriveChannel(0)) + +with pulse.build() as main_prog: + pulse.call(sub_prog, name="sub") + pulse.play(pulse.Constant(100, amp2), pulse.DriveChannel(0)) + +main_prog.search_parameters("root::sub::amp") +``` + +This finds `amp1` with scoped name “root::sub::amp”. + + + The method `qiskit.pulse.schedule.ScheduleBlock.search_parameters()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. There is no alternative to this method. Parameters must be mapped to references by checking the reference schedules directly. + + +**Parameters** + +**parameter\_regex** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Regular expression for scoped parameter name. + +**Returns** + +Parameter objects that have corresponding name. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.parameter.Parameter")] + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.channels.AcquireChannel.md b/docs/api/qiskit/0.46/qiskit.pulse.channels.AcquireChannel.md new file mode 100644 index 00000000000..7c91206e3ef --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.channels.AcquireChannel.md @@ -0,0 +1,68 @@ +--- +title: AcquireChannel +description: API reference for qiskit.pulse.channels.AcquireChannel +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.channels.AcquireChannel +--- + +# AcquireChannel + + + +`qiskit.pulse.channels.AcquireChannel(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Bases: [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") + +Acquire channels are used to collect data. + +Channel class. + +**Parameters** + +**index** – Index of channel. + +## Attributes + + + +### index + +Return the index of this channel. The index is a label for a control signal line typically mapped trivially to a qubit index. For instance, `DriveChannel(0)` labels the signal line driving the qubit labeled with index 0. + + + +### name + +Return the shorthand alias for this channel, which is based on its type and index. + + + +### parameters + +Parameters which determine the channel index. + + + +### prefix + +`str | None` + +`= 'a'` + +A shorthand string prefix for characterizing the channel type. + +## Methods + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the channel is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.channels.ControlChannel.md b/docs/api/qiskit/0.46/qiskit.pulse.channels.ControlChannel.md new file mode 100644 index 00000000000..ea7d084e183 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.channels.ControlChannel.md @@ -0,0 +1,68 @@ +--- +title: ControlChannel +description: API reference for qiskit.pulse.channels.ControlChannel +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.channels.ControlChannel +--- + +# ControlChannel + + + +`qiskit.pulse.channels.ControlChannel(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Bases: `PulseChannel` + +Control channels provide supplementary control over the qubit to the drive channel. These are often associated with multi-qubit gate operations. They may not map trivially to a particular qubit index. + +Channel class. + +**Parameters** + +**index** – Index of channel. + +## Attributes + + + +### index + +Return the index of this channel. The index is a label for a control signal line typically mapped trivially to a qubit index. For instance, `DriveChannel(0)` labels the signal line driving the qubit labeled with index 0. + + + +### name + +Return the shorthand alias for this channel, which is based on its type and index. + + + +### parameters + +Parameters which determine the channel index. + + + +### prefix + +`str | None` + +`= 'u'` + +A shorthand string prefix for characterizing the channel type. + +## Methods + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the channel is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.channels.DriveChannel.md b/docs/api/qiskit/0.46/qiskit.pulse.channels.DriveChannel.md new file mode 100644 index 00000000000..3fc44b1ae8a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.channels.DriveChannel.md @@ -0,0 +1,68 @@ +--- +title: DriveChannel +description: API reference for qiskit.pulse.channels.DriveChannel +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.channels.DriveChannel +--- + +# DriveChannel + + + +`qiskit.pulse.channels.DriveChannel(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Bases: `PulseChannel` + +Drive channels transmit signals to qubits which enact gate operations. + +Channel class. + +**Parameters** + +**index** – Index of channel. + +## Attributes + + + +### index + +Return the index of this channel. The index is a label for a control signal line typically mapped trivially to a qubit index. For instance, `DriveChannel(0)` labels the signal line driving the qubit labeled with index 0. + + + +### name + +Return the shorthand alias for this channel, which is based on its type and index. + + + +### parameters + +Parameters which determine the channel index. + + + +### prefix + +`str | None` + +`= 'd'` + +A shorthand string prefix for characterizing the channel type. + +## Methods + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the channel is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.channels.MeasureChannel.md b/docs/api/qiskit/0.46/qiskit.pulse.channels.MeasureChannel.md new file mode 100644 index 00000000000..d8d8b51b3c4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.channels.MeasureChannel.md @@ -0,0 +1,68 @@ +--- +title: MeasureChannel +description: API reference for qiskit.pulse.channels.MeasureChannel +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.channels.MeasureChannel +--- + +# MeasureChannel + + + +`qiskit.pulse.channels.MeasureChannel(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Bases: `PulseChannel` + +Measure channels transmit measurement stimulus pulses for readout. + +Channel class. + +**Parameters** + +**index** – Index of channel. + +## Attributes + + + +### index + +Return the index of this channel. The index is a label for a control signal line typically mapped trivially to a qubit index. For instance, `DriveChannel(0)` labels the signal line driving the qubit labeled with index 0. + + + +### name + +Return the shorthand alias for this channel, which is based on its type and index. + + + +### parameters + +Parameters which determine the channel index. + + + +### prefix + +`str | None` + +`= 'm'` + +A shorthand string prefix for characterizing the channel type. + +## Methods + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the channel is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.channels.MemorySlot.md b/docs/api/qiskit/0.46/qiskit.pulse.channels.MemorySlot.md new file mode 100644 index 00000000000..e2806667cbd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.channels.MemorySlot.md @@ -0,0 +1,68 @@ +--- +title: MemorySlot +description: API reference for qiskit.pulse.channels.MemorySlot +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.channels.MemorySlot +--- + +# MemorySlot + + + +`qiskit.pulse.channels.MemorySlot(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Bases: `ClassicalIOChannel` + +Memory slot channels represent classical memory storage. + +Channel class. + +**Parameters** + +**index** – Index of channel. + +## Attributes + + + +### index + +Return the index of this channel. The index is a label for a control signal line typically mapped trivially to a qubit index. For instance, `DriveChannel(0)` labels the signal line driving the qubit labeled with index 0. + + + +### name + +Return the shorthand alias for this channel, which is based on its type and index. + + + +### parameters + +Parameters which determine the channel index. + + + +### prefix + +`str | None` + +`= 'm'` + +A shorthand string prefix for characterizing the channel type. + +## Methods + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the channel is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.channels.RegisterSlot.md b/docs/api/qiskit/0.46/qiskit.pulse.channels.RegisterSlot.md new file mode 100644 index 00000000000..9ad0c1f3ea9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.channels.RegisterSlot.md @@ -0,0 +1,68 @@ +--- +title: RegisterSlot +description: API reference for qiskit.pulse.channels.RegisterSlot +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.channels.RegisterSlot +--- + +# RegisterSlot + + + +`qiskit.pulse.channels.RegisterSlot(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Bases: `ClassicalIOChannel` + +Classical resister slot channels represent classical registers (low-latency classical memory). + +Channel class. + +**Parameters** + +**index** – Index of channel. + +## Attributes + + + +### index + +Return the index of this channel. The index is a label for a control signal line typically mapped trivially to a qubit index. For instance, `DriveChannel(0)` labels the signal line driving the qubit labeled with index 0. + + + +### name + +Return the shorthand alias for this channel, which is based on its type and index. + + + +### parameters + +Parameters which determine the channel index. + + + +### prefix + +`str | None` + +`= 'c'` + +A shorthand string prefix for characterizing the channel type. + +## Methods + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the channel is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.channels.SnapshotChannel.md b/docs/api/qiskit/0.46/qiskit.pulse.channels.SnapshotChannel.md new file mode 100644 index 00000000000..3f34458c12d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.channels.SnapshotChannel.md @@ -0,0 +1,64 @@ +--- +title: SnapshotChannel +description: API reference for qiskit.pulse.channels.SnapshotChannel +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.channels.SnapshotChannel +--- + +# SnapshotChannel + + + +`qiskit.pulse.channels.SnapshotChannel(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/channels.py "view source code") + +Bases: `ClassicalIOChannel` + +Snapshot channels are used to specify instructions for simulators. + +Create new snapshot channel. + +## Attributes + + + +### index + +Return the index of this channel. The index is a label for a control signal line typically mapped trivially to a qubit index. For instance, `DriveChannel(0)` labels the signal line driving the qubit labeled with index 0. + + + +### name + +Return the shorthand alias for this channel, which is based on its type and index. + + + +### parameters + +Parameters which determine the channel index. + + + +### prefix + +`str | None` + +`= 's'` + +A shorthand string prefix for characterizing the channel type. + +## Methods + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the channel is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.Acquire.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Acquire.md new file mode 100644 index 00000000000..ab5562f4621 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Acquire.md @@ -0,0 +1,289 @@ +--- +title: Acquire +description: API reference for qiskit.pulse.instructions.Acquire +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.Acquire +--- + +# Acquire + + + +`qiskit.pulse.instructions.Acquire(duration, channel, mem_slot=None, reg_slot=None, kernel=None, discriminator=None, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/acquire.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +The Acquire instruction is used to trigger the ADC associated with a particular qubit; e.g. instantiated with AcquireChannel(0), the Acquire command will trigger data collection for the channel associated with qubit 0 readout. This instruction also provides acquisition metadata: + +> * the number of cycles during which to acquire (in terms of dt), +> * the register slot to store classified, intermediary readout results, +> * the memory slot to return classified results, +> * the kernel to integrate raw data for each shot, and +> * the discriminator to classify kerneled IQ points. + +Create a new Acquire instruction. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Length of time to acquire data in terms of dt. +* **channel** ([*AcquireChannel*](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel")) – The channel that will acquire data. +* **mem\_slot** ([*MemorySlot*](qiskit.pulse.channels.MemorySlot "qiskit.pulse.channels.MemorySlot") *| None*) – The classical memory slot in which to store the classified readout result. +* **reg\_slot** ([*RegisterSlot*](qiskit.pulse.channels.RegisterSlot "qiskit.pulse.channels.RegisterSlot") *| None*) – The fast-access register slot in which to store the classified readout result for fast feedback. +* **kernel** (*Kernel | None*) – A `Kernel` for integrating raw data. +* **discriminator** (*Discriminator | None*) – A `Discriminator` for discriminating kerneled IQ data into 0/1 results. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the instruction for display purposes. + +## Attributes + + + +### acquire + +Acquire channel to acquire data. The `AcquireChannel` index maps trivially to qubit index. + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### discriminator + +Return discrimination settings. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### kernel + +Return kernel settings. + + + +### mem\_slot + +The classical memory slot which will store the classified readout result. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### reg\_slot + +The fast-access register slot which will store the classified readout result for fast-feedback computation. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.Call.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Call.md new file mode 100644 index 00000000000..e0147d1868f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Call.md @@ -0,0 +1,303 @@ +--- +title: Call +description: API reference for qiskit.pulse.instructions.Call +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.Call +--- + +# Call + + + +`qiskit.pulse.instructions.Call(subroutine, value_dict=None, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/call.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +Pulse `Call` instruction. + +The `Call` instruction represents the calling of a referenced subroutine (schedule). It enables code reuse both within the pulse representation and hardware (if supported). + +Define new subroutine. + + + Inline subroutine is mutable. This requires special care for modification. + + + + The class `qiskit.pulse.instructions.call.Call` is deprecated as of qiskit-terra 0.25.0. It will be removed in the Qiskit 1.0 release. Instead, use the pulse builder function qiskit.pulse.builder.call(subroutine) within an active building context. + + +**Parameters** + +* **subroutine** (*Union\[*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule")*,* [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")*]*) – A program subroutine to be referred to. +* **value\_dict** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – Mapping of parameter object to assigned value. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Unique ID of this subroutine. If not provided, this is generated based on the subroutine name. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If subroutine is not valid data format. + +## Attributes + + + +### arguments + +Parameters dictionary to be assigned to subroutine. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Unassigned parameters which determine the instruction behavior. + + + +### prefix + +`= 'call'` + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + + + +### subroutine + +Return attached subroutine. + +**Returns** + +The program referenced by the call. + +**Return type** + +program (Union\[[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule"), [ScheduleBlock](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")]) + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### assigned\_subroutine + + + +`assigned_subroutine()` + +Returns this subroutine with the parameters assigned. + + + This function may be often called internally for class equality check despite its overhead of parameter assignment. The subroutine with parameter assigned is cached based on `.argument` hash. Once this argument is updated, new assigned instance will be returned. Note that this update is not mutable operation. + + +**Returns** + +Attached program. + +**Return type** + +program (Union\[[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule"), [ScheduleBlock](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock")]) + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.Delay.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Delay.md new file mode 100644 index 00000000000..3b634347219 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Delay.md @@ -0,0 +1,263 @@ +--- +title: Delay +description: API reference for qiskit.pulse.instructions.Delay +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.Delay +--- + +# Delay + + + +`qiskit.pulse.instructions.Delay(duration, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/delay.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +A blocking instruction with no other effect. The delay is used for aligning and scheduling other instructions. + +**Example** + +To schedule an instruction at time = 10, on a channel assigned to the variable `channel`, the following could be used: + +```python +sched = Schedule(name="Delay instruction example") +sched += Delay(10, channel) +sched += Gaussian(duration, amp, sigma, channel) +``` + +The `channel` will output no signal from time=0 up until time=10. + +Create a new delay instruction. + +No other instruction may be scheduled within a `Delay`. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Length of time of the delay in terms of dt. +* **channel** ([*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – The channel that will have the delay. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the delay for display purposes. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.Play.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Play.md new file mode 100644 index 00000000000..125e5646447 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Play.md @@ -0,0 +1,257 @@ +--- +title: Play +description: API reference for qiskit.pulse.instructions.Play +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.Play +--- + +# Play + + + +`qiskit.pulse.instructions.Play(pulse, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/play.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +This instruction is responsible for applying a pulse on a channel. + +The pulse specifies the exact time dynamics of the output signal envelope for a limited time. The output is modulated by a phase and frequency which are controlled by separate instructions. The pulse duration must be fixed, and is implicitly given in terms of the cycle time, dt, of the backend. + +Create a new pulse instruction. + +**Parameters** + +* **pulse** (*Pulse*) – A pulse waveform description, such as [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform"). +* **channel** (*PulseChannel*) – The channel to which the pulse is applied. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the instruction for display purposes. Defaults to `pulse.name`. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### pulse + +A description of the samples that will be played. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.Reference.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Reference.md new file mode 100644 index 00000000000..495498f1775 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Reference.md @@ -0,0 +1,268 @@ +--- +title: Reference +description: API reference for qiskit.pulse.instructions.Reference +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.Reference +--- + +# Reference + + + +`qiskit.pulse.instructions.Reference(name, *extra_keys)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/reference.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +Pulse compiler directive that refers to a subroutine. + +If a pulse program uses the same subset of instructions multiple times, then using the [`Reference`](#qiskit.pulse.instructions.Reference "qiskit.pulse.instructions.Reference") class may significantly reduce the memory footprint of the program. This instruction only stores the set of strings to identify the subroutine. + +The actual pulse program can be stored in the `ScheduleBlock.references` of the [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") that this reference instruction belongs to. + +You can later assign schedules with the `ScheduleBlock.assign_references()` method. This allows you to build the main program without knowing the actual subroutine, that is supplied at a later time. + +Create new reference. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Name of subroutine. +* **extra\_keys** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional. A set of string keys that may be necessary to refer to a particular subroutine. For example, when we use “sx” as a name to refer to the subroutine of an sx pulse, this name might be used among schedules for different qubits. In this example, you may specify “q0” in the extra keys to distinguish the sx schedule for qubit 0 from others. The user can use an arbitrary number of extra string keys to uniquely determine the subroutine. + +## Attributes + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### key\_delimiter + +`= ','` + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### ref\_keys + +Returns unique key of the subroutine. + + + +### scope\_delimiter = ' + +`= ':` + +`= '::'` + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.RelativeBarrier.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.RelativeBarrier.md new file mode 100644 index 00000000000..23ef2e0c82b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.RelativeBarrier.md @@ -0,0 +1,244 @@ +--- +title: RelativeBarrier +description: API reference for qiskit.pulse.instructions.RelativeBarrier +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.RelativeBarrier +--- + +# RelativeBarrier + + + +`qiskit.pulse.instructions.RelativeBarrier(*channels, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/directives.py "view source code") + +Bases: `Directive` + +Pulse `RelativeBarrier` directive. + +Create a relative barrier directive. + +The barrier directive blocks instructions within the same schedule as the barrier on channels contained within this barrier from moving through the barrier in time. + +**Parameters** + +* **channels** ([*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – The channel that the barrier applies to. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the directive for display purposes. + +## Attributes + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.SetFrequency.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.SetFrequency.md new file mode 100644 index 00000000000..771d723084f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.SetFrequency.md @@ -0,0 +1,265 @@ +--- +title: SetFrequency +description: API reference for qiskit.pulse.instructions.SetFrequency +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.SetFrequency +--- + +# SetFrequency + + + +`qiskit.pulse.instructions.SetFrequency(frequency, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/frequency.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +Set the channel frequency. This instruction operates on `PulseChannel` s. A `PulseChannel` creates pulses of the form + +$$ +Re[\exp(i 2\pi f jdt + \phi) d_j]. + + +$$ + +Here, $f$ is the frequency of the channel. The instruction `SetFrequency` allows the user to set the value of $f$. All pulses that are played on a channel after SetFrequency has been called will have the corresponding frequency. + +The duration of SetFrequency is 0. + +Creates a new set channel frequency instruction. + +**Parameters** + +* **frequency** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – New frequency of the channel in Hz. +* **channel** (*PulseChannel*) – The channel this instruction operates on. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of this set channel frequency instruction. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### frequency + +New frequency. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.SetPhase.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.SetPhase.md new file mode 100644 index 00000000000..20ee6dfade3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.SetPhase.md @@ -0,0 +1,263 @@ +--- +title: SetPhase +description: API reference for qiskit.pulse.instructions.SetPhase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.SetPhase +--- + +# SetPhase + + + +`qiskit.pulse.instructions.SetPhase(phase, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/phase.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +The set phase instruction sets the phase of the proceeding pulses on that channel to `phase` radians. + +In particular, a PulseChannel creates pulses of the form + +$$ +Re[\exp(i 2\pi f jdt + \phi) d_j] +$$ + +The `SetPhase` instruction sets $\phi$ to the instruction’s `phase` operand. + +Instantiate a set phase instruction, setting the output signal phase on `channel` to `phase` \[radians]. + +**Parameters** + +* **phase** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The rotation angle in radians. +* **channel** (*PulseChannel*) – The channel this instruction operates on. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this instruction. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### phase + +Return the rotation angle enacted by this instruction in radians. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftFrequency.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftFrequency.md new file mode 100644 index 00000000000..9e0ca23a4fb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftFrequency.md @@ -0,0 +1,255 @@ +--- +title: ShiftFrequency +description: API reference for qiskit.pulse.instructions.ShiftFrequency +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.ShiftFrequency +--- + +# ShiftFrequency + + + +`qiskit.pulse.instructions.ShiftFrequency(frequency, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/frequency.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +Shift the channel frequency away from the current frequency. + +Creates a new shift frequency instruction. + +**Parameters** + +* **frequency** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Frequency shift of the channel in Hz. +* **channel** (*PulseChannel*) – The channel this instruction operates on. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of this set channel frequency instruction. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### frequency + +Frequency shift from the set frequency. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftPhase.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftPhase.md new file mode 100644 index 00000000000..e6da3a67285 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.ShiftPhase.md @@ -0,0 +1,267 @@ +--- +title: ShiftPhase +description: API reference for qiskit.pulse.instructions.ShiftPhase +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.ShiftPhase +--- + +# ShiftPhase + + + +`qiskit.pulse.instructions.ShiftPhase(phase, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/phase.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +The shift phase instruction updates the modulation phase of proceeding pulses played on the same [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel"). It is a relative increase in phase determined by the `phase` operand. + +In particular, a PulseChannel creates pulses of the form + +$$ +Re[\exp(i 2\pi f jdt + \phi) d_j]. + + +$$ + +The `ShiftPhase` instruction causes $\phi$ to be increased by the instruction’s `phase` operand. This will affect all pulses following on the same channel. + +The qubit phase is tracked in software, enabling instantaneous, nearly error-free Z-rotations by using a ShiftPhase to update the frame tracking the qubit state. + +Instantiate a shift phase instruction, increasing the output signal phase on `channel` by `phase` \[radians]. + +**Parameters** + +* **phase** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The rotation angle in radians. +* **channel** (*PulseChannel*) – The channel this instruction operates on. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this instruction. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### phase + +Return the rotation angle enacted by this instruction in radians. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.Snapshot.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Snapshot.md new file mode 100644 index 00000000000..5ba7515d7e3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.Snapshot.md @@ -0,0 +1,261 @@ +--- +title: Snapshot +description: API reference for qiskit.pulse.instructions.Snapshot +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.Snapshot +--- + +# Snapshot + + + +`qiskit.pulse.instructions.Snapshot(label, snapshot_type='statevector', name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/snapshot.py "view source code") + +Bases: [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.instruction.Instruction") + +An instruction targeted for simulators, to capture a moment in the simulation. + +Create new snapshot. + +**Parameters** + +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Snapshot label which is used to identify the snapshot in the output. +* **snapshot\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Type of snapshot, e.g., “state” (take a snapshot of the quantum state). The types of snapshots offered are defined by the simulator used. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Snapshot name which defaults to `label`. This parameter is only for display purposes and is not taken into account during comparison. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on; trivially, a `SnapshotChannel`. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### label + +Label of snapshot. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + + + +### type + +Type of snapshot. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.instructions.TimeBlockade.md b/docs/api/qiskit/0.46/qiskit.pulse.instructions.TimeBlockade.md new file mode 100644 index 00000000000..f98c6b69bc4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.instructions.TimeBlockade.md @@ -0,0 +1,280 @@ +--- +title: TimeBlockade +description: API reference for qiskit.pulse.instructions.TimeBlockade +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.instructions.TimeBlockade +--- + +# TimeBlockade + + + +`qiskit.pulse.instructions.TimeBlockade(duration, channel, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/instructions/directives.py "view source code") + +Bases: `Directive` + +Pulse `TimeBlockade` directive. + +This instruction is intended to be used internally within the pulse builder, to convert [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") into [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"). Because [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") cannot take an absolute instruction time interval, this directive helps the block representation to find the starting time of an instruction. + +**Example** + +This schedule plays constant pulse at t0 = 120. + +```python +schedule = Schedule() +schedule.insert(120, Play(Constant(10, 0.1), DriveChannel(0))) +``` + +This schedule block is expected to be identical to above at a time of execution. + +```python +block = ScheduleBlock() +block.append(TimeBlockade(120, DriveChannel(0))) +block.append(Play(Constant(10, 0.1), DriveChannel(0))) +``` + +Such conversion may be done by + +```python +from qiskit.pulse.transforms import block_to_schedule, remove_directives + +schedule = remove_directives(block_to_schedule(block)) +``` + + + The TimeBlockade instruction behaves almost identically to [`Delay`](qiskit.pulse.instructions.Delay "qiskit.pulse.instructions.Delay") instruction. However, the TimeBlockade is just a compiler directive and must be removed before execution. This may be done by [`remove_directives()`](pulse#qiskit.pulse.transforms.remove_directives "qiskit.pulse.transforms.remove_directives") transform. Once these directives are removed, occupied timeslots are released and user can insert another instruction without timing overlap. + + +Create a time blockade directive. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Length of time of the occupation in terms of dt. +* **channel** ([*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")) – The channel that will be the occupied. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the time blockade for display purposes. + +## Attributes + + + +### channel + +Return the [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") that this instruction is scheduled on. + + + +### channels + +Returns the channels that this schedule uses. + + + +### duration + +Duration of this instruction. + + + +### id + +Unique identifier for this instruction. + + + +### instructions + +Iterable for getting instructions from Schedule tree. + + + +### name + +Name of this instruction. + + + +### operands + +Return instruction operands. + + + +### parameters + +Parameters which determine the instruction behavior. + + + +### start\_time + +Relative begin time of this instruction. + + + +### stop\_time + +Relative end time of this instruction. + +## Methods + +### append + + + +`append(schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted at the maximum time over all channels shared between `self` and `schedule`. + +**Parameters** + +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to be appended +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` a this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### ch\_duration + + + +`ch_duration(*channels)` + +Return duration of the supplied channels in this Instruction. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_start\_time + + + +`ch_start_time(*channels)` + +Return minimum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### ch\_stop\_time + + + +`ch_stop_time(*channels)` + +Return maximum start time for supplied channels. + +**Parameters** + +**\*channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*]*) – Supplied channels + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### draw + + + +`draw(dt=1, style=None, filename=None, interp_method=None, scale=1, plot_all=False, plot_range=None, interactive=False, table=True, label=False, framechange=True, channels=None)` + +Plot the instruction. + + + The method `qiskit.pulse.instructions.instruction.Instruction.draw()` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. No direct alternative is being provided to drawing individual pulses. But, instructions can be visualized as part of a complete schedule using `qiskit.visualization.pulse_drawer`. + + +**Parameters** + +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Time interval of samples +* **style** (*Optional\[SchedStyle]*) – A style sheet to configure plot appearance +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name required to save pulse image +* **interp\_method** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – A function for interpolation +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative visual scaling of waveform amplitudes +* **plot\_all** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot empty channels +* **plot\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – A tuple of time range to plot +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set true show the circuit in a new window (this depends on the matplotlib backend being used supporting this) +* **table** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Draw event table for supported instructions +* **label** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label individual instructions +* **framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Add framechange indicators +* **channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A list of channel names to plot + +**Returns** + +A matplotlib figure object of the pulse schedule + +**Return type** + +matplotlib.figure + +### insert + + + +`insert(start_time, schedule, name=None)` + +Return a new [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") with `schedule` inserted within `self` at `start_time`. + +**Parameters** + +* **start\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to insert the schedule schedule +* **schedule** (*Union\['Schedule', 'Instruction']*) – Schedule or instruction to insert +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +A new schedule with `schedule` inserted with this instruction at t=0. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### shift + + + +`shift(time, name=None)` + +Return a new schedule shifted forward by time. + +**Parameters** + +* **time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time to shift by +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Name of the new schedule. Defaults to name of self + +**Returns** + +The shifted schedule. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Constant_class.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Constant_class.rst.md new file mode 100644 index 00000000000..c6ca45c4016 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Constant_class.rst.md @@ -0,0 +1,45 @@ +--- +title: Constant +description: API reference for qiskit.pulse.library.Constant +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.library.Constant +--- + +# Constant + + + +`qiskit.pulse.library.Constant(duration, amp, angle=None, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A simple constant pulse, with an amplitude value and a duration: + +$$ +f(x) = \text{amp}\times\exp\left(i\text{angle}\right) , 0 <= x < duration +f(x) = 0 , elsewhere +$$ + +Create new pulse instance. + +**Parameters** + +* **duration** – Pulse length in terms of the sampling period dt. +* **amp** – The magnitude of the amplitude of the square envelope. Complex amp support is deprecated. +* **angle** – The angle of the complex amplitude of the square envelope. Default value 0. +* **name** – Display name for this pulse envelope. +* **limit\_amplitude** – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +## Attributes + + + +### alias + +`= 'Constant'` + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Cos_class.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Cos_class.rst.md new file mode 100644 index 00000000000..9dcb8eb5e53 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Cos_class.rst.md @@ -0,0 +1,44 @@ +--- +title: Cos +description: API reference for qiskit.pulse.library.Cos +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.Cos +--- + + + +# qiskit.pulse.library.Cos + + + +`qiskit.pulse.library.Cos(duration, amp, phase, freq=None, angle=0.0, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +A cosine pulse. + +The envelope of the pulse is given by: + +$$ +f(x) = \text{A}\cos\left(2\pi\text{freq}x+\text{phase}\right) , 0 <= x < duration +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the cosine wave. Wave range is \[-amp,\`amp\`]. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The phase of the cosine wave (note that this is not equivalent to the angle of the complex amplitude). +* **freq** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The frequency of the cosine wave, in terms of 1 over sampling period. If not provided defaults to a single cycle (i.e :math:’frac\{1}\{text\{duration}}’). The frequency is limited to the range $\left(0,0.5\right]$ (the Nyquist frequency). +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Drag_class.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Drag_class.rst.md new file mode 100644 index 00000000000..7e576b79092 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Drag_class.rst.md @@ -0,0 +1,61 @@ +--- +title: Drag +description: API reference for qiskit.pulse.library.Drag +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.library.Drag +--- + +# Drag + + + +`qiskit.pulse.library.Drag(duration, amp, sigma, beta, angle=None, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +The Derivative Removal by Adiabatic Gate (DRAG) pulse is a standard Gaussian pulse with an additional Gaussian derivative component and lifting applied. + +It can be calibrated either to reduce the phase error due to virtual population of the $|2\rangle$ state during the pulse or to reduce the frequency spectrum of a standard Gaussian pulse near the $|1\rangle\leftrightarrow|2\rangle$ transition, reducing the chance of leakage to the $|2\rangle$ state. + +$$ +\begin{aligned} +g(x) &= \exp\Bigl(-\frac12 \frac{(x - \text{duration}/2)^2}{\text{sigma}^2}\Bigr)\\ +g'(x) &= \text{A}\times\frac{g(x)-g(-1)}{1-g(-1)}\\ +f(x) &= g'(x) \times \Bigl(1 + 1j \times \text{beta} \times \Bigl(-\frac{x - \text{duration}/2}{\text{sigma}^2}\Bigr) \Bigr), + \quad 0 \le x < \text{duration} +\end{aligned} +$$ + +where $g(x)$ is a standard unlifted Gaussian waveform, $g'(x)$ is the lifted [`Gaussian`](qiskit.pulse.library.Gaussian_class.rst#qiskit.pulse.library.Gaussian "qiskit.pulse.library.Gaussian") waveform, and $\text{A} = \text{amp} \times \exp\left(i\times\text{angle}\right)$. + +**References** + +1. [*Gambetta, J. M., Motzoi, F., Merkel, S. T. & Wilhelm, F. K. Analytic control methods for high-fidelity unitary operations in a weakly nonlinear oscillator. Phys. Rev. A 83, 012308 (2011).*](https://link.aps.org/doi/10.1103/PhysRevA.83.012308) + +2. [*F. Motzoi, J. M. Gambetta, P. Rebentrost, and F. K. Wilhelm Phys. Rev. Lett. 103, 110501 – Published 8 September 2009.*](https://link.aps.org/doi/10.1103/PhysRevLett.103.110501) + +Create new pulse instance. + +**Parameters** + +* **duration** – Pulse length in terms of the sampling period dt. +* **amp** – The magnitude of the amplitude of the DRAG envelope. Complex amp support is deprecated. +* **sigma** – A measure of how wide or narrow the Gaussian peak is; described mathematically in the class docstring. +* **beta** – The correction amplitude. +* **angle** – The angle of the complex amplitude of the DRAG envelope. Default value 0. +* **name** – Display name for this pulse envelope. +* **limit\_amplitude** – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +## Attributes + + + +### alias + +`= 'Drag'` + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianDeriv.md b/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianDeriv.md new file mode 100644 index 00000000000..445dabbda96 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianDeriv.md @@ -0,0 +1,44 @@ +--- +title: GaussianDeriv +description: API reference for qiskit.pulse.library.GaussianDeriv +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.GaussianDeriv +--- + + + +# qiskit.pulse.library.GaussianDeriv + + + +`qiskit.pulse.library.GaussianDeriv(duration, amp, sigma, angle=0.0, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +An unnormalized Gaussian derivative pulse. + +The Gaussian function is centered around the halfway point of the pulse, and the envelope of the pulse is given by: + +$$ +f(x) = -\text{A}\frac{x-\mu}{\text{sigma}^{2}}\exp + \left[-\left(\frac{x-\mu}{2\text{sigma}}\right)^{2}\right] , 0 <= x < duration +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$, and $\mu=\text{duration}/2$. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the pulse (the value of the corresponding Gaussian at the midpoint duration/2). +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A measure of how wide or narrow the corresponding Gaussian peak is in terms of dt; described mathematically in the class docstring. +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquare.md b/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquare.md new file mode 100644 index 00000000000..2f56de68217 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquare.md @@ -0,0 +1,79 @@ +--- +title: GaussianSquare +description: API reference for qiskit.pulse.library.GaussianSquare +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.library.GaussianSquare +--- + +# GaussianSquare + + + +`qiskit.pulse.library.GaussianSquare(duration, amp, sigma, width=None, angle=None, risefall_sigma_ratio=None, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A square pulse with a Gaussian shaped risefall on both sides lifted such that its first sample is zero. + +Exactly one of the `risefall_sigma_ratio` and `width` parameters has to be specified. + +If `risefall_sigma_ratio` is not None and `width` is None: + +$$ +\begin{aligned} +\text{risefall} &= \text{risefall\_sigma\_ratio} \times \text{sigma}\\ +\text{width} &= \text{duration} - 2 \times \text{risefall} +\end{aligned} +$$ + +If `width` is not None and `risefall_sigma_ratio` is None: + +$$ +\text{risefall} = \frac{\text{duration} - \text{width}}{2} + + +$$ + +In both cases, the lifted gaussian square pulse $f'(x)$ is defined as: + +$$ +\begin{aligned} +f'(x) &= \begin{cases} \exp\biggl(-\frac12 \frac{(x - \text{risefall})^2}{\text{sigma}^2}\biggr) & x < \text{risefall}\\ + 1 & \text{risefall} \le x < \text{risefall} + \text{width}\\ + \exp\biggl(-\frac12 \frac{{\bigl(x - (\text{risefall} + \text{width})\bigr)}^2} {\text{sigma}^2} \biggr) & \text{risefall} + \text{width} \le x \end{cases}\\ +f(x) &= \text{A} \times \frac{f'(x) - f'(-1)}{1-f'(-1)}, \quad 0 \le x < \text{duration} +\end{aligned} +$$ + +where $f'(x)$ is the gaussian square waveform without lifting or amplitude scaling, and $\text{A} = \text{amp} \times \exp\left(i\times\text{angle}\right)$. + +Create new pulse instance. + +**Parameters** + +* **duration** – Pulse length in terms of the sampling period dt. +* **amp** – The magnitude of the amplitude of the Gaussian and square pulse. Complex amp support is deprecated. +* **sigma** – A measure of how wide or narrow the Gaussian risefall is; see the class docstring for more details. +* **width** – The duration of the embedded square pulse. +* **angle** – The angle of the complex amplitude of the pulse. Default value 0. +* **risefall\_sigma\_ratio** – The ratio of each risefall duration to sigma. +* **name** – Display name for this pulse envelope. +* **limit\_amplitude** – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When width and risefall\_sigma\_ratio are both empty or both non-empty. + +## Attributes + + + +### alias + +`= 'GaussianSquare'` + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquareDrag.md b/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquareDrag.md new file mode 100644 index 00000000000..54c55a57c26 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.GaussianSquareDrag.md @@ -0,0 +1,90 @@ +--- +title: GaussianSquareDrag +description: API reference for qiskit.pulse.library.GaussianSquareDrag +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.GaussianSquareDrag +--- + + + +# qiskit.pulse.library.GaussianSquareDrag + + + +`qiskit.pulse.library.GaussianSquareDrag(duration, amp, sigma, beta, width=None, angle=0.0, risefall_sigma_ratio=None, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +A square pulse with a Drag shaped rise and fall + +This pulse shape is similar to [`GaussianSquare`](qiskit.pulse.library.GaussianSquare "qiskit.pulse.library.GaussianSquare") but uses [`Drag`](qiskit.pulse.library.Drag_class.rst#qiskit.pulse.library.Drag "qiskit.pulse.library.Drag") for its rise and fall instead of [`Gaussian`](qiskit.pulse.library.Gaussian_class.rst#qiskit.pulse.library.Gaussian "qiskit.pulse.library.Gaussian"). The addition of the DRAG component of the rise and fall is sometimes helpful in suppressing the spectral content of the pulse at frequencies near to, but slightly offset from, the fundamental frequency of the drive. When there is a spectator qubit close in frequency to the fundamental frequency, suppressing the drive at the spectator’s frequency can help avoid unwanted excitation of the spectator. + +Exactly one of the `risefall_sigma_ratio` and `width` parameters has to be specified. + +If `risefall_sigma_ratio` is not `None` and `width` is `None`: + +$$ +\begin{aligned} +\text{risefall} &= \text{risefall\_sigma\_ratio} \times \text{sigma}\\ +\text{width} &= \text{duration} - 2 \times \text{risefall} +\end{aligned} +$$ + +If `width` is not None and `risefall_sigma_ratio` is None: + +$$ +\text{risefall} = \frac{\text{duration} - \text{width}}{2} + + +$$ + +Gaussian $g(x, c, σ)$ and lifted gaussian $g'(x, c, σ)$ curves can be written as: + +$$ +\begin{aligned} +g(x, c, σ) &= \exp\Bigl(-\frac12 \frac{(x - c)^2}{σ^2}\Bigr)\\ +g'(x, c, σ) &= \frac{g(x, c, σ)-g(-1, c, σ)}{1-g(-1, c, σ)} +\end{aligned} +$$ + +From these, the lifted DRAG curve $d'(x, c, σ, β)$ can be written as + +$$ +d'(x, c, σ, β) = g'(x, c, σ) \times \Bigl(1 + 1j \times β \times \Bigl(-\frac{x - c}{σ^2}\Bigr)\Bigr) +$$ + +The lifted gaussian square drag pulse $f'(x)$ is defined as: + +$$ +\begin{aligned} +f'(x) &= \begin{cases} \text{A} \times d'(x, \text{risefall}, \text{sigma}, \text{beta}) & x < \text{risefall}\\ + \text{A} & \text{risefall} \le x < \text{risefall} + \text{width}\\ + \text{A} \times \times d'( x - (\text{risefall} + \text{width}), \text{risefall}, \text{sigma}, \text{beta} ) & \text{risefall} + \text{width} \le x \end{cases}\\ +\end{aligned} +$$ + +where $\text{A} = \text{amp} \times \exp\left(i\times\text{angle}\right)$. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The amplitude of the DRAG rise and fall and of the square pulse. +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A measure of how wide or narrow the DRAG risefall is; see the class docstring for more details. +* **beta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The DRAG correction amplitude. +* **width** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The duration of the embedded square pulse. +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **risefall\_sigma\_ratio** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The ratio of each risefall duration to sigma. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When width and risefall\_sigma\_ratio are both empty or both non-empty. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Gaussian_class.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Gaussian_class.rst.md new file mode 100644 index 00000000000..1af4a6bbbec --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Gaussian_class.rst.md @@ -0,0 +1,50 @@ +--- +title: Gaussian +description: API reference for qiskit.pulse.library.Gaussian +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.library.Gaussian +--- + +# Gaussian + + + +`qiskit.pulse.library.Gaussian(duration, amp, sigma, angle=None, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A lifted and truncated pulse envelope shaped according to the Gaussian function whose mean is centered at the center of the pulse (duration / 2): + +$$ +\begin{aligned} +f'(x) &= \exp\Bigl( -\frac12 \frac{{(x - \text{duration}/2)}^2}{\text{sigma}^2} \Bigr)\\ +f(x) &= \text{A} \times \frac{f'(x) - f'(-1)}{1-f'(-1)}, \quad 0 \le x < \text{duration} +\end{aligned} +$$ + +where $f'(x)$ is the gaussian waveform without lifting or amplitude scaling, and $\text{A} = \text{amp} \times \exp\left(i\times\text{angle}\right)$. + +Create new pulse instance. + +**Parameters** + +* **duration** – Pulse length in terms of the sampling period dt. +* **amp** – The magnitude of the amplitude of the Gaussian envelope. Complex amp support is deprecated. +* **sigma** – A measure of how wide or narrow the Gaussian peak is; described mathematically in the class docstring. +* **angle** – The angle of the complex amplitude of the Gaussian envelope. Default value 0. +* **name** – Display name for this pulse envelope. +* **limit\_amplitude** – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +## Attributes + + + +### alias + +`= 'Gaussian'` + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.ParametricPulse.md b/docs/api/qiskit/0.46/qiskit.pulse.library.ParametricPulse.md new file mode 100644 index 00000000000..37043893531 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.ParametricPulse.md @@ -0,0 +1,138 @@ +--- +title: ParametricPulse +description: API reference for qiskit.pulse.library.ParametricPulse +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.library.ParametricPulse +--- + +# ParametricPulse + + + +`qiskit.pulse.library.ParametricPulse(duration, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/parametric_pulses.py "view source code") + +Bases: `Pulse` + +The abstract superclass for parametric pulses. + + + This class was superseded by [`SymbolicPulse`](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") and is deprecated. It will be removed in Qiskit 1.0 because of the poor flexibility for defining a new waveform type and serializing it through the [`qiskit.qpy`](qpy#module-qiskit.qpy "qiskit.qpy") framework. + + +Create a parametric pulse and validate the input parameters. + + + The class `qiskit.pulse.library.parametric_pulses.ParametricPulse` is deprecated as of qiskit-terra 0.46. It will be removed in Qiskit 1.0. Instead, use SymbolicPulse because of QPY serialization support. See qiskit.pulse.library.symbolic\_pulses for details. + + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +## Attributes + + + +### duration + + + +### name + + + +### id + +Unique identifier for this pulse. + + + +### limit\_amplitude + +`= True` + + + +### parameters + +Return a dictionary containing the pulse’s parameters. + +## Methods + +### draw + + + +`draw(style=None, backend=None, time_range=None, time_unit='dt', show_waveform_info=True, plotter='mpl2d', axis=None)` + +Plot the interpolated envelope of pulse. + +**Parameters** + +* **style** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Stylesheet options. This can be dictionary or preset stylesheet classes. See `IQXStandard`, `IQXSimple`, and `IQXDebugging` for details of preset stylesheets. + +* **backend** (*Optional\[BaseBackend]*) – Backend object to play the input pulse program. If provided, the plotter may use to make the visualization hardware aware. + +* **time\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Set horizontal axis limit. Tuple `(tmin, tmax)`. + +* **time\_unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unit of specified time range either `dt` or `ns`. The unit of `ns` is available only when `backend` object is provided. + +* **show\_waveform\_info** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show waveform annotations, i.e. name, of waveforms. Set `True` to show additional information about waveforms. + +* **plotter** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – + + Name of plotter API to generate an output image. One of following APIs should be specified: + + ```python + mpl2d: Matplotlib API for 2D image generation. + Matplotlib API to generate 2D image. Charts are placed along y axis with + vertical offset. This API takes matplotlib.axes.Axes as `axis` input. + ``` + + axis and style kwargs may depend on the plotter. + +* **axis** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") *| None*) – Arbitrary object passed to the plotter. If this object is provided, the plotters use a given `axis` instead of internally initializing a figure object. This object format depends on the plotter. See plotter argument for details. + +**Returns** + +Visualization output data. The returned data type depends on the `plotter`. If matplotlib family is specified, this will be a `matplotlib.pyplot.Figure` data. + +### get\_waveform + + + +`abstract get_waveform()` + +Return a Waveform with samples filled according to the formula that the pulse represents and the parameter values it contains. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### validate\_parameters + + + +`abstract validate_parameters()` + +Validate parameters. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the parameters passed are not valid. + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Sawtooth_class.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Sawtooth_class.rst.md new file mode 100644 index 00000000000..f3c3f650ea7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Sawtooth_class.rst.md @@ -0,0 +1,45 @@ +--- +title: Sawtooth +description: API reference for qiskit.pulse.library.Sawtooth +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.Sawtooth +--- + + + +# qiskit.pulse.library.Sawtooth + + + +`qiskit.pulse.library.Sawtooth(duration, amp, phase, freq=None, angle=0.0, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +A sawtooth pulse. + +The envelope of the pulse is given by: + +$$ +f(x) = 2\text{A}\left[g\left(x\right)- + \lfloor g\left(x\right)+\frac{1}{2}\rfloor\right] +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$, $g\left(x\right)=x\times\text{freq}+\frac{\text{phase}}{2\pi}$, and $\lfloor ...\rfloor$ is the floor operation. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the sawtooth wave. Wave range is \[-amp,\`amp\`]. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The phase of the sawtooth wave (note that this is not equivalent to the angle of the complex amplitude) +* **freq** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The frequency of the sawtooth wave, in terms of 1 over sampling period. If not provided defaults to a single cycle (i.e :math:’frac\{1}\{text\{duration}}’). The frequency is limited to the range $\left(0,0.5\right]$ (the Nyquist frequency). +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.SechDeriv.md b/docs/api/qiskit/0.46/qiskit.pulse.library.SechDeriv.md new file mode 100644 index 00000000000..7a8151f033f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.SechDeriv.md @@ -0,0 +1,44 @@ +--- +title: SechDeriv +description: API reference for qiskit.pulse.library.SechDeriv +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.SechDeriv +--- + + + +# qiskit.pulse.library.SechDeriv + + + +`qiskit.pulse.library.SechDeriv(duration, amp, sigma, angle=0.0, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +An unnormalized sech derivative pulse. + +The sech function is centered around the halfway point of the pulse, and the envelope of the pulse is given by: + +$$ +f(x) = \text{A}\frac{d}{dx}\left[\text{sech} + \left(\frac{x-\mu}{\text{sigma}}\right)\right] , 0 <= x < duration +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$, $\mu=\text{duration}/2$, and $d/dx$ is a derivative with respect to x. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the pulse (the value of the corresponding sech function at the midpoint duration/2). +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A measure of how wide or narrow the corresponding sech peak is, in terms of dt; described mathematically in the class docstring. +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Sech_fun.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Sech_fun.rst.md new file mode 100644 index 00000000000..7ad40da19a5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Sech_fun.rst.md @@ -0,0 +1,53 @@ +--- +title: Sech +description: API reference for qiskit.pulse.library.Sech +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.Sech +--- + + + +# qiskit.pulse.library.Sech + + + +`qiskit.pulse.library.Sech(duration, amp, sigma, angle=0.0, name=None, zero_ends=True, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +An unnormalized sech pulse. + +The sech function is centered around the halfway point of the pulse, and the envelope of the pulse is given by: + +$$ +f(x) = \text{A}\text{sech}\left( + \frac{x-\mu}{\text{sigma}}\right) , 0 <= x < duration +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$, and $\mu=\text{duration}/2$. + +If zero\_ends is set to True, the output y is modified: .. math: + +```python +y\left(x\right) \mapsto \text{A}\frac{y-y^{*}}{\text{A}-y^{*}}, +``` + +where $y^{*}$ is the value of $y$ at the endpoints (at $x=-1 and :math:`x=\text{duration}+1$). This shifts the endpoints value to zero, while also rescaling to preserve the amplitude at :math:text\{duration}/2\`\`. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the pulse (the value at the midpoint duration/2). +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A measure of how wide or narrow the sech peak is in terms of dt; described mathematically in the class docstring. +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **zero\_ends** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If True, zeros the ends at x = -1, x = duration + 1, but rescales to preserve amp. Default value True. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Sin_class.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Sin_class.rst.md new file mode 100644 index 00000000000..770520300bf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Sin_class.rst.md @@ -0,0 +1,44 @@ +--- +title: Sin +description: API reference for qiskit.pulse.library.Sin +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.Sin +--- + + + +# qiskit.pulse.library.Sin + + + +`qiskit.pulse.library.Sin(duration, amp, phase, freq=None, angle=0.0, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +A sinusoidal pulse. + +The envelope of the pulse is given by: + +$$ +f(x) = \text{A}\sin\left(2\pi\text{freq}x+\text{phase}\right) , 0 <= x < duration +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the sinusoidal wave. Wave range is \[-amp,\`amp\`]. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The phase of the sinusoidal wave (note that this is not equivalent to the angle of the complex amplitude) +* **freq** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The frequency of the sinusoidal wave, in terms of 1 over sampling period. If not provided defaults to a single cycle (i.e :math:’frac\{1}\{text\{duration}}’). The frequency is limited to the range $\left(0,0.5\right]$ (the Nyquist frequency). +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Square_fun.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Square_fun.rst.md new file mode 100644 index 00000000000..3910c9f65d4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Square_fun.rst.md @@ -0,0 +1,45 @@ +--- +title: Square +description: API reference for qiskit.pulse.library.Square +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.Square +--- + + + +# qiskit.pulse.library.Square + + + +`qiskit.pulse.library.Square(duration, amp, phase, freq=None, angle=0.0, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +A square wave pulse. + +The envelope of the pulse is given by: + +$$ +f(x) = \text{A}\text{sign}\left[\sin + \left(2\pi x\times\text{freq}+\text{phase}\right)\right] , 0 <= x < duration +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$, and $\text{sign}$ is the sign function with the convention $\text{sign}\left(0\right)=1$. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the square wave. Wave range is \[-amp,\`amp\`]. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The phase of the square wave (note that this is not equivalent to the angle of the complex amplitude). +* **freq** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The frequency of the square wave, in terms of 1 over sampling period. If not provided defaults to a single cycle (i.e :math:’frac\{1}\{text\{duration}}’). The frequency is limited to the range $\left(0,0.5\right]$ (the Nyquist frequency). +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.SymbolicPulse.md b/docs/api/qiskit/0.46/qiskit.pulse.library.SymbolicPulse.md new file mode 100644 index 00000000000..14388e5870c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.SymbolicPulse.md @@ -0,0 +1,258 @@ +--- +title: SymbolicPulse +description: API reference for qiskit.pulse.library.SymbolicPulse +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.library.SymbolicPulse +--- + +# SymbolicPulse + + + +`qiskit.pulse.library.SymbolicPulse(pulse_type, duration, parameters=None, name=None, limit_amplitude=None, envelope=None, constraints=None, valid_amp_conditions=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +Bases: `Pulse` + +The pulse representation model with parameters and symbolic expressions. + +A symbolic pulse instance can be defined with an envelope and parameter constraints. Envelope and parameter constraints should be provided as symbolic expressions. Rather than creating a subclass, different pulse shapes can be distinguished by the instance attributes [`SymbolicPulse.envelope`](#qiskit.pulse.library.SymbolicPulse.envelope "qiskit.pulse.library.SymbolicPulse.envelope") and [`SymbolicPulse.pulse_type`](#qiskit.pulse.library.SymbolicPulse.pulse_type "qiskit.pulse.library.SymbolicPulse.pulse_type"). + +The symbolic expressions must be defined either with [SymPy](https://www.sympy.org/en/index.html) or [Symengine](https://symengine.org). Usually Symengine-based expression is much more performant for instantiation of the [`SymbolicPulse`](#qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse"), however, it doesn’t support every functions available in SymPy. You may need to choose proper library depending on how you define your pulses. Symengine works in the most envelopes and constraints, and thus it is recommended to use this library especially when your program contains a lot of pulses. Also note that Symengine has the limited platform support and may not be available for your local system. Symengine is a required dependency for Qiskit on platforms that support it will always be installed along with Qiskit on macOS `x86_64` and `arm64`, and Linux `x86_64`, `aarch64`, and `ppc64le`. For 64-bit Windows users they will need to manual install it. For 32-bit platforms such as `i686` and `armv7` Linux, and on Linux `s390x` there are no pre-compiled packages available and to use symengine you’ll need to compile it from source. If Symengine is not available in your environment SymPy will be used. + +**Envelope function** + +The waveform at time $t$ is generated by the [`get_waveform()`](#qiskit.pulse.library.SymbolicPulse.get_waveform "qiskit.pulse.library.SymbolicPulse.get_waveform") according to + +$$ +F(t, \Theta) = \times F(t, {\rm duration}, \overline{\rm params}) +$$ + +where $\Theta$ is the set of full pulse parameters in the [`SymbolicPulse.parameters`](#qiskit.pulse.library.SymbolicPulse.parameters "qiskit.pulse.library.SymbolicPulse.parameters") dictionary which must include the $\rm duration$. Note that the $F$ is an envelope of the waveform, and a programmer must provide this as a symbolic expression. $\overline{\rm params}$ can be arbitrary complex values as long as they pass [`validate_parameters()`](#qiskit.pulse.library.SymbolicPulse.validate_parameters "qiskit.pulse.library.SymbolicPulse.validate_parameters") and your quantum backend can accept. The time $t$ and $\rm duration$ are in units of dt, i.e. sample time resolution, and this function is sampled with a discrete time vector in $[0, {\rm duration}]$ sampling the pulse envelope at every 0.5 dt (middle sampling strategy) when the [`SymbolicPulse.get_waveform()`](#qiskit.pulse.library.SymbolicPulse.get_waveform "qiskit.pulse.library.SymbolicPulse.get_waveform") method is called. The sample data is not generated until this method is called thus a symbolic pulse instance only stores parameter values and waveform shape, which greatly reduces memory footprint during the program generation. + +**Constraint functions** + +Constraints on the parameters are defined with an instance attribute [`SymbolicPulse.constraints`](#qiskit.pulse.library.SymbolicPulse.constraints "qiskit.pulse.library.SymbolicPulse.constraints") which can be provided through the constructor. The constraints value must be a symbolic expression, which is a function of parameters to be validated and must return a boolean value being `True` when parameters are valid. If there are multiple conditions to be evaluated, these conditions can be concatenated with logical expressions such as `And` and `Or` in SymPy or Symengine. The symbolic pulse instance can be played only when the constraint function returns `True`. The constraint is evaluated when [`validate_parameters()`](#qiskit.pulse.library.SymbolicPulse.validate_parameters "qiskit.pulse.library.SymbolicPulse.validate_parameters") is called. + +**Maximum amplitude validation** + +When you play a pulse in a quantum backend, you might face the restriction on the power that your waveform generator can handle. Usually, the pulse amplitude is normalized by this maximum power, namely $\max |F| \leq 1$. This condition is evaluated along with above constraints when you set `limit_amplitude = True` in the constructor. To evaluate maximum amplitude of the waveform, we need to call [`get_waveform()`](#qiskit.pulse.library.SymbolicPulse.get_waveform "qiskit.pulse.library.SymbolicPulse.get_waveform"). However, this introduces a significant overhead in the validation, and this cannot be ignored when you repeatedly instantiate symbolic pulse instances. [`SymbolicPulse.valid_amp_conditions`](#qiskit.pulse.library.SymbolicPulse.valid_amp_conditions "qiskit.pulse.library.SymbolicPulse.valid_amp_conditions") provides a condition to skip this waveform validation, and the waveform is not generated as long as this condition returns `True`, so that healthy symbolic pulses are created very quick. For example, for a simple pulse shape like `amp * cos(f * t)`, we know that pulse amplitude is valid as long as `amp` remains less than magnitude 1.0. So `abs(amp) <= 1` could be passed as [`SymbolicPulse.valid_amp_conditions`](#qiskit.pulse.library.SymbolicPulse.valid_amp_conditions "qiskit.pulse.library.SymbolicPulse.valid_amp_conditions") to skip doing a full waveform evaluation for amplitude validation. This expression is provided through the constructor. If this is not provided, the waveform is generated everytime when [`validate_parameters()`](#qiskit.pulse.library.SymbolicPulse.validate_parameters "qiskit.pulse.library.SymbolicPulse.validate_parameters") is called. + +**Examples** + +This is how a user can instantiate a symbolic pulse instance. In this example, we instantiate a custom Sawtooth envelope. + +```python +from qiskit.pulse.library import SymbolicPulse + +my_pulse = SymbolicPulse( + pulse_type="Sawtooth", + duration=100, + parameters={"amp": 0.1, "freq": 0.05}, + name="pulse1", +) +``` + +Note that [`SymbolicPulse`](#qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") can be instantiated without providing the envelope and constraints. However, this instance cannot generate waveforms without knowing the envelope definition. Now you need to provide the envelope. + +```python +import sympy +from qiskit.pulse.library import SymbolicPulse + +t, amp, freq = sympy.symbols("t, amp, freq") +envelope = 2 * amp * (freq * t - sympy.floor(1 / 2 + freq * t)) + +my_pulse = SymbolicPulse( + pulse_type="Sawtooth", + duration=100, + parameters={"amp": 0.1, "freq": 0.05}, + envelope=envelope, + name="pulse1", +) + +my_pulse.draw() +``` + +![../\_images/qiskit-pulse-library-SymbolicPulse-1.png](/images/api/qiskit/0.46/qiskit-pulse-library-SymbolicPulse-1.png) + +Likewise, you can define [`SymbolicPulse.constraints`](#qiskit.pulse.library.SymbolicPulse.constraints "qiskit.pulse.library.SymbolicPulse.constraints") for `my_pulse`. After providing the envelope definition, you can generate the waveform data. Note that it would be convenient to define a factory function that automatically accomplishes this procedure. + +```python +def Sawtooth(duration, amp, freq, name): + t, amp, freq = sympy.symbols("t, amp, freq") + + instance = SymbolicPulse( + pulse_type="Sawtooth", + duration=duration, + parameters={"amp": amp, "freq": freq}, + envelope=2 * amp * (freq * t - sympy.floor(1 / 2 + freq * t)), + name=name, + ) + + return instance +``` + +You can also provide a `Parameter` object in the `parameters` dictionary, or define `duration` with a `Parameter` object when you instantiate the symbolic pulse instance. A waveform cannot be generated until you assign all unbounded parameters. Note that parameters will be assigned through the schedule playing the pulse. + +**Serialization** + +The [`SymbolicPulse`](#qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") subclass can be serialized along with the symbolic expressions through [`qiskit.qpy`](qpy#module-qiskit.qpy "qiskit.qpy"). A user can therefore create a custom pulse subclass with a novel envelope and constraints, and then one can instantiate the class with certain parameters to run on a backend. This pulse instance can be saved in the QPY binary, which can be loaded afterwards even within the environment not having original class definition loaded. This mechanism also allows us to easily share a pulse program including custom pulse instructions with collaborators. + +Create a parametric pulse. + +**Parameters** + +* **pulse\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Display name of this pulse shape. +* **duration** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Duration of pulse. +* **parameters** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*] | None*) – Dictionary of pulse parameters that defines the pulse envelope. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this particular pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the absolute value of the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. +* **envelope** (*Expr | None*) – Pulse envelope expression. +* **constraints** (*Expr | None*) – Pulse parameter constraint expression. +* **valid\_amp\_conditions** (*Expr | None*) – Extra conditions to skip a full-waveform check for the amplitude limit. If this condition is not met, then the validation routine will investigate the full-waveform and raise an error when the amplitude norm of any data point exceeds 1.0. If not provided, the validation always creates a full-waveform. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When not all parameters are listed in the attribute `PARAM_DEF`. + +## Attributes + + + +### constraints + +Return symbolic expression for the pulse parameter constraints. + + + +### duration + + + +### envelope + +Return symbolic expression for the pulse envelope. + + + +### id + +Unique identifier for this pulse. + + + +### limit\_amplitude + +`= True` + + + +### name + + + +### parameters + + + +### pulse\_type + +Return display name of the pulse shape. + + + +### valid\_amp\_conditions + +Return symbolic expression for the pulse amplitude constraints. + +## Methods + +### draw + + + +`draw(style=None, backend=None, time_range=None, time_unit='dt', show_waveform_info=True, plotter='mpl2d', axis=None)` + +Plot the interpolated envelope of pulse. + +**Parameters** + +* **style** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Stylesheet options. This can be dictionary or preset stylesheet classes. See `IQXStandard`, `IQXSimple`, and `IQXDebugging` for details of preset stylesheets. + +* **backend** (*Optional\[BaseBackend]*) – Backend object to play the input pulse program. If provided, the plotter may use to make the visualization hardware aware. + +* **time\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Set horizontal axis limit. Tuple `(tmin, tmax)`. + +* **time\_unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unit of specified time range either `dt` or `ns`. The unit of `ns` is available only when `backend` object is provided. + +* **show\_waveform\_info** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show waveform annotations, i.e. name, of waveforms. Set `True` to show additional information about waveforms. + +* **plotter** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – + + Name of plotter API to generate an output image. One of following APIs should be specified: + + ```python + mpl2d: Matplotlib API for 2D image generation. + Matplotlib API to generate 2D image. Charts are placed along y axis with + vertical offset. This API takes matplotlib.axes.Axes as `axis` input. + ``` + + axis and style kwargs may depend on the plotter. + +* **axis** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") *| None*) – Arbitrary object passed to the plotter. If this object is provided, the plotters use a given `axis` instead of internally initializing a figure object. This object format depends on the plotter. See plotter argument for details. + +**Returns** + +Visualization output data. The returned data type depends on the `plotter`. If matplotlib family is specified, this will be a `matplotlib.pyplot.Figure` data. + +### get\_waveform + + + +`get_waveform()` + +Return a Waveform with samples filled according to the formula that the pulse represents and the parameter values it contains. + +Since the returned array is a discretized time series of the continuous function, this method uses a midpoint sampler. For `duration`, return: + +$$ +\{f(t+0.5) \in \mathbb{C} | t \in \mathbb{Z} \wedge 0<=t<\texttt{duration}\} +$$ + +**Returns** + +A waveform representation of this pulse. + +**Raises** + +* [**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When parameters are not assigned. +* [**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When expression for pulse envelope is not assigned. + +**Return type** + +[*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### validate\_parameters + + + +`validate_parameters()` + +Validate parameters. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – If the parameters passed are not valid. + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Triangle_class.rst.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Triangle_class.rst.md new file mode 100644 index 00000000000..e2ee9f33ae5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Triangle_class.rst.md @@ -0,0 +1,44 @@ +--- +title: Triangle +description: API reference for qiskit.pulse.library.Triangle +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.Triangle +--- + + + +# qiskit.pulse.library.Triangle + + + +`qiskit.pulse.library.Triangle(duration, amp, phase, freq=None, angle=0.0, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +A triangle wave pulse. + +The envelope of the pulse is given by: + +$$ +f(x) = \text{A}\left[\text{sawtooth}\left(x\right)\right] , 0 <= x < duration +$$ + +where $\text{A} = \text{amp} \times\exp\left(i\times\text{angle}\right)$, and $\text{sawtooth}\left(x\right)$ is a sawtooth wave with the same frequency as the triangle wave, but a phase shifted by $\frac{\pi}{2}$. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The magnitude of the amplitude of the triangle wave. Wave range is \[-amp,\`amp\`]. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The phase of the triangle wave (note that this is not equivalent to the angle of the complex amplitude) +* **freq** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The frequency of the triangle wave, in terms of 1 over sampling period. If not provided defaults to a single cycle (i.e :math:’frac\{1}\{text\{duration}}’). The frequency is limited to the range $\left(0,0.5\right]$ (the Nyquist frequency). +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the pulse. Default value 0. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Return type** + +*ScalableSymbolicPulse* + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.Waveform.md b/docs/api/qiskit/0.46/qiskit.pulse.library.Waveform.md new file mode 100644 index 00000000000..f2b8f6b35f2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.Waveform.md @@ -0,0 +1,113 @@ +--- +title: Waveform +description: API reference for qiskit.pulse.library.Waveform +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.library.Waveform +--- + +# Waveform + + + +`qiskit.pulse.library.Waveform(samples, name=None, epsilon=1e-07, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/waveform.py "view source code") + +Bases: `Pulse` + +A pulse specified completely by complex-valued samples; each sample is played for the duration of the backend cycle-time, dt. + +Create new sample pulse command. + +**Parameters** + +* **samples** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *|*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]*) – Complex array of the samples in the pulse envelope. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Unique name to identify the pulse. +* **epsilon** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Pulse sample norm tolerance for clipping. If any sample’s norm exceeds unity by less than or equal to epsilon it will be clipped to unit norm. If the sample norm is greater than 1+epsilon an error will be raised. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – Passed to parent Pulse + +## Attributes + + + +### duration + + + +### name + + + +### id + +Unique identifier for this pulse. + + + +### limit\_amplitude + +`= True` + + + +### parameters + +Return a dictionary containing the pulse’s parameters. + + + +### samples + +Return sample values. + +## Methods + +### draw + + + +`draw(style=None, backend=None, time_range=None, time_unit='dt', show_waveform_info=True, plotter='mpl2d', axis=None)` + +Plot the interpolated envelope of pulse. + +**Parameters** + +* **style** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Stylesheet options. This can be dictionary or preset stylesheet classes. See `IQXStandard`, `IQXSimple`, and `IQXDebugging` for details of preset stylesheets. + +* **backend** (*Optional\[BaseBackend]*) – Backend object to play the input pulse program. If provided, the plotter may use to make the visualization hardware aware. + +* **time\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Set horizontal axis limit. Tuple `(tmin, tmax)`. + +* **time\_unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unit of specified time range either `dt` or `ns`. The unit of `ns` is available only when `backend` object is provided. + +* **show\_waveform\_info** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show waveform annotations, i.e. name, of waveforms. Set `True` to show additional information about waveforms. + +* **plotter** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – + + Name of plotter API to generate an output image. One of following APIs should be specified: + + ```python + mpl2d: Matplotlib API for 2D image generation. + Matplotlib API to generate 2D image. Charts are placed along y axis with + vertical offset. This API takes matplotlib.axes.Axes as `axis` input. + ``` + + axis and style kwargs may depend on the plotter. + +* **axis** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") *| None*) – Arbitrary object passed to the plotter. If this object is provided, the plotters use a given `axis` instead of internally initializing a figure object. This object format depends on the plotter. See plotter argument for details. + +**Returns** + +Visualization output data. The returned data type depends on the `plotter`. If matplotlib family is specified, this will be a `matplotlib.pyplot.Figure` data. + +### is\_parameterized + + + +`is_parameterized()` + +Return True iff the instruction is parameterized. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.library.gaussian_square_echo.md b/docs/api/qiskit/0.46/qiskit.pulse.library.gaussian_square_echo.md new file mode 100644 index 00000000000..80c17b389ff --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.library.gaussian_square_echo.md @@ -0,0 +1,77 @@ +--- +title: gaussian_square_echo +description: API reference for qiskit.pulse.library.gaussian_square_echo +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.pulse.library.gaussian_square_echo +--- + + + +# qiskit.pulse.library.gaussian\_square\_echo + + + +`qiskit.pulse.library.gaussian_square_echo(duration, amp, sigma, width=None, angle=0.0, active_amp=0.0, active_angle=0.0, risefall_sigma_ratio=None, name=None, limit_amplitude=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/library/symbolic_pulses.py "view source code") + +An echoed Gaussian square pulse with an active tone overlaid on it. + +The Gaussian Square Echo pulse is composed of three pulses. First, a Gaussian Square pulse $f_{echo}(x)$ with amplitude `amp` and phase `angle` playing for half duration, followed by a second Gaussian Square pulse $-f_{echo}(x)$ with opposite amplitude and same phase playing for the rest of the duration. Third a Gaussian Square pulse $f_{active}(x)$ with amplitude `active_amp` and phase `active_angle` playing for the entire duration. The Gaussian Square Echo pulse $g_e()$ can be written as: + +$$ +\begin{aligned} +g_e(x) &= \begin{cases} f_{\text{active}} + f_{\text{echo}}(x) & x < \frac{\text{duration}}{2}\\ + f_{\text{active}} - f_{\text{echo}}(x) & \frac{\text{duration}}{2} < x \end{cases}\\ +\end{aligned} +$$ + +One case where this pulse can be used is when implementing a direct CNOT gate with a cross-resonance superconducting qubit architecture. When applying this pulse to the target qubit, the active portion can be used to cancel IX terms from the cross-resonance drive while the echo portion can reduce the impact of a static ZZ coupling. + +Exactly one of the `risefall_sigma_ratio` and `width` parameters has to be specified. + +If `risefall_sigma_ratio` is not `None` and `width` is `None`: + +$$ +\begin{aligned} +\text{risefall} &= \text{risefall\_sigma\_ratio} \times \text{sigma}\\ +\text{width} &= \text{duration} - 2 \times \text{risefall} +\end{aligned} +$$ + +If `width` is not None and `risefall_sigma_ratio` is None: + +$$ +\text{risefall} = \frac{\text{duration} - \text{width}}{2} + + +$$ + +**References** + +1. [*Jurcevic, P., Javadi-Abhari, A., Bishop, L. S., Lauer, I., Bogorin, D. F., Brink, M., Capelluto, L., G\{“u}nl\{“u}k, O., Itoko, T., Kanazawa, N. & others Demonstration of quantum volume 64 on a superconducting quantum computing system. (Section V)*](https://iopscience.iop.org/article/10.1088/2058-9565/abe519) + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Pulse length in terms of the sampling period dt. +* **amp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – The amplitude of the rise and fall and of the echoed pulse. +* **sigma** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – A measure of how wide or narrow the risefall is; see the class docstring for more details. +* **width** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The duration of the embedded square pulse. +* **angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radians of the complex phase factor uniformly scaling the echoed pulse. Default value 0. +* **active\_amp** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The amplitude of the active pulse. +* **active\_angle** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The angle in radian of the complex phase factor uniformly scaling the active pulse. Default value 0. +* **risefall\_sigma\_ratio** ([*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The ratio of each risefall duration to sigma. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Display name for this pulse envelope. +* **limit\_amplitude** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If `True`, then limit the amplitude of the waveform to 1. The default is `True` and the amplitude is constrained to 1. + +**Returns** + +ScalableSymbolicPulse instance. + +**Raises** + +[**PulseError**](pulse#qiskit.pulse.PulseError "qiskit.pulse.PulseError") – When width and risefall\_sigma\_ratio are both empty or both non-empty. + +**Return type** + +[*SymbolicPulse*](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.symbolic_pulses.SymbolicPulse") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignEquispaced.md b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignEquispaced.md new file mode 100644 index 00000000000..5c220683540 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignEquispaced.md @@ -0,0 +1,62 @@ +--- +title: AlignEquispaced +description: API reference for qiskit.pulse.transforms.AlignEquispaced +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.transforms.AlignEquispaced +--- + +# AlignEquispaced + + + +`qiskit.pulse.transforms.AlignEquispaced(duration)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/alignments.py "view source code") + +Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +Align instructions with equispaced interval within a specified duration. + +Instructions played on different channels are also arranged in a sequence. This alignment is convenient to create dynamical decoupling sequences such as PDD. + +Create new equispaced context. + +**Parameters** + +**duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Duration of this context. This should be larger than the schedule duration. If the specified duration is shorter than the schedule duration, no alignment is performed and the input schedule is just returned. This duration can be parametrized. + +## Attributes + + + +### duration + +Return context duration. + + + +### is\_sequential + +## Methods + +### align + + + +`align(schedule)` + +Reallocate instructions according to the policy. + +Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. + +**Parameters** + +**schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – Schedule to align. + +**Returns** + +Schedule with reallocated instructions. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignFunc.md b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignFunc.md new file mode 100644 index 00000000000..9f1a159ff4b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignFunc.md @@ -0,0 +1,82 @@ +--- +title: AlignFunc +description: API reference for qiskit.pulse.transforms.AlignFunc +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.transforms.AlignFunc +--- + +# AlignFunc + + + +`qiskit.pulse.transforms.AlignFunc(duration, func)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/alignments.py "view source code") + +Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +Allocate instructions at position specified by callback function. + +The position is specified for each instruction of index `j` as a fractional coordinate in \[0, 1] within the specified duration. + +Instructions played on different channels are also arranged in a sequence. This alignment is convenient to create dynamical decoupling sequences such as UDD. + +For example, UDD sequence with 10 pulses can be specified with following function. + +```python +def udd10_pos(j): +return np.sin(np.pi*j/(2*10 + 2))**2 +``` + + + This context cannot be QPY serialized because of the callable. If you use this context, your program cannot be saved in QPY format. + + +Create new equispaced context. + +**Parameters** + +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.parameterexpression.ParameterExpression")) – Duration of this context. This should be larger than the schedule duration. If the specified duration is shorter than the schedule duration, no alignment is performed and the input schedule is just returned. This duration can be parametrized. +* **func** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")) – A function that takes an index of sub-schedule and returns the fractional coordinate of of that sub-schedule. The returned value should be defined within \[0, 1]. The pulse index starts from 1. + +## Attributes + + + +### duration + +Return context duration. + + + +### func + +Return context alignment function. + + + +### is\_sequential + +## Methods + +### align + + + +`align(schedule)` + +Reallocate instructions according to the policy. + +Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. + +**Parameters** + +**schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – Schedule to align. + +**Returns** + +Schedule with reallocated instructions. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignLeft.md b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignLeft.md new file mode 100644 index 00000000000..913fff433db --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignLeft.md @@ -0,0 +1,52 @@ +--- +title: AlignLeft +description: API reference for qiskit.pulse.transforms.AlignLeft +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.transforms.AlignLeft +--- + +# AlignLeft + + + +`qiskit.pulse.transforms.AlignLeft`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/alignments.py "view source code") + +Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +Align instructions in as-soon-as-possible manner. + +Instructions are placed at earliest available timeslots. + +Create new left-justified context. + +## Attributes + + + +### is\_sequential + +## Methods + +### align + + + +`align(schedule)` + +Reallocate instructions according to the policy. + +Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. + +**Parameters** + +**schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – Schedule to align. + +**Returns** + +Schedule with reallocated instructions. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignRight.md b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignRight.md new file mode 100644 index 00000000000..63beef9db7b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignRight.md @@ -0,0 +1,52 @@ +--- +title: AlignRight +description: API reference for qiskit.pulse.transforms.AlignRight +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.transforms.AlignRight +--- + +# AlignRight + + + +`qiskit.pulse.transforms.AlignRight`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/alignments.py "view source code") + +Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +Align instructions in as-late-as-possible manner. + +Instructions are placed at latest available timeslots. + +Create new right-justified context. + +## Attributes + + + +### is\_sequential + +## Methods + +### align + + + +`align(schedule)` + +Reallocate instructions according to the policy. + +Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. + +**Parameters** + +**schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – Schedule to align. + +**Returns** + +Schedule with reallocated instructions. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignSequential.md b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignSequential.md new file mode 100644 index 00000000000..30e2864a2d6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.pulse.transforms.AlignSequential.md @@ -0,0 +1,52 @@ +--- +title: AlignSequential +description: API reference for qiskit.pulse.transforms.AlignSequential +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.pulse.transforms.AlignSequential +--- + +# AlignSequential + + + +`qiskit.pulse.transforms.AlignSequential`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/pulse/transforms/alignments.py "view source code") + +Bases: [`AlignmentKind`](pulse#qiskit.pulse.transforms.AlignmentKind "qiskit.pulse.transforms.alignments.AlignmentKind") + +Align instructions sequentially. + +Instructions played on different channels are also arranged in a sequence. No buffer time is inserted in between instructions. + +Create new sequential context. + +## Attributes + + + +### is\_sequential + +## Methods + +### align + + + +`align(schedule)` + +Reallocate instructions according to the policy. + +Only top-level sub-schedules are aligned. If sub-schedules are nested, nested schedules are not recursively aligned. + +**Parameters** + +**schedule** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule")) – Schedule to align. + +**Returns** + +Schedule with reallocated instructions. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.GateCalibration.md b/docs/api/qiskit/0.46/qiskit.qobj.GateCalibration.md new file mode 100644 index 00000000000..7d83034a566 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.GateCalibration.md @@ -0,0 +1,65 @@ +--- +title: GateCalibration +description: API reference for qiskit.qobj.GateCalibration +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.GateCalibration +--- + +# GateCalibration + + + +`qiskit.qobj.GateCalibration(name, qubits, params, instructions)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/qasm_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Each calibration specifies a unique gate by name, qubits and params, and contains the Pulse instructions to implement it. + +Initialize a single gate calibration. Instructions may reference waveforms which should be made available in the pulse\_library. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Gate name. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*)*) – Qubits the gate applies to. +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*)*) – Gate parameter values, if any. +* **instructions** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*PulseQobjInstruction*](qiskit.qobj.PulseQobjInstruction "qiskit.qobj.PulseQobjInstruction")*)*) – The gate implementation. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new GateCalibration object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the GateCalibration to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.GateCalibration.to_dict "qiskit.qobj.GateCalibration.to_dict"). + +**Returns** + +The GateCalibration from the input dictionary. + +**Return type** + +[GateCalibration](#qiskit.qobj.GateCalibration "qiskit.qobj.GateCalibration") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Gate Calibration. + +**Returns** + +The dictionary form of the GateCalibration. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.PulseLibraryItem.md b/docs/api/qiskit/0.46/qiskit.qobj.PulseLibraryItem.md new file mode 100644 index 00000000000..3d607960751 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.PulseLibraryItem.md @@ -0,0 +1,63 @@ +--- +title: PulseLibraryItem +description: API reference for qiskit.qobj.PulseLibraryItem +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.PulseLibraryItem +--- + +# PulseLibraryItem + + + +`qiskit.qobj.PulseLibraryItem(name, samples)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/pulse_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +An item in a pulse library. + +Instantiate a pulse library item. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A name for the pulse. +* **samples** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]*) – A list of complex values defining pulse shape. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new PulseLibraryItem object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the experiment config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[PulseLibraryItem](#qiskit.qobj.PulseLibraryItem "qiskit.qobj.PulseLibraryItem") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the pulse library item. + +**Returns** + +The dictionary form of the PulseLibraryItem. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.PulseQobj.md b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobj.md new file mode 100644 index 00000000000..decbaddfd3a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobj.md @@ -0,0 +1,84 @@ +--- +title: PulseQobj +description: API reference for qiskit.qobj.PulseQobj +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.PulseQobj +--- + +# PulseQobj + + + +`qiskit.qobj.PulseQobj(qobj_id, config, experiments, header=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/pulse_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A Pulse Qobj. + +Instantiate a new Pulse Qobj Object. + +Each Pulse Qobj object is used to represent a single payload that will be passed to a Qiskit provider. It mirrors the Qobj the published [Qobj specification](https://arxiv.org/abs/1809.03452) for Pulse experiments. + +**Parameters** + +* **qobj\_id** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An identifier for the qobj +* **config** ([*PulseQobjConfig*](qiskit.qobj.PulseQobjConfig "qiskit.qobj.PulseQobjConfig")) – A config for the entire run +* **header** ([*QobjHeader*](qiskit.qobj.QobjHeader "qiskit.qobj.QobjHeader")) – A header for the entire run +* **experiments** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of lists of [`PulseQobjExperiment`](qiskit.qobj.PulseQobjExperiment "qiskit.qobj.PulseQobjExperiment") objects representing an experiment + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new PulseQobj object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the PulseQobj to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.PulseQobj.to_dict "qiskit.qobj.PulseQobj.to_dict"). + +**Returns** + +The PulseQobj from the input dictionary. + +**Return type** + +[PulseQobj](#qiskit.qobj.PulseQobj "qiskit.qobj.PulseQobj") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Pulse Qobj. + +Note this dict is not in the json wire format expected by IBMQ and qobj specification because complex numbers are still of type complex. Also this may contain native numpy arrays. When serializing this output for use with IBMQ you can leverage a json encoder that converts these as expected. For example: + +```python +import json +import numpy + +class QobjEncoder(json.JSONEncoder): + def default(self, obj): + if isinstance(obj, numpy.ndarray): + return obj.tolist() + if isinstance(obj, complex): + return (obj.real, obj.imag) + return json.JSONEncoder.default(self, obj) + +json.dumps(qobj.to_dict(), cls=QobjEncoder) +``` + +**Returns** + +A dictionary representation of the PulseQobj object + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjConfig.md b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjConfig.md new file mode 100644 index 00000000000..f0d15776ff7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjConfig.md @@ -0,0 +1,73 @@ +--- +title: PulseQobjConfig +description: API reference for qiskit.qobj.PulseQobjConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.PulseQobjConfig +--- + +# PulseQobjConfig + + + +`qiskit.qobj.PulseQobjConfig(meas_level, meas_return, pulse_library, qubit_lo_freq, meas_lo_freq, memory_slot_size=None, rep_time=None, rep_delay=None, shots=None, seed_simulator=None, memory_slots=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/pulse_qobj.py "view source code") + +Bases: `QobjDictField` + +A configuration for a Pulse Qobj. + +Instantiate a PulseQobjConfig object. + +**Parameters** + +* **meas\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The measurement level to use. +* **meas\_return** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The level of measurement information to return. +* **pulse\_library** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of [`PulseLibraryItem`](qiskit.qobj.PulseLibraryItem "qiskit.qobj.PulseLibraryItem") objects which define the set of primitive pulses +* **qubit\_lo\_freq** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of frequencies (as floats) for the qubit driver LO’s in GHz. +* **meas\_lo\_freq** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of frequencies (as floats) for the’ measurement driver LO’s in GHz. +* **memory\_slot\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Size of each memory slot if the output is Level 0. +* **rep\_time** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time per program execution in sec. Must be from the list provided by the backend (`backend.configuration().rep_times`). Defaults to the first entry in `backend.configuration().rep_times`. +* **rep\_delay** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Delay between programs in sec. Only supported on certain backends (`backend.configuration().dynamic_reprate_enabled` ). If supported, `rep_delay` will be used instead of `rep_time` and must be from the range supplied by the backend (`backend.configuration().rep_delay_range`). Default is `backend.configuration().default_rep_delay`. +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of shots +* **seed\_simulator** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the seed to use in the simulator +* **memory\_slots** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The number of memory slots on the device +* **kwargs** – Additional free form key value fields to add to the configuration + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new PulseQobjConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[PulseQobjConfig](#qiskit.qobj.PulseQobjConfig "qiskit.qobj.PulseQobjConfig") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Pulse Qobj config. + +**Returns** + +The dictionary form of the PulseQobjConfig. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperiment.md b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperiment.md new file mode 100644 index 00000000000..bf4b7534b2a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperiment.md @@ -0,0 +1,66 @@ +--- +title: PulseQobjExperiment +description: API reference for qiskit.qobj.PulseQobjExperiment +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.PulseQobjExperiment +--- + +# PulseQobjExperiment + + + +`qiskit.qobj.PulseQobjExperiment(instructions, config=None, header=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/pulse_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A Pulse Qobj Experiment. + +Each instance of this class is used to represent an individual Pulse experiment as part of a larger Pulse Qobj. + +Instantiate a PulseQobjExperiment. + +**Parameters** + +* **config** ([*PulseQobjExperimentConfig*](qiskit.qobj.PulseQobjExperimentConfig "qiskit.qobj.PulseQobjExperimentConfig")) – A config object for the experiment +* **header** (*PulseQobjExperimentHeader*) – A header object for the experiment +* **instructions** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of [`PulseQobjInstruction`](qiskit.qobj.PulseQobjInstruction "qiskit.qobj.PulseQobjInstruction") objects + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new PulseQobjExperiment object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the experiment config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[PulseQobjExperiment](#qiskit.qobj.PulseQobjExperiment "qiskit.qobj.PulseQobjExperiment") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Experiment. + +**Returns** + +The dictionary form of the PulseQobjExperiment. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperimentConfig.md b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperimentConfig.md new file mode 100644 index 00000000000..6233282afa2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjExperimentConfig.md @@ -0,0 +1,64 @@ +--- +title: PulseQobjExperimentConfig +description: API reference for qiskit.qobj.PulseQobjExperimentConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.PulseQobjExperimentConfig +--- + +# PulseQobjExperimentConfig + + + +`qiskit.qobj.PulseQobjExperimentConfig(qubit_lo_freq=None, meas_lo_freq=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/pulse_qobj.py "view source code") + +Bases: `QobjDictField` + +A config for a single Pulse experiment in the qobj. + +Instantiate a PulseQobjExperimentConfig object. + +**Parameters** + +* **qubit\_lo\_freq** (*List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of qubit LO frequencies in GHz. +* **meas\_lo\_freq** (*List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of meas readout LO frequencies in GHz. +* **kwargs** – Additional free form key value fields to add to the configuration + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QobjHeader object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the QobjHeader to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.PulseQobjExperimentConfig.to_dict "qiskit.qobj.PulseQobjExperimentConfig.to_dict"). + +**Returns** + +The QobjDictField from the input dictionary. + +**Return type** + +QobjDictFieldr + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the OpenQASM 2 Qobj. + +**Returns** + +The dictionary form of the QobjHeader. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjInstruction.md b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjInstruction.md new file mode 100644 index 00000000000..a10e26aa2e6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.PulseQobjInstruction.md @@ -0,0 +1,78 @@ +--- +title: PulseQobjInstruction +description: API reference for qiskit.qobj.PulseQobjInstruction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.PulseQobjInstruction +--- + +# PulseQobjInstruction + + + +`qiskit.qobj.PulseQobjInstruction(name, t0, ch=None, conditional=None, val=None, phase=None, duration=None, qubits=None, memory_slot=None, register_slot=None, kernels=None, discriminators=None, label=None, type=None, pulse_shape=None, parameters=None, frequency=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/pulse_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A class representing a single instruction in an PulseQobj Experiment. + +Instantiate a new PulseQobjInstruction object. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the instruction +* **t0** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Pulse start time in integer **dt** units. +* **ch** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The channel to apply the pulse instruction. +* **conditional** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The register to use for a conditional for this instruction +* **val** ([*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")) – Complex value to apply, bounded by an absolute value of 1. +* **phase** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – if a `fc` instruction, the frame change phase in radians. +* **frequency** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – if a `sf` instruction, the frequency in Hz. +* **duration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The duration of the pulse in **dt** units. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of `int` representing the qubits the instruction operates on +* **memory\_slot** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – If a `measure` instruction this is a list of `int` containing the list of memory slots to store the measurement results in (must be the same length as qubits). If a `bfunc` instruction this is a single `int` of the memory slot to store the boolean function result in. +* **register\_slot** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – If a `measure` instruction this is a list of `int` containing the list of register slots in which to store the measurement results (must be the same length as qubits). If a `bfunc` instruction this is a single `int` of the register slot in which to store the result. +* **kernels** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of [`QobjMeasurementOption`](qiskit.qobj.QobjMeasurementOption "qiskit.qobj.QobjMeasurementOption") objects defining the measurement kernels and set of parameters if the measurement level is 1 or 2. Only used for `acquire` instructions. +* **discriminators** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of [`QobjMeasurementOption`](qiskit.qobj.QobjMeasurementOption "qiskit.qobj.QobjMeasurementOption") used to set the discriminators to be used if the measurement level is 2. Only used for `acquire` instructions. +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Label of instruction +* **type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Type of instruction +* **pulse\_shape** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The shape of the parametric pulse +* **parameters** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The parameters for a parametric pulse + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new PulseQobjExperimentConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the experiment config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[PulseQobjInstruction](#qiskit.qobj.PulseQobjInstruction "qiskit.qobj.PulseQobjInstruction") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Instruction. + +**Returns** + +The dictionary form of the PulseQobjInstruction. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QasmExperimentCalibrations.md b/docs/api/qiskit/0.46/qiskit.qobj.QasmExperimentCalibrations.md new file mode 100644 index 00000000000..a1bfe465e57 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QasmExperimentCalibrations.md @@ -0,0 +1,62 @@ +--- +title: QasmExperimentCalibrations +description: API reference for qiskit.qobj.QasmExperimentCalibrations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QasmExperimentCalibrations +--- + +# QasmExperimentCalibrations + + + +`qiskit.qobj.QasmExperimentCalibrations(gates)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/qasm_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A container for any calibrations data. The gates attribute contains a list of GateCalibrations. + +Initialize a container for calibrations. + +**Parameters** + +**gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*GateCalibration*](qiskit.qobj.GateCalibration "qiskit.qobj.GateCalibration")*)*) – + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new GateCalibration object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the QasmExperimentCalibrations to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.QasmExperimentCalibrations.to_dict "qiskit.qobj.QasmExperimentCalibrations.to_dict"). + +**Returns** + +The QasmExperimentCalibrations from the input dictionary. + +**Return type** + +[QasmExperimentCalibrations](#qiskit.qobj.QasmExperimentCalibrations "qiskit.qobj.QasmExperimentCalibrations") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the calibrations. + +**Returns** + +The dictionary form of the GateCalibration. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QasmQobj.md b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobj.md new file mode 100644 index 00000000000..fa3039bb4eb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobj.md @@ -0,0 +1,84 @@ +--- +title: QasmQobj +description: API reference for qiskit.qobj.QasmQobj +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QasmQobj +--- + +# QasmQobj + + + +`qiskit.qobj.QasmQobj(qobj_id=None, config=None, experiments=None, header=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/qasm_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +An OpenQASM 2 Qobj. + +Instantiate a new OpenQASM 2 Qobj Object. + +Each OpenQASM 2 Qobj object is used to represent a single payload that will be passed to a Qiskit provider. It mirrors the Qobj the published [Qobj specification](https://arxiv.org/abs/1809.03452) for OpenQASM experiments. + +**Parameters** + +* **qobj\_id** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An identifier for the qobj +* **config** (*QasmQobjRunConfig*) – A config for the entire run +* **header** ([*QobjHeader*](qiskit.qobj.QobjHeader "qiskit.qobj.QobjHeader")) – A header for the entire run +* **experiments** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of lists of [`QasmQobjExperiment`](qiskit.qobj.QasmQobjExperiment "qiskit.qobj.QasmQobjExperiment") objects representing an experiment + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QASMQobj object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the QasmQobj to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.QasmQobj.to_dict "qiskit.qobj.QasmQobj.to_dict"). + +**Returns** + +The QasmQobj from the input dictionary. + +**Return type** + +[QasmQobj](#qiskit.qobj.QasmQobj "qiskit.qobj.QasmQobj") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the OpenQASM 2 Qobj. + +Note this dict is not in the json wire format expected by IBM and Qobj specification because complex numbers are still of type complex. Also, this may contain native numpy arrays. When serializing this output for use with IBM systems, you can leverage a json encoder that converts these as expected. For example: + +```python +import json +import numpy + +class QobjEncoder(json.JSONEncoder): + def default(self, obj): + if isinstance(obj, numpy.ndarray): + return obj.tolist() + if isinstance(obj, complex): + return (obj.real, obj.imag) + return json.JSONEncoder.default(self, obj) + +json.dumps(qobj.to_dict(), cls=QobjEncoder) +``` + +**Returns** + +A dictionary representation of the QasmQobj object + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjConfig.md b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjConfig.md new file mode 100644 index 00000000000..85d12ad1dd5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjConfig.md @@ -0,0 +1,75 @@ +--- +title: QasmQobjConfig +description: API reference for qiskit.qobj.QasmQobjConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QasmQobjConfig +--- + +# QasmQobjConfig + + + +`qiskit.qobj.QasmQobjConfig(shots=None, seed_simulator=None, memory=None, parameter_binds=None, meas_level=None, meas_return=None, memory_slots=None, n_qubits=None, pulse_library=None, calibrations=None, rep_delay=None, qubit_lo_freq=None, meas_lo_freq=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/qasm_qobj.py "view source code") + +Bases: [`SimpleNamespace`](https://docs.python.org/3/library/types.html#types.SimpleNamespace "(in Python v3.12)") + +A configuration for an OpenQASM 2 Qobj. + +Model for RunConfig. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of shots. +* **seed\_simulator** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the seed to use in the simulator +* **memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to request memory from backend (per-shot readouts) +* **parameter\_binds** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*]*) – List of parameter bindings +* **meas\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Measurement level 0, 1, or 2 +* **meas\_return** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – For measurement level \< 2, whether single or avg shots are returned +* **memory\_slots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of memory slots on the device +* **n\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits on the device +* **pulse\_library** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of [`PulseLibraryItem`](qiskit.qobj.PulseLibraryItem "qiskit.qobj.PulseLibraryItem"). +* **calibrations** ([*QasmExperimentCalibrations*](qiskit.qobj.QasmExperimentCalibrations "qiskit.qobj.QasmExperimentCalibrations")) – Information required for Pulse gates. +* **rep\_delay** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Delay between programs in sec. Only supported on certain backends (`backend.configuration().dynamic_reprate_enabled` ). Must be from the range supplied by the backend (`backend.configuration().rep_delay_range`). Default is `backend.configuration().default_rep_delay`. +* **qubit\_lo\_freq** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of frequencies (as floats) for the qubit driver LO’s in GHz. +* **meas\_lo\_freq** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of frequencies (as floats) for the measurement driver LO’s in GHz. +* **kwargs** – Additional free form key value fields to add to the configuration. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QasmQobjConfig object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[QasmQobjConfig](#qiskit.qobj.QasmQobjConfig "qiskit.qobj.QasmQobjConfig") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the OpenQASM 2 Qobj config. + +**Returns** + +The dictionary form of the QasmQobjConfig. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperiment.md b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperiment.md new file mode 100644 index 00000000000..2f88fa0a5fa --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperiment.md @@ -0,0 +1,66 @@ +--- +title: QasmQobjExperiment +description: API reference for qiskit.qobj.QasmQobjExperiment +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QasmQobjExperiment +--- + +# QasmQobjExperiment + + + +`qiskit.qobj.QasmQobjExperiment(config=None, header=None, instructions=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/qasm_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +An OpenQASM 2 Qobj Experiment. + +Each instance of this class is used to represent an OpenQASM 2 experiment as part of a larger OpenQASM 2 qobj. + +Instantiate a QasmQobjExperiment. + +**Parameters** + +* **config** ([*QasmQobjExperimentConfig*](qiskit.qobj.QasmQobjExperimentConfig "qiskit.qobj.QasmQobjExperimentConfig")) – A config object for the experiment +* **header** (*QasmQobjExperimentHeader*) – A header object for the experiment +* **instructions** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of [`QasmQobjInstruction`](qiskit.qobj.QasmQobjInstruction "qiskit.qobj.QasmQobjInstruction") objects + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QasmQobjExperiment object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the experiment config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[QasmQobjExperiment](#qiskit.qobj.QasmQobjExperiment "qiskit.qobj.QasmQobjExperiment") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Experiment. + +**Returns** + +The dictionary form of the QasmQObjExperiment. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperimentConfig.md b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperimentConfig.md new file mode 100644 index 00000000000..1f0b1641370 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjExperimentConfig.md @@ -0,0 +1,63 @@ +--- +title: QasmQobjExperimentConfig +description: API reference for qiskit.qobj.QasmQobjExperimentConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QasmQobjExperimentConfig +--- + +# QasmQobjExperimentConfig + + + +`qiskit.qobj.QasmQobjExperimentConfig(calibrations=None, qubit_lo_freq=None, meas_lo_freq=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/qasm_qobj.py "view source code") + +Bases: `QobjDictField` + +Configuration for a single OpenQASM 2 experiment in the qobj. + +**Parameters** + +* **calibrations** ([*QasmExperimentCalibrations*](qiskit.qobj.QasmExperimentCalibrations "qiskit.qobj.QasmExperimentCalibrations")) – Information required for Pulse gates. +* **qubit\_lo\_freq** (*List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of qubit LO frequencies in GHz. +* **meas\_lo\_freq** (*List\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – List of meas readout LO frequencies in GHz. +* **kwargs** – Additional free form key value fields to add to the configuration + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QobjHeader object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the QobjHeader to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.QasmQobjExperimentConfig.to_dict "qiskit.qobj.QasmQobjExperimentConfig.to_dict"). + +**Returns** + +The QobjDictField from the input dictionary. + +**Return type** + +QobjDictFieldr + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the OpenQASM 2 Qobj. + +**Returns** + +The dictionary form of the QobjHeader. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjInstruction.md b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjInstruction.md new file mode 100644 index 00000000000..2bbca305490 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QasmQobjInstruction.md @@ -0,0 +1,73 @@ +--- +title: QasmQobjInstruction +description: API reference for qiskit.qobj.QasmQobjInstruction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QasmQobjInstruction +--- + +# QasmQobjInstruction + + + +`qiskit.qobj.QasmQobjInstruction(name, params=None, qubits=None, register=None, memory=None, condition=None, conditional=None, label=None, mask=None, relation=None, val=None, snapshot_type=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/qasm_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A class representing a single instruction in an QasmQobj Experiment. + +Instantiate a new QasmQobjInstruction object. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the instruction +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The list of parameters for the gate +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of `int` representing the qubits the instruction operates on +* **register** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – If a `measure` instruction this is a list of `int` containing the list of register slots in which to store the measurement results (must be the same length as qubits). If a `bfunc` instruction this is a single `int` of the register slot in which to store the result. +* **memory** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – If a `measure` instruction this is a list of `int` containing the list of memory slots to store the measurement results in (must be the same length as qubits). If a `bfunc` instruction this is a single `int` of the memory slot to store the boolean function result in. +* **condition** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – A tuple of the form `(int, int)` where the first `int` is the control register and the second `int` is the control value if the gate has a condition. +* **conditional** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The register index of the condition +* **label** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional label assigned to the instruction +* **mask** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – For a `bfunc` instruction the hex value which is applied as an `AND` to the register bits. +* **relation** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Relational operator for comparing the masked register to the `val` kwarg. Can be either `==` (equals) or `!=` (not equals). +* **val** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Value to which to compare the masked register. In other words, the output of the function is `(register AND mask)` +* **snapshot\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – For snapshot instructions the type of snapshot to use + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QasmQobjInstruction object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the experiment config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[QasmQobjInstruction](#qiskit.qobj.QasmQobjInstruction "qiskit.qobj.QasmQobjInstruction") + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Instruction. + +**Returns** + +The dictionary form of the QasmQobjInstruction. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QobjExperimentHeader.md b/docs/api/qiskit/0.46/qiskit.qobj.QobjExperimentHeader.md new file mode 100644 index 00000000000..4d39794d8fe --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QobjExperimentHeader.md @@ -0,0 +1,62 @@ +--- +title: QobjExperimentHeader +description: API reference for qiskit.qobj.QobjExperimentHeader +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QobjExperimentHeader +--- + +# QobjExperimentHeader + + + +`qiskit.qobj.QobjExperimentHeader(**kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/common.py "view source code") + +Bases: [`QobjHeader`](qiskit.qobj.QobjHeader "qiskit.qobj.common.QobjHeader") + +A class representing a header dictionary for a Qobj Experiment. + +Instantiate a new Qobj dict field object. + +**Parameters** + +**kwargs** – arbitrary keyword arguments that can be accessed as attributes of the object. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QobjHeader object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the QobjHeader to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.QobjExperimentHeader.to_dict "qiskit.qobj.QobjExperimentHeader.to_dict"). + +**Returns** + +The QobjDictField from the input dictionary. + +**Return type** + +QobjDictFieldr + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the OpenQASM 2 Qobj. + +**Returns** + +The dictionary form of the QobjHeader. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QobjHeader.md b/docs/api/qiskit/0.46/qiskit.qobj.QobjHeader.md new file mode 100644 index 00000000000..f079518f430 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QobjHeader.md @@ -0,0 +1,62 @@ +--- +title: QobjHeader +description: API reference for qiskit.qobj.QobjHeader +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QobjHeader +--- + +# QobjHeader + + + +`qiskit.qobj.QobjHeader(**kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/common.py "view source code") + +Bases: `QobjDictField` + +A class used to represent a dictionary header in Qobj objects. + +Instantiate a new Qobj dict field object. + +**Parameters** + +**kwargs** – arbitrary keyword arguments that can be accessed as attributes of the object. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QobjHeader object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the QobjHeader to create. It will be in the same format as output by [`to_dict()`](#qiskit.qobj.QobjHeader.to_dict "qiskit.qobj.QobjHeader.to_dict"). + +**Returns** + +The QobjDictField from the input dictionary. + +**Return type** + +QobjDictFieldr + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the OpenQASM 2 Qobj. + +**Returns** + +The dictionary form of the QobjHeader. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.qobj.QobjMeasurementOption.md b/docs/api/qiskit/0.46/qiskit.qobj.QobjMeasurementOption.md new file mode 100644 index 00000000000..63deedcf568 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.qobj.QobjMeasurementOption.md @@ -0,0 +1,63 @@ +--- +title: QobjMeasurementOption +description: API reference for qiskit.qobj.QobjMeasurementOption +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.qobj.QobjMeasurementOption +--- + +# QobjMeasurementOption + + + +`qiskit.qobj.QobjMeasurementOption(name, params=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qobj/pulse_qobj.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +An individual measurement option. + +Instantiate a new QobjMeasurementOption object. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the measurement option +* **params** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The parameters of the measurement option. + +## Methods + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new QobjMeasurementOption object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary for the experiment config + +**Returns** + +The object from the input dictionary. + +**Return type** + +[QobjMeasurementOption](#qiskit.qobj.QobjMeasurementOption "qiskit.qobj.QobjMeasurementOption") + +### to\_dict + + + +`to_dict()` + +Return a dict format representation of the QobjMeasurementOption. + +**Returns** + +The dictionary form of the QasmMeasurementOption. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.CNOTDihedral.md b/docs/api/qiskit/0.46/qiskit.quantum_info.CNOTDihedral.md new file mode 100644 index 00000000000..bfbb10a5c39 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.CNOTDihedral.md @@ -0,0 +1,361 @@ +--- +title: CNOTDihedral +description: API reference for qiskit.quantum_info.CNOTDihedral +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.CNOTDihedral +--- + +# CNOTDihedral + + + +`qiskit.quantum_info.CNOTDihedral(data=None, num_qubits=None, validate=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/dihedral/dihedral.py "view source code") + +Bases: `BaseOperator`, `AdjointMixin` + +An N-qubit operator from the CNOT-Dihedral group. + +> The CNOT-Dihedral group is generated by the quantum gates, [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"), [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"), and [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"). +> +> **Representation** +> +> An $N$-qubit CNOT-Dihedral operator is stored as an affine function and a phase polynomial, based on the convention in references \[1, 2]. +> +> The affine function consists of an $N \times N$ invertible binary matrix, and an $N$ binary vector. +> +> The phase polynomial is a polynomial of degree at most 3, in $N$ variables, whose coefficients are in the ring Z\_8 with 8 elements. +> +> ```python +> from qiskit import QuantumCircuit +> from qiskit.quantum_info import CNOTDihedral +> +> circ = QuantumCircuit(3) +> circ.cx(0, 1) +> circ.x(2) +> circ.t(1) +> circ.t(1) +> circ.t(1) +> elem = CNOTDihedral(circ) +> +> # Print the CNOTDihedral element +> print(elem) +> ``` + +```python +phase polynomial = +0 + 3*x_0 + 3*x_1 + 2*x_0*x_1 +affine function = + (x_0,x_0 + x_1,x_2 + 1) +``` + +**Circuit Conversion** + +> CNOTDihedral operators can be initialized from circuits containing *only* the following gates: [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate"), [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"), [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate"), [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate"), [`TGate`](qiskit.circuit.library.TGate "qiskit.circuit.library.TGate"), [`TdgGate`](qiskit.circuit.library.TdgGate "qiskit.circuit.library.TdgGate") [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"), [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"), [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate"), [`CSGate`](qiskit.circuit.library.CSGate "qiskit.circuit.library.CSGate"), [`CSdgGate`](qiskit.circuit.library.CSdgGate "qiskit.circuit.library.CSdgGate"), [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"), [`CCZGate`](qiskit.circuit.library.CCZGate "qiskit.circuit.library.CCZGate"). They can be converted back into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") object using the [`to_circuit()`](#qiskit.quantum_info.CNOTDihedral.to_circuit "qiskit.quantum_info.CNOTDihedral.to_circuit") or `to_instruction()` methods respectively. Note that this decomposition is not necessarily optimal in terms of number of gates if the number of qubits is more than two. +> +> CNOTDihedral operators can also be converted to [`Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") objects using the [`to_operator()`](#qiskit.quantum_info.CNOTDihedral.to_operator "qiskit.quantum_info.CNOTDihedral.to_operator") method. This is done via decomposing to a circuit, and then simulating the circuit as a unitary operator. +> +> **References:** +> +> 1. Shelly Garion and Andrew W. Cross, *Synthesis of CNOT-Dihedral circuits with optimal number of two qubit gates*, [Quantum 4(369), 2020](https://quantum-journal.org/papers/q-2020-12-07-369/) +> 2. Andrew W. Cross, Easwar Magesan, Lev S. Bishop, John A. Smolin and Jay M. Gambetta, *Scalable randomised benchmarking of non-Clifford gates*, npj Quantum Inf 2, 16012 (2016). + +Initialize a CNOTDihedral operator object. + +**Parameters** + +* **data** ([*CNOTDihedral*](#qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")) – Optional, operator to initialize. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional, initialize an empty CNOTDihedral operator. +* **validate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, validates the CNOTDihedral element. + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the type is invalid. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if validate=True and the CNOTDihedral element is invalid. + +## Attributes + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### name + +Unique string identifier for operation type. + + + +### num\_clbits + +Number of classical bits. + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the Operator. + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another CNOTDihedral. + +**Parameters** + +* **other** ([*CNOTDihedral*](#qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral")) – a CNOTDihedral object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed CNOTDihedral. + +**Return type** + +[CNOTDihedral](#qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.CNOTDihedral.dot "qiskit.quantum_info.CNOTDihedral.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.CNOTDihedral.dot "qiskit.quantum_info.CNOTDihedral.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate of the CNOTDihedral. + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another CNOTDihedral. + +**Parameters** + +**other** ([*CNOTDihedral*](#qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral")) – a CNOTDihedral object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current CNOTDihedral, and $b$ is the other CNOTDihedral. + +**Return type** + +[CNOTDihedral](#qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the compose of a operator with itself n times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of times to compose with self (n>0). + +**Returns** + +the n-times composed operator. + +**Return type** + +[Clifford](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the operator are not equal, or the power is not a positive integer. + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another CNOTDihedral. + +**Parameters** + +**other** ([*CNOTDihedral*](#qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral")) – a CNOTDihedral object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current CNOTDihedral, and $b$ is the other CNOTDihedral. + +**Return type** + +[CNOTDihedral](#qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_circuit + + + +`to_circuit()` + +Return a QuantumCircuit implementing the CNOT-Dihedral element. + +**Returns** + +a circuit implementation of the CNOTDihedral object. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**References** + +1. Shelly Garion and Andrew W. Cross, *Synthesis of CNOT-Dihedral circuits with optimal number of two qubit gates*, [Quantum 4(369), 2020](https://quantum-journal.org/papers/q-2020-12-07-369/) +2. Andrew W. Cross, Easwar Magesan, Lev S. Bishop, John A. Smolin and Jay M. Gambetta, *Scalable randomised benchmarking of non-Clifford gates*, npj Quantum Inf 2, 16012 (2016). + +### to\_instruction + + + +`to_instruction()` + +Return a Gate instruction implementing the CNOTDihedral object. + +### to\_matrix + + + +`to_matrix()` + +Convert operator to Numpy matrix. + +### to\_operator + + + +`to_operator()` + +Convert to an Operator object. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose of the CNOTDihedral. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Chi.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Chi.md new file mode 100644 index 00000000000..3a4e4f6885c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Chi.md @@ -0,0 +1,395 @@ +--- +title: Chi +description: API reference for qiskit.quantum_info.Chi +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Chi +--- + +# Chi + + + +`qiskit.quantum_info.Chi(data, input_dims=None, output_dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/channel/chi.py "view source code") + +Bases: `QuantumChannel` + +Pauli basis Chi-matrix representation of a quantum channel. + +The Chi-matrix representation of an $n$-qubit quantum channel $\mathcal{E}$ is a matrix $\chi$ such that the evolution of a [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") $\rho$ is given by + +$$ +\mathcal{E}(ρ) = \frac{1}{2^n} \sum_{i, j} \chi_{i,j} P_i ρ P_j +$$ + +where $[P_0, P_1, ..., P_{4^{n}-1}]$ is the $n$-qubit Pauli basis in lexicographic order. It is related to the [`Choi`](qiskit.quantum_info.Choi "qiskit.quantum_info.Choi") representation by a change of basis of the Choi-matrix into the Pauli basis. The $\frac{1}{2^n}$ in the definition above is a normalization factor that arises from scaling the Pauli basis to make it orthonormal. + +See reference \[1] for further details. + +**References** + +1. C.J. Wood, J.D. Biamonte, D.G. Cory, *Tensor networks and graphical calculus for open quantum systems*, Quant. Inf. Comp. 15, 0579-0811 (2015). [arXiv:1111.6950 \[quant-ph\]](https://arxiv.org/abs/1111.6950) + +Initialize a quantum channel Chi-matrix operator. + +**Parameters** + +* **or** (*data (*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Instruction or BaseOperator or matrix): data to initialize superoperator. +* **input\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input subsystem dimensions. \[Default: None] +* **output\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the output subsystem dimensions. \[Default: None] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit channel or cannot be initialized as a Chi-matrix. + +**Additional Information:** + +If the input or output dimensions are None, they will be automatically determined from the input data. The Chi matrix representation is only valid for N-qubit channels. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +Return data. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint quantum channel. + + + This is equivalent to the matrix Hermitian conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the adjoint channel $\mathcal{{E}}^\dagger$ is $S_{\mathcal{E}^\dagger} = S_{\mathcal{E}}^\dagger$. + + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another Chi. + +**Parameters** + +* **other** ([*Chi*](#qiskit.quantum_info.Chi "qiskit.quantum_info.Chi")) – a Chi object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed Chi. + +**Return type** + +[Chi](#qiskit.quantum_info.Chi "qiskit.quantum_info.Chi") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.Chi.dot "qiskit.quantum_info.Chi.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.Chi.dot "qiskit.quantum_info.Chi.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate quantum channel. + + + This is equivalent to the matrix complex conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the conjugate channel $\overline{{\mathcal{{E}}}}$ is $S_{\overline{\mathcal{E}^\dagger}} = \overline{S_{\mathcal{E}}}$. + + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another Chi. + +**Parameters** + +**other** ([*Chi*](#qiskit.quantum_info.Chi "qiskit.quantum_info.Chi")) – a Chi object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current Chi, and $b$ is the other Chi. + +**Return type** + +[Chi](#qiskit.quantum_info.Chi "qiskit.quantum_info.Chi") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_cp + + + +`is_cp(atol=None, rtol=None)` + +Test if Choi-matrix is completely-positive (CP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_cptp + + + +`is_cptp(atol=None, rtol=None)` + +Return True if completely-positive trace-preserving (CPTP). + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_tp + + + +`is_tp(atol=None, rtol=None)` + +Test if a channel is trace-preserving (TP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if QuantumChannel is a unitary channel. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the power of the quantum channel. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power exponent. + +**Returns** + +the channel $\mathcal{{E}} ^n$. + +**Return type** + +[SuperOp](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the SuperOp are not equal. + + + For non-positive or non-integer exponents the power is defined as the matrix power of the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{{E}}$, the SuperOp of the powered channel $\mathcal{{E}}^\n$ is $S_{{\mathcal{{E}}^n}} = S_{{\mathcal{{E}}}}^n$. + + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another Chi. + +**Parameters** + +**other** ([*Chi*](#qiskit.quantum_info.Chi "qiskit.quantum_info.Chi")) – a Chi object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current Chi, and $b$ is the other Chi. + +**Return type** + +[Chi](#qiskit.quantum_info.Chi "qiskit.quantum_info.Chi") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to a Kraus or UnitaryGate circuit instruction. + +If the channel is unitary it will be added as a unitary gate, otherwise it will be added as a kraus simulator instruction. + +**Returns** + +A kraus instruction for the channel. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit CPTP quantum channel. + +### to\_operator + + + +`to_operator()` + +Try to convert channel to a unitary representation Operator. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose quantum channel. + + + This is equivalent to the matrix transpose in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation, ie. for a channel $\mathcal{E}$, the SuperOp of the transpose channel $\mathcal{{E}}^T$ is $S_{mathcal{E}^T} = S_{\mathcal{E}}^T$. + + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Choi.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Choi.md new file mode 100644 index 00000000000..4d23ae851bf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Choi.md @@ -0,0 +1,407 @@ +--- +title: Choi +description: API reference for qiskit.quantum_info.Choi +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Choi +--- + +# Choi + + + +`qiskit.quantum_info.Choi(data, input_dims=None, output_dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/channel/choi.py "view source code") + +Bases: `QuantumChannel` + +Choi-matrix representation of a Quantum Channel. + +The Choi-matrix representation of a quantum channel $\mathcal{E}$ is a matrix + +$$ +\Lambda = \sum_{i,j} |i\rangle\!\langle j|\otimes + \mathcal{E}\left(|i\rangle\!\langle j|\right) +$$ + +Evolution of a [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") $\rho$ with respect to the Choi-matrix is given by + +$$ +\mathcal{E}(\rho) = \mbox{Tr}_{1}\left[\Lambda + (\rho^T \otimes \mathbb{I})\right] +$$ + +where $\mbox{Tr}_1$ is the [`partial_trace()`](quantum_info#qiskit.quantum_info.partial_trace "qiskit.quantum_info.partial_trace") over subsystem 1. + +See reference \[1] for further details. + +**References** + +1. C.J. Wood, J.D. Biamonte, D.G. Cory, *Tensor networks and graphical calculus for open quantum systems*, Quant. Inf. Comp. 15, 0579-0811 (2015). [arXiv:1111.6950 \[quant-ph\]](https://arxiv.org/abs/1111.6950) + +Initialize a quantum channel Choi matrix operator. + +**Parameters** + +* **or** (*data (*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Instruction or BaseOperator or matrix): data to initialize superoperator. +* **input\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input subsystem dimensions. \[Default: None] +* **output\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the output subsystem dimensions. \[Default: None] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data cannot be initialized as a Choi matrix. + +**Additional Information:** + +If the input or output dimensions are None, they will be automatically determined from the input data. If the input data is a Numpy array of shape (4\*\*N, 4\*\*N) qubit systems will be used. If the input operator is not an N-qubit operator, it will assign a single subsystem with dimension specified by the shape of the input. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +Return data. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint quantum channel. + + + This is equivalent to the matrix Hermitian conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the adjoint channel $\mathcal{{E}}^\dagger$ is $S_{\mathcal{E}^\dagger} = S_{\mathcal{E}}^\dagger$. + + +**Return type** + +*Self* + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another Choi. + +**Parameters** + +* **other** ([*Choi*](#qiskit.quantum_info.Choi "qiskit.quantum_info.Choi")) – a Choi object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed Choi. + +**Return type** + +[Choi](#qiskit.quantum_info.Choi "qiskit.quantum_info.Choi") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.Choi.dot "qiskit.quantum_info.Choi.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.Choi.dot "qiskit.quantum_info.Choi.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate quantum channel. + + + This is equivalent to the matrix complex conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the conjugate channel $\overline{{\mathcal{{E}}}}$ is $S_{\overline{\mathcal{E}^\dagger}} = \overline{S_{\mathcal{E}}}$. + + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another Choi. + +**Parameters** + +**other** ([*Choi*](#qiskit.quantum_info.Choi "qiskit.quantum_info.Choi")) – a Choi object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current Choi, and $b$ is the other Choi. + +**Return type** + +[Choi](#qiskit.quantum_info.Choi "qiskit.quantum_info.Choi") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_cp + + + +`is_cp(atol=None, rtol=None)` + +Test if Choi-matrix is completely-positive (CP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_cptp + + + +`is_cptp(atol=None, rtol=None)` + +Return True if completely-positive trace-preserving (CPTP). + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_tp + + + +`is_tp(atol=None, rtol=None)` + +Test if a channel is trace-preserving (TP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if QuantumChannel is a unitary channel. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the power of the quantum channel. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power exponent. + +**Returns** + +the channel $\mathcal{{E}} ^n$. + +**Return type** + +[SuperOp](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the SuperOp are not equal. + + + For non-positive or non-integer exponents the power is defined as the matrix power of the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{{E}}$, the SuperOp of the powered channel $\mathcal{{E}}^\n$ is $S_{{\mathcal{{E}}^n}} = S_{{\mathcal{{E}}}}^n$. + + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another Choi. + +**Parameters** + +**other** ([*Choi*](#qiskit.quantum_info.Choi "qiskit.quantum_info.Choi")) – a Choi object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current Choi, and $b$ is the other Choi. + +**Return type** + +[Choi](#qiskit.quantum_info.Choi "qiskit.quantum_info.Choi") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to a Kraus or UnitaryGate circuit instruction. + +If the channel is unitary it will be added as a unitary gate, otherwise it will be added as a kraus simulator instruction. + +**Returns** + +A kraus instruction for the channel. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit CPTP quantum channel. + +### to\_operator + + + +`to_operator()` + +Try to convert channel to a unitary representation Operator. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose quantum channel. + + + This is equivalent to the matrix transpose in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation, ie. for a channel $\mathcal{E}$, the SuperOp of the transpose channel $\mathcal{{E}}^T$ is $S_{mathcal{E}^T} = S_{\mathcal{E}}^T$. + + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Clifford.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Clifford.md new file mode 100644 index 00000000000..352b6a551b9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Clifford.md @@ -0,0 +1,661 @@ +--- +title: Clifford +description: API reference for qiskit.quantum_info.Clifford +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Clifford +--- + +# Clifford + + + +`qiskit.quantum_info.Clifford(data, validate=True, copy=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/clifford.py "view source code") + +Bases: `BaseOperator`, `AdjointMixin`, [`Operation`](qiskit.circuit.Operation "qiskit.circuit.operation.Operation") + +An N-qubit unitary operator from the Clifford group. + +**Representation** + +An *N*-qubit Clifford operator is stored as a length *2N × (2N+1)* boolean tableau using the convention from reference \[1]. + +* Rows 0 to *N-1* are the *destabilizer* group generators +* Rows *N* to *2N-1* are the *stabilizer* group generators. + +The internal boolean tableau for the Clifford can be accessed using the `tableau` attribute. The destabilizer or stabilizer rows can each be accessed as a length-N Stabilizer table using [`destab`](#qiskit.quantum_info.Clifford.destab "qiskit.quantum_info.Clifford.destab") and [`stab`](#qiskit.quantum_info.Clifford.stab "qiskit.quantum_info.Clifford.stab") attributes. + +A more easily human readable representation of the Clifford operator can be obtained by calling the [`to_dict()`](#qiskit.quantum_info.Clifford.to_dict "qiskit.quantum_info.Clifford.to_dict") method. This representation is also used if a Clifford object is printed as in the following example + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import Clifford + +# Bell state generation circuit +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) +cliff = Clifford(qc) + +# Print the Clifford +print(cliff) + +# Print the Clifford destabilizer rows +print(cliff.to_labels(mode="D")) + +# Print the Clifford stabilizer rows +print(cliff.to_labels(mode="S")) +``` + +```python +Clifford: Stabilizer = ['+XX', '+ZZ'], Destabilizer = ['+IZ', '+XI'] +['+IZ', '+XI'] +['+XX', '+ZZ'] +``` + +**Circuit Conversion** + +Clifford operators can be initialized from circuits containing *only* the following Clifford gates: [`IGate`](qiskit.circuit.library.IGate "qiskit.circuit.library.IGate"), [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate"), [`YGate`](qiskit.circuit.library.YGate "qiskit.circuit.library.YGate"), [`ZGate`](qiskit.circuit.library.ZGate "qiskit.circuit.library.ZGate"), [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate"), [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate"), [`SdgGate`](qiskit.circuit.library.SdgGate "qiskit.circuit.library.SdgGate"), [`SXGate`](qiskit.circuit.library.SXGate "qiskit.circuit.library.SXGate"), [`SXdgGate`](qiskit.circuit.library.SXdgGate "qiskit.circuit.library.SXdgGate"), [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"), [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate"), [`CYGate`](qiskit.circuit.library.CYGate "qiskit.circuit.library.CYGate"), `DXGate`, [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate"), [`iSwapGate`](qiskit.circuit.library.iSwapGate "qiskit.circuit.library.iSwapGate"), [`ECRGate`](qiskit.circuit.library.ECRGate "qiskit.circuit.library.ECRGate"), [`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction"), [`PermutationGate`](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate"). They can be converted back into a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), or [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") object using the [`to_circuit()`](#qiskit.quantum_info.Clifford.to_circuit "qiskit.quantum_info.Clifford.to_circuit") or [`to_instruction()`](#qiskit.quantum_info.Clifford.to_instruction "qiskit.quantum_info.Clifford.to_instruction") methods respectively. Note that this decomposition is not necessarily optimal in terms of number of gates. + + + A minimally generating set of gates for Clifford circuits is the [`HGate`](qiskit.circuit.library.HGate "qiskit.circuit.library.HGate") and [`SGate`](qiskit.circuit.library.SGate "qiskit.circuit.library.SGate") gate and *either* the [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") or [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate") two-qubit gate. + + +Clifford operators can also be converted to [`Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") objects using the [`to_operator()`](#qiskit.quantum_info.Clifford.to_operator "qiskit.quantum_info.Clifford.to_operator") method. This is done via decomposing to a circuit, and then simulating the circuit as a unitary operator. + +**References** + +1. S. Aaronson, D. Gottesman, *Improved Simulation of Stabilizer Circuits*, Phys. Rev. A 70, 052328 (2004). [arXiv:quant-ph/0406196](https://arxiv.org/abs/quant-ph/0406196) + +Initialize an operator object. + +## Attributes + + + +### destab + +The destabilizer array for the symplectic representation. + + + +### destab\_phase + +Return phase of destabilizer with boolean representation. + + + +### destab\_x + +The destabilizer x array for the symplectic representation. + + + +### destab\_z + +The destabilizer z array for the symplectic representation. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### name + +Unique string identifier for operation type. + + + +### num\_clbits + +Number of classical bits. + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### phase + +Return phase with boolean representation. + + + +### qargs + +Return the qargs for the operator. + + + +### stab + +The stabilizer array for the symplectic representation. + + + +### stab\_phase + +Return phase of stabilizer with boolean representation. + + + +### stab\_x + +The stabilizer x array for the symplectic representation. + + + +### stab\_z + +The stabilizer array for the symplectic representation. + + + +### symplectic\_matrix + +Return boolean symplectic matrix. + + + +### x + +The x array for the symplectic representation. + + + +### z + +The z array for the symplectic representation. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the Operator. + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another Clifford. + +**Parameters** + +* **other** ([*Clifford*](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a Clifford object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed Clifford. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.Clifford.dot "qiskit.quantum_info.Clifford.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.Clifford.dot "qiskit.quantum_info.Clifford.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate of the Clifford. + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another Clifford. + +**Parameters** + +**other** ([*Clifford*](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a Clifford object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current Clifford, and $b$ is the other Clifford. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +### from\_circuit + + + +`static from_circuit(circuit)` + +Initialize from a QuantumCircuit or Instruction. + +**Parameters** + +**circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")) – instruction to initialize. + +**Returns** + +the Clifford object for the instruction. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input instruction is non-Clifford or contains classical register instruction. + +### from\_dict + + + +`classmethod from_dict(obj)` + +Load a Clifford from a dictionary + +### from\_label + + + +`static from_label(label)` + +Return a tensor product of single-qubit Clifford gates. + +**Parameters** + +**label** (*string*) – single-qubit operator string. + +**Returns** + +The N-qubit Clifford operator. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the label contains invalid characters. + +**Additional Information:** + +The labels correspond to the single-qubit Cliffords are + +* * Label + * Stabilizer + * Destabilizer +* * `"I"` + * +Z + * +X +* * `"X"` + * -Z + * +X +* * `"Y"` + * -Z + * -X +* * `"Z"` + * +Z + * -X +* * `"H"` + * +X + * +Z +* * `"S"` + * +Z + * +Y + +### from\_linear\_function + + + +`classmethod from_linear_function(linear_function)` + +Create a Clifford from a Linear Function. + +If the linear function is represented by a nxn binary invertible matrix A, then the corresponding Clifford has symplectic matrix \[\[A^t, 0], \[0, A^\{-1}]]. + +**Parameters** + +**linear\_function** ([*LinearFunction*](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction")) – A linear function to be converted. + +**Returns** + +the Clifford object for this linear function. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +### from\_matrix + + + +`classmethod from_matrix(matrix)` + +Create a Clifford from a unitary matrix. + +Note that this function takes exponentially long time w\.r.t. the number of qubits. + +**Parameters** + +**matrix** (*np.array*) – A unitary matrix representing a Clifford to be converted. + +**Returns** + +the Clifford object for the unitary matrix. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input is not a Clifford matrix. + +### from\_operator + + + +`classmethod from_operator(operator)` + +Create a Clifford from a operator. + +Note that this function takes exponentially long time w\.r.t. the number of qubits. + +**Parameters** + +**operator** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – An operator representing a Clifford to be converted. + +**Returns** + +the Clifford object for the operator. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input is not a Clifford operator. + +### from\_permutation + + + +`classmethod from_permutation(permutation_gate)` + +Create a Clifford from a PermutationGate. + +**Parameters** + +**permutation\_gate** ([*PermutationGate*](qiskit.circuit.library.PermutationGate "qiskit.circuit.library.PermutationGate")) – A permutation to be converted. + +**Returns** + +the Clifford object for this permutation. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_unitary + + + +`is_unitary()` + +Return True if the Clifford table is valid. + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the compose of a operator with itself n times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of times to compose with self (n>0). + +**Returns** + +the n-times composed operator. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the operator are not equal, or the power is not a positive integer. + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another Clifford. + +**Parameters** + +**other** ([*Clifford*](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a Clifford object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current Clifford, and $b$ is the other Clifford. + +**Return type** + +[Clifford](#qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_circuit + + + +`to_circuit()` + +Return a QuantumCircuit implementing the Clifford. + +For N \<= 3 qubits this is based on optimal CX cost decomposition from reference \[1]. For N > 3 qubits this is done using the general non-optimal compilation routine from reference \[2]. + +**Returns** + +a circuit implementation of the Clifford. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**References** + +1. S. Bravyi, D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*, [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) +2. S. Aaronson, D. Gottesman, *Improved Simulation of Stabilizer Circuits*, Phys. Rev. A 70, 052328 (2004). [arXiv:quant-ph/0406196](https://arxiv.org/abs/quant-ph/0406196) + +### to\_dict + + + +`to_dict()` + +Return dictionary representation of Clifford object. + +### to\_instruction + + + +`to_instruction()` + +Return a Gate instruction implementing the Clifford. + +### to\_labels + + + +`to_labels(array=False, mode='B')` + +Convert a Clifford to a list Pauli (de)stabilizer string labels. + +For large Clifford converting using the `array=True` kwarg will be more efficient since it allocates memory for the full Numpy array of labels in advance. + +| Label | Phase | Symplectic | Matrix | Pauli | +| ------ | ----- | ---------- | ------------------------------------------------ | ----- | +| `"+I"` | 0 | $[0, 0]$ | $\begin{bmatrix} 1 & 0 \\ 0 & 1 \end{bmatrix}$ | $I$ | +| `"-I"` | 1 | $[0, 0]$ | $\begin{bmatrix} -1 & 0 \\ 0 & -1 \end{bmatrix}$ | $-I$ | +| `"X"` | 0 | $[1, 0]$ | $\begin{bmatrix} 0 & 1 \\ 1 & 0 \end{bmatrix}$ | $X$ | +| `"-X"` | 1 | $[1, 0]$ | $\begin{bmatrix} 0 & -1 \\ -1 & 0 \end{bmatrix}$ | $-X$ | +| `"Y"` | 0 | $[1, 1]$ | $\begin{bmatrix} 0 & 1 \\ -1 & 0 \end{bmatrix}$ | $iY$ | +| `"-Y"` | 1 | $[1, 1]$ | $\begin{bmatrix} 0 & -1 \\ 1 & 0 \end{bmatrix}$ | $-iY$ | +| `"Z"` | 0 | $[0, 1]$ | $\begin{bmatrix} 1 & 0 \\ 0 & -1 \end{bmatrix}$ | $Z$ | +| `"-Z"` | 1 | $[0, 1]$ | $\begin{bmatrix} -1 & 0 \\ 0 & 1 \end{bmatrix}$ | $-Z$ | + +**Parameters** + +* **array** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – return a Numpy array if True, otherwise return a list (Default: False). +* **mode** (*Literal\["S", "D", "B"]*) – return both stabilizer and destabilizer if “B”, return only stabilizer if “S” and return only destabilizer if “D”. + +**Returns** + +The rows of the StabilizerTable in label form. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") or array + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if stabilizer and destabilizer are both False. + +### to\_matrix + + + +`to_matrix()` + +Convert operator to Numpy matrix. + +### to\_operator + + + +`to_operator()` + +Convert to an Operator object. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose of the Clifford. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.DensityMatrix.md b/docs/api/qiskit/0.46/qiskit.quantum_info.DensityMatrix.md new file mode 100644 index 00000000000..7803a2dea97 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.DensityMatrix.md @@ -0,0 +1,703 @@ +--- +title: DensityMatrix +description: API reference for qiskit.quantum_info.DensityMatrix +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.DensityMatrix +--- + +# DensityMatrix + + + +`qiskit.quantum_info.DensityMatrix(data, dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/densitymatrix.py "view source code") + +Bases: `QuantumState`, `TolerancesMixin` + +DensityMatrix class + +Initialize a density matrix object. + +**Parameters** + +* **or** (*data (np.ndarray or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or matrix\_like or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – qiskit.circuit.Instruction): A statevector, quantum instruction or an object with a `to_operator` or `to_matrix` method from which the density matrix can be constructed. If a vector the density matrix is constructed as the projector of that vector. If a quantum instruction, the density matrix is constructed by assuming all qubits are initialized in the zero state. +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Optional. The subsystem dimension of the state (See additional information). + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not valid. + +**Additional Information:** + +The `dims` kwarg can be None, an integer, or an iterable of integers. + +* `Iterable` – the subsystem dimensions are the values in the list with the total number of subsystems given by the length of the list. +* `Int` or `None` – the leading dimension of the input matrix specifies the total dimension of the density matrix. If it is a power of two the state will be initialized as an N-qubit state. If it is not a power of two the state will have a single d-dimensional subsystem. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +Return data. + + + +### dim + +Return total state dimension. + + + +### num\_qubits + +Return the number of qubits if a N-qubit state or None otherwise. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### conjugate + + + +`conjugate()` + +Return the conjugate of the density matrix. + +### copy + + + +`copy()` + +Make a copy of current operator. + +### dims + + + +`dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### draw + + + +`draw(output=None, **drawer_args)` + +Return a visualization of the Statevector. + +**repr**: ASCII TextMatrix of the state’s `__repr__`. + +**text**: ASCII TextMatrix that can be printed in the console. + +**latex**: An IPython Latex object for displaying in Jupyter Notebooks. + +**latex\_source**: Raw, uncompiled ASCII source to generate array using LaTeX. + +**qsphere**: Matplotlib figure, rendering of density matrix using plot\_state\_qsphere(). + +**hinton**: Matplotlib figure, rendering of density matrix using plot\_state\_hinton(). + +**bloch**: Matplotlib figure, rendering of density matrix using plot\_bloch\_multivector(). + +**Parameters** + +* **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Select the output method to use for drawing the state. Valid choices are repr, text, latex, latex\_source, qsphere, hinton, or bloch. Default is repr. Default can be changed by adding the line `state_drawer = ` to `~/.qiskit/settings.conf` under `[default]`. +* **drawer\_args** – Arguments to be passed directly to the relevant drawing function or constructor (TextMatrix(), array\_to\_latex(), plot\_state\_qsphere(), plot\_state\_hinton() or plot\_bloch\_multivector()). See the relevant function under qiskit.visualization for that function’s documentation. + +**Returns** + +`matplotlib.Figure` or [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") or `TextMatrix` or `IPython.display.Latex`: Drawing of the Statevector. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – when an invalid output method is selected. + +### evolve + + + +`evolve(other, qargs=None)` + +Evolve a quantum state by an operator. + +**Parameters** + +* **QuantumChannel** (*other (Operator or*) – or Instruction or Circuit): The operator to evolve by. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a list of QuantumState subsystem positions to apply the operator on. + +**Returns** + +the output density matrix. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the operator dimension does not match the specified QuantumState subsystem dimensions. + +### expand + + + +`expand(other)` + +Return the tensor product state other ⊗ self. + +**Parameters** + +**other** ([*DensityMatrix*](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – a quantum state object. + +**Returns** + +the tensor product state other ⊗ self. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a quantum state. + +### expectation\_value + + + +`expectation_value(oper, qargs=None)` + +Compute the expectation value of an operator. + +**Parameters** + +* **oper** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator to evaluate expval. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to apply the operator on. + +**Returns** + +the expectation value. + +**Return type** + +[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### from\_instruction + + + +`classmethod from_instruction(instruction)` + +Return the output density matrix of an instruction. + +The statevector is initialized in the state $|{0,\ldots,0}\rangle$ of the same number of qubits as the input instruction or circuit, evolved by the input instruction, and the output statevector returned. + +**Parameters** + +**instruction** ([*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – instruction or circuit + +**Returns** + +the final density matrix. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the instruction contains invalid instructions for density matrix simulation. + +### from\_int + + + +`static from_int(i, dims)` + +Return a computational basis state density matrix. + +**Parameters** + +* **i** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the basis state element. +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The subsystem dimensions of the statevector (See additional information). + +**Returns** + +The computational basis state $|i\rangle\!\langle i|$. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Additional Information:** + +The `dims` kwarg can be an integer or an iterable of integers. + +* `Iterable` – the subsystem dimensions are the values in the list with the total number of subsystems given by the length of the list. +* `Int` – the integer specifies the total dimension of the state. If it is a power of two the state will be initialized as an N-qubit state. If it is not a power of two the state will have a single d-dimensional subsystem. + +### from\_label + + + +`classmethod from_label(label)` + +Return a tensor product of Pauli X,Y,Z eigenstates. + +| Label | Statevector | +| ----- | ----------------------------------------------------------- | +| `"0"` | $\begin{pmatrix} 1 & 0 \\ 0 & 0 \end{pmatrix}$ | +| `"1"` | $\begin{pmatrix} 0 & 0 \\ 0 & 1 \end{pmatrix}$ | +| `"+"` | $\frac{1}{2}\begin{pmatrix} 1 & 1 \\ 1 & 1 \end{pmatrix}$ | +| `"-"` | $\frac{1}{2}\begin{pmatrix} 1 & -1 \\ -1 & 1 \end{pmatrix}$ | +| `"r"` | $\frac{1}{2}\begin{pmatrix} 1 & -i \\ i & 1 \end{pmatrix}$ | +| `"l"` | $\frac{1}{2}\begin{pmatrix} 1 & i \\ -i & 1 \end{pmatrix}$ | + +**Parameters** + +**label** (*string*) – a eigenstate string ket label (see table for allowed values). + +**Returns** + +The N-qubit basis state density matrix. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the label contains invalid characters, or the length of the label is larger than an explicitly specified num\_qubits. + +### is\_valid + + + +`is_valid(atol=None, rtol=None)` + +Return True if trace 1 and positive semidefinite. + +### measure + + + +`measure(qargs=None)` + +Measure subsystems and return outcome and post-measure state. + +Note that this function uses the QuantumStates internal random number generator for sampling the measurement outcome. The RNG seed can be set using the [`seed()`](#qiskit.quantum_info.DensityMatrix.seed "qiskit.quantum_info.DensityMatrix.seed") method. + +**Parameters** + +**qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +**the pair `(outcome, state)` where `outcome` is the** + +measurement outcome string label, and `state` is the collapsed post-measurement state for the corresponding outcome. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + +### partial\_transpose + + + +`partial_transpose(qargs)` + +Return partially transposed density matrix. + +**Parameters** + +**qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The subsystems to be transposed. + +**Returns** + +The partially transposed density matrix. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +### probabilities + + + +`probabilities(qargs=None, decimals=None)` + +Return the subsystem measurement probability vector. + +Measurement probabilities are with respect to measurement in the computation (diagonal) basis. + +**Parameters** + +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to return probabilities for, if None return for all subsystems (Default: None). +* **decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +The Numpy vector array of probabilities. + +**Return type** + +np.array + +**Examples** + +Consider a 2-qubit product state $\rho=\rho_1\otimes\rho_0$ with $\rho_1=|+\rangle\!\langle+|$, $\rho_0=|0\rangle\!\langle0|$. + +```python +from qiskit.quantum_info import DensityMatrix + +rho = DensityMatrix.from_label('+0') + +# Probabilities for measuring both qubits +probs = rho.probabilities() +print('probs: {}'.format(probs)) + +# Probabilities for measuring only qubit-0 +probs_qubit_0 = rho.probabilities([0]) +print('Qubit-0 probs: {}'.format(probs_qubit_0)) + +# Probabilities for measuring only qubit-1 +probs_qubit_1 = rho.probabilities([1]) +print('Qubit-1 probs: {}'.format(probs_qubit_1)) +``` + +```python +probs: [0.5 0. 0.5 0. ] +Qubit-0 probs: [1. 0.] +Qubit-1 probs: [0.5 0.5] +``` + +We can also permute the order of qubits in the `qargs` list to change the qubit position in the probabilities output + +```python +from qiskit.quantum_info import DensityMatrix + +rho = DensityMatrix.from_label('+0') + +# Probabilities for measuring both qubits +probs = rho.probabilities([0, 1]) +print('probs: {}'.format(probs)) + +# Probabilities for measuring both qubits +# but swapping qubits 0 and 1 in output +probs_swapped = rho.probabilities([1, 0]) +print('Swapped probs: {}'.format(probs_swapped)) +``` + +```python +probs: [0.5 0. 0.5 0. ] +Swapped probs: [0.5 0.5 0. 0. ] +``` + +### probabilities\_dict + + + +`probabilities_dict(qargs=None, decimals=None)` + +Return the subsystem measurement probability dictionary. + +Measurement probabilities are with respect to measurement in the computation (diagonal) basis. + +This dictionary representation uses a Ket-like notation where the dictionary keys are qudit strings for the subsystem basis vectors. If any subsystem has a dimension greater than 10 comma delimiters are inserted between integers so that subsystems can be distinguished. + +**Parameters** + +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to return probabilities for, if None return for all subsystems (Default: None). +* **decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +The measurement probabilities in dict (ket) form. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### purity + + + +`purity()` + +Return the purity of the quantum state. + +### reset + + + +`reset(qargs=None)` + +Reset state or subsystems to the 0-state. + +**Parameters** + +**qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – subsystems to reset, if None all subsystems will be reset to their 0-state (Default: None). + +**Returns** + +the reset state. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Additional Information:** + +If all subsystems are reset this will return the ground state on all subsystems. If only a some subsystems are reset this function will perform evolution by the reset [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") of the reset subsystems. + +### reverse\_qargs + + + +`reverse_qargs()` + +Return a DensityMatrix with reversed subsystem ordering. + +For a tensor product state this is equivalent to reversing the order of tensor product subsystems. For a density matrix $\rho = \rho_{n-1} \otimes ... \otimes \rho_0$ the returned state will be $\rho_0 \otimes ... \otimes \rho_{n-1}$. + +**Returns** + +the state with reversed subsystem order. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +### sample\_counts + + + +`sample_counts(shots, qargs=None)` + +Sample a dict of qubit measurement outcomes in the computational basis. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of samples to generate. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +sampled counts dictionary. + +**Return type** + +[Counts](qiskit.result.Counts "qiskit.result.Counts") + +Additional Information: + +> This function *samples* measurement outcomes using the measure [`probabilities()`](#qiskit.quantum_info.DensityMatrix.probabilities "qiskit.quantum_info.DensityMatrix.probabilities") for the current state and qargs. It does not actually implement the measurement so the current state is not modified. +> +> The seed for random number generator used for sampling can be set to a fixed value by using the stats [`seed()`](#qiskit.quantum_info.DensityMatrix.seed "qiskit.quantum_info.DensityMatrix.seed") method. + +### sample\_memory + + + +`sample_memory(shots, qargs=None)` + +Sample a list of qubit measurement outcomes in the computational basis. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of samples to generate. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +list of sampled counts if the order sampled. + +**Return type** + +np.array + +Additional Information: + +> This function *samples* measurement outcomes using the measure [`probabilities()`](#qiskit.quantum_info.DensityMatrix.probabilities "qiskit.quantum_info.DensityMatrix.probabilities") for the current state and qargs. It does not actually implement the measurement so the current state is not modified. +> +> The seed for random number generator used for sampling can be set to a fixed value by using the stats [`seed()`](#qiskit.quantum_info.DensityMatrix.seed "qiskit.quantum_info.DensityMatrix.seed") method. + +### seed + + + +`seed(value=None)` + +Set the seed for the quantum state RNG. + +### tensor + + + +`tensor(other)` + +Return the tensor product state self ⊗ other. + +**Parameters** + +**other** ([*DensityMatrix*](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – a quantum state object. + +**Returns** + +the tensor product operator self ⊗ other. + +**Return type** + +[DensityMatrix](#qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a quantum state. + +### to\_dict + + + +`to_dict(decimals=None)` + +Convert the density matrix to dictionary form. + +This dictionary representation uses a Ket-like notation where the dictionary keys are qudit strings for the subsystem basis vectors. If any subsystem has a dimension greater than 10 comma delimiters are inserted between integers so that subsystems can be distinguished. + +**Parameters** + +**decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +the dictionary form of the DensityMatrix. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Examples** + +The ket-form of a 2-qubit density matrix $rho = |-\rangle\!\langle -|\otimes |0\rangle\!\langle 0|$ + +```python +from qiskit.quantum_info import DensityMatrix + +rho = DensityMatrix.from_label('-0') +print(rho.to_dict()) +``` + +```python +{ + '00|00': (0.4999999999999999+0j), + '10|00': (-0.4999999999999999-0j), + '00|10': (-0.4999999999999999+0j), + '10|10': (0.4999999999999999+0j) +} +``` + +For non-qubit subsystems the integer range can go from 0 to 9. For example in a qutrit system + +```python +import numpy as np +from qiskit.quantum_info import DensityMatrix + +mat = np.zeros((9, 9)) +mat[0, 0] = 0.25 +mat[3, 3] = 0.25 +mat[6, 6] = 0.25 +mat[-1, -1] = 0.25 +rho = DensityMatrix(mat, dims=(3, 3)) +print(rho.to_dict()) +``` + +```python +{'00|00': (0.25+0j), '10|10': (0.25+0j), '20|20': (0.25+0j), '22|22': (0.25+0j)} +``` + +For large subsystem dimensions delimiters are required. The following example is for a 20-dimensional system consisting of a qubit and 10-dimensional qudit. + +```python +import numpy as np +from qiskit.quantum_info import DensityMatrix + +mat = np.zeros((2 * 10, 2 * 10)) +mat[0, 0] = 0.5 +mat[-1, -1] = 0.5 +rho = DensityMatrix(mat, dims=(2, 10)) +print(rho.to_dict()) +``` + +```python +{'00|00': (0.5+0j), '91|91': (0.5+0j)} +``` + +### to\_operator + + + +`to_operator()` + +Convert to Operator + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### to\_statevector + + + +`to_statevector(atol=None, rtol=None)` + +Return a statevector from a pure density matrix. + +**Parameters** + +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Absolute tolerance for checking operation validity. +* **rtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Relative tolerance for checking operation validity. + +**Returns** + +**The pure density matrix’s corresponding statevector.** + +Corresponds to the eigenvector of the only non-zero eigenvalue. + +**Return type** + +[Statevector](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the state is not pure. + +### trace + + + +`trace()` + +Return the trace of the density matrix. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Kraus.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Kraus.md new file mode 100644 index 00000000000..3d9a6349de7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Kraus.md @@ -0,0 +1,395 @@ +--- +title: Kraus +description: API reference for qiskit.quantum_info.Kraus +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Kraus +--- + +# Kraus + + + +`qiskit.quantum_info.Kraus(data, input_dims=None, output_dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/channel/kraus.py "view source code") + +Bases: `QuantumChannel` + +Kraus representation of a quantum channel. + +For a quantum channel $\mathcal{E}$, the Kraus representation is given by a set of matrices $[A_0,...,A_{K-1}]$ such that the evolution of a [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") $\rho$ is given by + +$$ +\mathcal{E}(\rho) = \sum_{i=0}^{K-1} A_i \rho A_i^\dagger +$$ + +A general operator map $\mathcal{G}$ can also be written using the generalized Kraus representation which is given by two sets of matrices $[A_0,...,A_{K-1}]$, $[B_0,...,A_{B-1}]$ such that + +$$ +\mathcal{G}(\rho) = \sum_{i=0}^{K-1} A_i \rho B_i^\dagger +$$ + +See reference \[1] for further details. + +**References** + +1. C.J. Wood, J.D. Biamonte, D.G. Cory, *Tensor networks and graphical calculus for open quantum systems*, Quant. Inf. Comp. 15, 0579-0811 (2015). [arXiv:1111.6950 \[quant-ph\]](https://arxiv.org/abs/1111.6950) + +Initialize a quantum channel Kraus operator. + +**Parameters** + +* **data** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*circuit.instruction.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction") *| BaseOperator | np.ndarray*) – data to initialize superoperator. +* **input\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *| None*) – the input subsystem dimensions. +* **output\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *| None*) – the output subsystem dimensions. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data cannot be initialized as a list of Kraus matrices. + +**Additional Information:** + +If the input or output dimensions are None, they will be automatically determined from the input data. If the input data is a list of Numpy arrays of shape $(2^N,\,2^N)$ qubit systems will be used. If the input does not correspond to an N-qubit channel, it will assign a single subsystem with dimension specified by the shape of the input. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +Return list of Kraus matrices for channel. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint quantum channel. + + + This is equivalent to the matrix Hermitian conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the adjoint channel $\mathcal{{E}}^\dagger$ is $S_{\mathcal{E}^\dagger} = S_{\mathcal{E}}^\dagger$. + + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another Kraus. + +**Parameters** + +* **other** ([*Kraus*](#qiskit.quantum_info.Kraus "qiskit.quantum_info.Kraus")) – a Kraus object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed Kraus. + +**Return type** + +[Kraus](#qiskit.quantum_info.Kraus "qiskit.quantum_info.Kraus") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.Kraus.dot "qiskit.quantum_info.Kraus.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.Kraus.dot "qiskit.quantum_info.Kraus.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate quantum channel. + + + This is equivalent to the matrix complex conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the conjugate channel $\overline{{\mathcal{{E}}}}$ is $S_{\overline{\mathcal{E}^\dagger}} = \overline{S_{\mathcal{E}}}$. + + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another Kraus. + +**Parameters** + +**other** ([*Kraus*](#qiskit.quantum_info.Kraus "qiskit.quantum_info.Kraus")) – a Kraus object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current Kraus, and $b$ is the other Kraus. + +**Return type** + +[Kraus](#qiskit.quantum_info.Kraus "qiskit.quantum_info.Kraus") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_cp + + + +`is_cp(atol=None, rtol=None)` + +Test if Choi-matrix is completely-positive (CP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_cptp + + + +`is_cptp(atol=None, rtol=None)` + +Return True if completely-positive trace-preserving. + +### is\_tp + + + +`is_tp(atol=None, rtol=None)` + +Test if a channel is trace-preserving (TP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if QuantumChannel is a unitary channel. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the power of the quantum channel. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power exponent. + +**Returns** + +the channel $\mathcal{{E}} ^n$. + +**Return type** + +[SuperOp](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the SuperOp are not equal. + + + For non-positive or non-integer exponents the power is defined as the matrix power of the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{{E}}$, the SuperOp of the powered channel $\mathcal{{E}}^\n$ is $S_{{\mathcal{{E}}^n}} = S_{{\mathcal{{E}}}}^n$. + + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another Kraus. + +**Parameters** + +**other** ([*Kraus*](#qiskit.quantum_info.Kraus "qiskit.quantum_info.Kraus")) – a Kraus object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current Kraus, and $b$ is the other Kraus. + +**Return type** + +[Kraus](#qiskit.quantum_info.Kraus "qiskit.quantum_info.Kraus") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to a Kraus or UnitaryGate circuit instruction. + +If the channel is unitary it will be added as a unitary gate, otherwise it will be added as a kraus simulator instruction. + +**Returns** + +A kraus instruction for the channel. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit CPTP quantum channel. + +### to\_operator + + + +`to_operator()` + +Try to convert channel to a unitary representation Operator. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose quantum channel. + + + This is equivalent to the matrix transpose in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation, ie. for a channel $\mathcal{E}$, the SuperOp of the transpose channel $\mathcal{{E}}^T$ is $S_{mathcal{E}^T} = S_{\mathcal{E}}^T$. + + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Operator.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Operator.md new file mode 100644 index 00000000000..fe2ac5fcdff --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Operator.md @@ -0,0 +1,488 @@ +--- +title: Operator +description: API reference for qiskit.quantum_info.Operator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Operator +--- + +# Operator + + + +`qiskit.quantum_info.Operator(data, input_dims=None, output_dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/operator.py "view source code") + +Bases: `LinearOp` + +Matrix operator class + +This represents a matrix operator $M$ that will [`evolve()`](qiskit.quantum_info.Statevector#evolve "qiskit.quantum_info.Statevector.evolve") a [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") $|\psi\rangle$ by matrix-vector multiplication + +$$ +|\psi\rangle \mapsto M|\psi\rangle, +$$ + +and will [`evolve()`](qiskit.quantum_info.DensityMatrix#evolve "qiskit.quantum_info.DensityMatrix.evolve") a [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") $\rho$ by left and right multiplication + +$$ +\rho \mapsto M \rho M^\dagger. +$$ + +Initialize an operator object. + +**Parameters** + +* **data** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation") *or BaseOperator or matrix*) – data to initialize operator. +* **input\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input subsystem dimensions. \[Default: None] +* **output\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the output subsystem dimensions. \[Default: None] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data cannot be initialized as an operator. + +**Additional Information:** + +If the input or output dimensions are None, they will be automatically determined from the input data. If the input data is a Numpy array of shape (2\*\*N, 2\*\*N) qubit systems will be used. If the input operator is not an N-qubit operator, it will assign a single subsystem with dimension specified by the shape of the input. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +The underlying Numpy array. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return operator settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the Operator. + +**Return type** + +*Self* + +### apply\_permutation + + + +`apply_permutation(perm, front=False)` + +Modifies operator’s data by composing it with a permutation. + +**Parameters** + +* **perm** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – permutation pattern, describing which qubits occupy the positions 0, 1, 2, etc. after applying the permutation. +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set to `True` the permutation is applied before the operator, when set to `False` the permutation is applied after the operator. + +**Returns** + +The modified operator. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the size of the permutation pattern does not match the dimensions of the operator. + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another Operator. + +**Parameters** + +* **other** ([*Operator*](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – a Operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed Operator. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.Operator.dot "qiskit.quantum_info.Operator.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.Operator.dot "qiskit.quantum_info.Operator.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate of the Operator. + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### draw + + + +`draw(output=None, **drawer_args)` + +Return a visualization of the Operator. + +**repr**: String of the state’s `__repr__`. + +**text**: ASCII TextMatrix that can be printed in the console. + +**latex**: An IPython Latex object for displaying in Jupyter Notebooks. + +**latex\_source**: Raw, uncompiled ASCII source to generate array using LaTeX. + +**Parameters** + +* **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Select the output method to use for drawing the state. Valid choices are repr, text, latex, latex\_source, Default is repr. +* **drawer\_args** – Arguments to be passed directly to the relevant drawing function or constructor (TextMatrix(), array\_to\_latex()). See the relevant function under qiskit.visualization for that function’s documentation. + +**Returns** + +Drawing of the Operator. + +**Return type** + +[`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") or `TextMatrix` or `IPython.display.Latex` + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – when an invalid output method is selected. + +### equiv + + + +`equiv(other, rtol=None, atol=None)` + +Return True if operators are equivalent up to global phase. + +**Parameters** + +* **other** ([*Operator*](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **rtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – relative tolerance value for comparison. +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – absolute tolerance value for comparison. + +**Returns** + +True if operators are equivalent up to global phase. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another Operator. + +**Parameters** + +**other** ([*Operator*](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – a Operator object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current Operator, and $b$ is the other Operator. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +### from\_circuit + + + +`classmethod from_circuit(circuit, ignore_set_layout=False, layout=None, final_layout=None)` + +Create a new Operator object from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +While a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object can passed directly as `data` to the class constructor this provides no options on how the circuit is used to create an [`Operator`](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator"). This constructor method lets you control how the [`Operator`](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") is created so it can be adjusted for a particular use case. + +By default this constructor method will permute the qubits based on a configured initial layout (i.e. after it was transpiled). It also provides an option to manually provide a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object directly. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") to create an Operator object from. +* **ignore\_set\_layout** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – When set to `True` if the input `circuit` has a layout set it will be ignored +* **layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout")) – If specified this kwarg can be used to specify a particular layout to use to permute the qubits in the created [`Operator`](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator"). If this is specified it will be used instead of a layout contained in the `circuit` input. If specified the virtual bits in the [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") must be present in the `circuit` input. +* **final\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout")) – If specified this kwarg can be used to represent the output permutation caused by swap insertions during the routing stage of the transpiler. + +**Returns** + +An operator representing the input circuit + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +### from\_label + + + +`classmethod from_label(label)` + +Return a tensor product of single-qubit operators. + +**Parameters** + +**label** (*string*) – single-qubit operator string. + +**Returns** + +The N-qubit operator. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the label contains invalid characters, or the length of the label is larger than an explicitly specified num\_qubits. + +**Additional Information:** + +The labels correspond to the single-qubit matrices: ‘I’: \[\[1, 0], \[0, 1]] ‘X’: \[\[0, 1], \[1, 0]] ‘Y’: \[\[0, -1j], \[1j, 0]] ‘Z’: \[\[1, 0], \[0, -1]] ‘H’: \[\[1, 1], \[1, -1]] / sqrt(2) ‘S’: \[\[1, 0], \[0 , 1j]] ‘T’: \[\[1, 0], \[0, (1+1j) / sqrt(2)]] ‘0’: \[\[1, 0], \[0, 0]] ‘1’: \[\[0, 0], \[0, 1]] ‘+’: \[\[0.5, 0.5], \[0.5 , 0.5]] ‘-’: \[\[0.5, -0.5], \[-0.5 , 0.5]] ‘r’: \[\[0.5, -0.5j], \[0.5j , 0.5]] ‘l’: \[\[0.5, 0.5j], \[-0.5j , 0.5]] + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if operator is a unitary matrix. + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the matrix power of the operator. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power to raise the matrix to. + +**Returns** + +the resulting operator `O ** n`. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the operator are not equal. + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### reverse\_qargs + + + +`reverse_qargs()` + +Return an Operator with reversed subsystem ordering. + +For a tensor product operator this is equivalent to reversing the order of tensor product subsystems. For an operator $A = A_{n-1} \otimes ... \otimes A_0$ the returned operator will be $A_0 \otimes ... \otimes A_{n-1}$. + +**Returns** + +the operator with reversed subsystem order. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +### tensor + + + +`tensor(other)` + +Return the tensor product with another Operator. + +**Parameters** + +**other** ([*Operator*](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – a Operator object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current Operator, and $b$ is the other Operator. + +**Return type** + +[Operator](#qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to a UnitaryGate instruction. + +### to\_matrix + + + +`to_matrix()` + +Convert operator to NumPy matrix. + +### to\_operator + + + +`to_operator()` + +Convert operator to matrix operator class + +**Return type** + +[*Operator*](#qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose of the Operator. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.PTM.md b/docs/api/qiskit/0.46/qiskit.quantum_info.PTM.md new file mode 100644 index 00000000000..4731d769bb8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.PTM.md @@ -0,0 +1,403 @@ +--- +title: PTM +description: API reference for qiskit.quantum_info.PTM +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.PTM +--- + +# PTM + + + +`qiskit.quantum_info.PTM(data, input_dims=None, output_dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/channel/ptm.py "view source code") + +Bases: `QuantumChannel` + +Pauli Transfer Matrix (PTM) representation of a Quantum Channel. + +The PTM representation of an $n$-qubit quantum channel $\mathcal{E}$ is an $n$-qubit [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") $R$ defined with respect to vectorization in the Pauli basis instead of column-vectorization. The elements of the PTM $R$ are given by + +$$ +R_{i,j} = \frac{1}{2^n} \mbox{Tr}\left[P_i \mathcal{E}(P_j) \right] +$$ + +where $[P_0, P_1, ..., P_{4^{n}-1}]$ is the $n$-qubit Pauli basis in lexicographic order. + +Evolution of a [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") $\rho$ with respect to the PTM is given by + +$$ +|\mathcal{E}(\rho)\rangle\!\rangle_P = S_P |\rho\rangle\!\rangle_P +$$ + +where $|A\rangle\!\rangle_P$ denotes vectorization in the Pauli basis $\langle i | A\rangle\!\rangle_P = \sqrt{\frac{1}{2^n}} \mbox{Tr}[P_i A]$. + +See reference \[1] for further details. + +**References** + +1. C.J. Wood, J.D. Biamonte, D.G. Cory, *Tensor networks and graphical calculus for open quantum systems*, Quant. Inf. Comp. 15, 0579-0811 (2015). [arXiv:1111.6950 \[quant-ph\]](https://arxiv.org/abs/1111.6950) + +Initialize a PTM quantum channel operator. + +**Parameters** + +* **or** (*data (*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Instruction or BaseOperator or matrix): data to initialize superoperator. +* **input\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input subsystem dimensions. \[Default: None] +* **output\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the output subsystem dimensions. \[Default: None] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit channel or cannot be initialized as a PTM. + +**Additional Information:** + +If the input or output dimensions are None, they will be automatically determined from the input data. The PTM representation is only valid for N-qubit channels. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +Return data. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint quantum channel. + + + This is equivalent to the matrix Hermitian conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the adjoint channel $\mathcal{{E}}^\dagger$ is $S_{\mathcal{E}^\dagger} = S_{\mathcal{E}}^\dagger$. + + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another PTM. + +**Parameters** + +* **other** ([*PTM*](#qiskit.quantum_info.PTM "qiskit.quantum_info.PTM")) – a PTM object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed PTM. + +**Return type** + +[PTM](#qiskit.quantum_info.PTM "qiskit.quantum_info.PTM") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.PTM.dot "qiskit.quantum_info.PTM.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.PTM.dot "qiskit.quantum_info.PTM.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate quantum channel. + + + This is equivalent to the matrix complex conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the conjugate channel $\overline{{\mathcal{{E}}}}$ is $S_{\overline{\mathcal{E}^\dagger}} = \overline{S_{\mathcal{E}}}$. + + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another PTM. + +**Parameters** + +**other** ([*PTM*](#qiskit.quantum_info.PTM "qiskit.quantum_info.PTM")) – a PTM object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current PTM, and $b$ is the other PTM. + +**Return type** + +[PTM](#qiskit.quantum_info.PTM "qiskit.quantum_info.PTM") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_cp + + + +`is_cp(atol=None, rtol=None)` + +Test if Choi-matrix is completely-positive (CP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_cptp + + + +`is_cptp(atol=None, rtol=None)` + +Return True if completely-positive trace-preserving (CPTP). + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_tp + + + +`is_tp(atol=None, rtol=None)` + +Test if a channel is trace-preserving (TP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if QuantumChannel is a unitary channel. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the power of the quantum channel. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power exponent. + +**Returns** + +the channel $\mathcal{{E}} ^n$. + +**Return type** + +[SuperOp](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the SuperOp are not equal. + + + For non-positive or non-integer exponents the power is defined as the matrix power of the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{{E}}$, the SuperOp of the powered channel $\mathcal{{E}}^\n$ is $S_{{\mathcal{{E}}^n}} = S_{{\mathcal{{E}}}}^n$. + + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another PTM. + +**Parameters** + +**other** ([*PTM*](#qiskit.quantum_info.PTM "qiskit.quantum_info.PTM")) – a PTM object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current PTM, and $b$ is the other PTM. + +**Return type** + +[PTM](#qiskit.quantum_info.PTM "qiskit.quantum_info.PTM") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to a Kraus or UnitaryGate circuit instruction. + +If the channel is unitary it will be added as a unitary gate, otherwise it will be added as a kraus simulator instruction. + +**Returns** + +A kraus instruction for the channel. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit CPTP quantum channel. + +### to\_operator + + + +`to_operator()` + +Try to convert channel to a unitary representation Operator. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose quantum channel. + + + This is equivalent to the matrix transpose in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation, ie. for a channel $\mathcal{E}$, the SuperOp of the transpose channel $\mathcal{{E}}^T$ is $S_{mathcal{E}^T} = S_{\mathcal{E}}^T$. + + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Pauli.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Pauli.md new file mode 100644 index 00000000000..7200a492d18 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Pauli.md @@ -0,0 +1,589 @@ +--- +title: Pauli +description: API reference for qiskit.quantum_info.Pauli +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Pauli +--- + +# Pauli + + + +`qiskit.quantum_info.Pauli(data=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/pauli.py "view source code") + +Bases: `BasePauli` + +N-qubit Pauli operator. + +This class represents an operator $P$ from the full $n$-qubit *Pauli* group + +$$ +P = (-i)^{q} P_{n-1} \otimes ... \otimes P_{0} +$$ + +where $q\in \mathbb{Z}_4$ and $P_i \in \{I, X, Y, Z\}$ are single-qubit Pauli matrices: + +$$ +I = \begin{pmatrix} 1 & 0 \\ 0 & 1 \end{pmatrix}, +X = \begin{pmatrix} 0 & 1 \\ 1 & 0 \end{pmatrix}, +Y = \begin{pmatrix} 0 & -i \\ i & 0 \end{pmatrix}, +Z = \begin{pmatrix} 1 & 0 \\ 0 & -1 \end{pmatrix}. +$$ + +**Initialization** + +A Pauli object can be initialized in several ways: + +> **`Pauli(obj)`** +> +> where `obj` is a Pauli string, `Pauli` or [`ScalarOp`](qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp") operator, or a Pauli gate or `QuantumCircuit` containing only Pauli gates. +> +> **`Pauli((z, x, phase))`** +> +> where `z` and `x` are boolean `numpy.ndarrays` and `phase` is an integer in `[0, 1, 2, 3]`. +> +> **`Pauli((z, x))`** +> +> equivalent to `Pauli((z, x, 0))` with trivial phase. + +**String representation** + +An $n$-qubit Pauli may be represented by a string consisting of $n$ characters from `['I', 'X', 'Y', 'Z']`, and optionally phase coefficient in $['', '-i', '-', 'i']$. For example: `XYZ` or `'-iZIZ'`. + +In the string representation qubit-0 corresponds to the right-most Pauli character, and qubit-$(n-1)$ to the left-most Pauli character. For example `'XYZ'` represents $X\otimes Y \otimes Z$ with `'Z'` on qubit-0, `'Y'` on qubit-1, and `'X'` on qubit-2. + +The string representation can be converted to a `Pauli` using the class initialization (`Pauli('-iXYZ')`). A `Pauli` object can be converted back to the string representation using the [`to_label()`](#qiskit.quantum_info.Pauli.to_label "qiskit.quantum_info.Pauli.to_label") method or `str(pauli)`. + + + Using `str` to convert a `Pauli` to a string will truncate the returned string for large numbers of qubits while [`to_label()`](#qiskit.quantum_info.Pauli.to_label "qiskit.quantum_info.Pauli.to_label") will return the full string with no truncation. The default truncation length is 50 characters. The default value can be changed by setting the class `__truncate__` attribute to an integer value. If set to `0` no truncation will be performed. + + +**Array Representation** + +The internal data structure of an $n$-qubit Pauli is two length-$n$ boolean vectors $z \in \mathbb{Z}_2^N$, $x \in \mathbb{Z}_2^N$, and an integer $q \in \mathbb{Z}_4$ defining the Pauli operator + +$$ +P = (-i)^{q + z\cdot x} Z^z \cdot X^x. +$$ + +The $k$-th qubit corresponds to the $k$-th entry in the $z$ and $x$ arrays + +$$ +\begin{aligned} +P &= P_{n-1} \otimes ... \otimes P_{0} \\ +P_k &= (-i)^{z[k] * x[k]} Z^{z[k]}\cdot X^{x[k]} +\end{aligned} +$$ + +where `z[k] = P.z[k]`, `x[k] = P.x[k]` respectively. + +The $z$ and $x$ arrays can be accessed and updated using the [`z`](#qiskit.quantum_info.Pauli.z "qiskit.quantum_info.Pauli.z") and [`x`](#qiskit.quantum_info.Pauli.x "qiskit.quantum_info.Pauli.x") properties respectively. The phase integer $q$ can be accessed and updated using the [`phase`](#qiskit.quantum_info.Pauli.phase "qiskit.quantum_info.Pauli.phase") property. + +**Matrix Operator Representation** + +Pauli’s can be converted to $(2^n, 2^n)$ [`Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") using the `to_operator()` method, or to a dense or sparse complex matrix using the [`to_matrix()`](#qiskit.quantum_info.Pauli.to_matrix "qiskit.quantum_info.Pauli.to_matrix") method. + +**Data Access** + +The individual qubit Paulis can be accessed and updated using the `[]` operator which accepts integer, lists, or slices for selecting subsets of Paulis. Note that selecting subsets of Pauli’s will discard the phase of the current Pauli. + +For example + +```python +p = Pauli('-iXYZ') + +print('P[0] =', repr(P[0])) +print('P[1] =', repr(P[1])) +print('P[2] =', repr(P[2])) +print('P[:] =', repr(P[:])) +print('P[::-1] =, repr(P[::-1])) +``` + +Initialize the Pauli. + +When using the symplectic array input data both z and x arguments must be provided, however the first (z) argument can be used alone for string label, Pauli operator, or ScalarOp input data. + +**Parameters** + +**data** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*ScalarOp*](qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp")) – input data for Pauli. If input is a tuple it must be of the form `(z, x)` or (z, x, phase)\`\` where `z` and `x` are boolean Numpy arrays, and phase is an integer from Z\_4. If input is a string, it must be a concatenation of a phase and a Pauli string (e.g. ‘XYZ’, ‘-iZIZ’) where a phase string is a combination of at most three characters from \[‘+’, ‘-’, ‘’], \[‘1’, ‘’], and \[‘i’, ‘j’, ‘’] in this order, e.g. ‘’, ‘-1j’ while a Pauli string is 1 or more characters of ‘I’, ‘X’, ‘Y’ or ‘Z’, e.g. ‘Z’, ‘XIYY’. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input array is invalid shape. + +## Attributes + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### name + +Unique string identifier for operation type. + + + +### num\_clbits + +Number of classical bits. + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### phase + +Return the group phase exponent for the Pauli. + + + +### qargs + +Return the qargs for the operator. + + + +### settings + +Return settings. + + + +### x + +The x vector for the Pauli. + + + +### z + +The z vector for the Pauli. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the Operator. + +### anticommutes + + + +`anticommutes(other, qargs=None)` + +Return True if other Pauli anticommutes with self. + +**Parameters** + +* **other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – another Pauli operator. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits to apply dot product on (default: None). + +**Returns** + +True if Pauli’s anticommute, False if they commute. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### commutes + + + +`commutes(other, qargs=None)` + +Return True if the Pauli commutes with other. + +**Parameters** + +* **other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*PauliList*](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – another Pauli operator. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits to apply dot product on (default: None). + +**Returns** + +True if Pauli’s commute, False if they anti-commute. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### compose + + + +`compose(other, qargs=None, front=False, inplace=False)` + +Return the operator composition with another Pauli. + +**Parameters** + +* **other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – a Pauli object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, qubits to apply dot product on (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True update in-place (default: False). + +**Returns** + +The composed Pauli. + +**Return type** + +[Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while [`dot()`](#qiskit.quantum_info.Pauli.dot "qiskit.quantum_info.Pauli.dot") is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.Pauli.dot "qiskit.quantum_info.Pauli.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate of each Pauli in the list. + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### delete + + + +`delete(qubits)` + +Return a Pauli with qubits deleted. + +**Parameters** + +**qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits to delete from Pauli. + +**Returns** + +the resulting Pauli with the specified qubits removed. + +**Return type** + +[Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if ind is out of bounds for the array size or number of qubits. + +### dot + + + +`dot(other, qargs=None, inplace=False)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, qubits to apply dot product on (default: None). +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True update in-place (default: False). + +**Returns** + +The operator self \* other. + +**Return type** + +[Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + +### equiv + + + +`equiv(other)` + +Return True if Pauli’s are equivalent up to group phase. + +**Parameters** + +**other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – an operator object. + +**Returns** + +True if the Pauli’s are equivalent up to group phase. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### evolve + + + +`evolve(other, qargs=None, frame='h')` + +Performs either Heisenberg (default) or Schrödinger picture evolution of the Pauli by a Clifford and returns the evolved Pauli. + +Schrödinger picture evolution can be chosen by passing parameter `frame='s'`. This option yields a faster calculation. + +Heisenberg picture evolves the Pauli as $P^\prime = C^\dagger.P.C$. + +Schrödinger picture evolves the Pauli as $P^\prime = C.P.C^\dagger$. + +**Parameters** + +* **other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The Clifford operator to evolve by. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a list of qubits to apply the Clifford to. +* **frame** (*string*) – `'h'` for Heisenberg (default) or `'s'` for +* **framework.** (*Schrödinger*) – + +**Returns** + +the Pauli $C^\dagger.P.C$ (Heisenberg picture) or the Pauli $C.P.C^\dagger$ (Schrödinger picture). + +**Return type** + +[Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the Clifford number of qubits and qargs don’t match. + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another Pauli. + +**Parameters** + +**other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – a Pauli object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current Pauli, and $b$ is the other Pauli. + +**Return type** + +[Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### insert + + + +`insert(qubits, value)` + +Insert a Pauli at specific qubit value. + +**Parameters** + +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits index to insert at. +* **value** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – value to insert. + +**Returns** + +the resulting Pauli with the entries inserted. + +**Return type** + +[Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the insertion qubits are invalid. + +### inverse + + + +`inverse()` + +Return the inverse of the Pauli. + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the compose of a operator with itself n times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of times to compose with self (n>0). + +**Returns** + +the n-times composed operator. + +**Return type** + +[Clifford](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the operator are not equal, or the power is not a positive integer. + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### set\_truncation + + + +`classmethod set_truncation(val)` + +Set the max number of Pauli characters to display before truncation/ + +**Parameters** + +**val** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of characters. + + + Truncation will be disabled if the truncation value is set to 0. + + +### tensor + + + +`tensor(other)` + +Return the tensor product with another Pauli. + +**Parameters** + +**other** ([*Pauli*](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – a Pauli object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current Pauli, and $b$ is the other Pauli. + +**Return type** + +[Pauli](#qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to Pauli circuit instruction. + +### to\_label + + + +`to_label()` + +Convert a Pauli to a string label. + + + The difference between to\_label and `__str__()` is that the later will truncate the output for large numbers of qubits. + + +**Returns** + +the Pauli string label. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### to\_matrix + + + +`to_matrix(sparse=False)` + +Convert to a Numpy array or sparse CSR matrix. + +**Parameters** + +**sparse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True return sparse CSR matrices, otherwise return dense Numpy arrays (default: False). + +**Returns** + +The Pauli matrix. + +**Return type** + +array + +### transpose + + + +`transpose()` + +Return the transpose of each Pauli in the list. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.PauliList.md b/docs/api/qiskit/0.46/qiskit.quantum_info.PauliList.md new file mode 100644 index 00000000000..7c5519e0e3f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.PauliList.md @@ -0,0 +1,865 @@ +--- +title: PauliList +description: API reference for qiskit.quantum_info.PauliList +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.PauliList +--- + +# PauliList + + + +`qiskit.quantum_info.PauliList(data)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/pauli_list.py "view source code") + +Bases: `BasePauli`, `LinearMixin`, `GroupMixin` + +List of N-qubit Pauli operators. + +This class is an efficient representation of a list of [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") operators. It supports 1D numpy array indexing returning a [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") for integer indexes or a [`PauliList`](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") for slice or list indices. + +**Initialization** + +A PauliList object can be initialized in several ways. + +> **`PauliList(list[str])`** +> +> where strings are same representation with [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli"). +> +> **`PauliList(Pauli) and PauliList(list[Pauli])`** +> +> where Pauli is [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli"). +> +> **`PauliList.from_symplectic(z, x, phase)`** +> +> where `z` and `x` are 2 dimensional boolean `numpy.ndarrays` and `phase` is an integer in `[0, 1, 2, 3]`. + +For example, + +```python +import numpy as np + +from qiskit.quantum_info import Pauli, PauliList + +# 1. init from list[str] +pauli_list = PauliList(["II", "+ZI", "-iYY"]) +print("1. ", pauli_list) + +pauli1 = Pauli("iXI") +pauli2 = Pauli("iZZ") + +# 2. init from Pauli +print("2. ", PauliList(pauli1)) + +# 3. init from list[Pauli] +print("3. ", PauliList([pauli1, pauli2])) + +# 4. init from np.ndarray +z = np.array([[True, True], [False, False]]) +x = np.array([[False, True], [True, False]]) +phase = np.array([0, 1]) +pauli_list = PauliList.from_symplectic(z, x, phase) +print("4. ", pauli_list) +``` + +```python +1. ['II', 'ZI', '-iYY'] +2. ['iXI'] +3. ['iXI', 'iZZ'] +4. ['YZ', '-iIX'] +``` + +**Data Access** + +The individual Paulis can be accessed and updated using the `[]` operator which accepts integer, lists, or slices for selecting subsets of PauliList. If integer is given, it returns Pauli not PauliList. + +```python +pauli_list = PauliList(["XX", "ZZ", "IZ"]) +print("Integer: ", repr(pauli_list[1])) +print("List: ", repr(pauli_list[[0, 2]])) +print("Slice: ", repr(pauli_list[0:2])) +``` + +```python +Integer: Pauli('ZZ') +List: PauliList(['XX', 'IZ']) +Slice: PauliList(['XX', 'ZZ']) +``` + +**Iteration** + +Rows in the Pauli table can be iterated over like a list. Iteration can also be done using the label or matrix representation of each row using the [`label_iter()`](#qiskit.quantum_info.PauliList.label_iter "qiskit.quantum_info.PauliList.label_iter") and [`matrix_iter()`](#qiskit.quantum_info.PauliList.matrix_iter "qiskit.quantum_info.PauliList.matrix_iter") methods. + +Initialize the PauliList. + +**Parameters** + +**data** ([*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – input data for Paulis. If input is a list each item in the list must be a Pauli object or Pauli str. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input array is invalid shape. + +**Additional Information:** + +The input array is not copied so multiple Pauli tables can share the same underlying array. + +## Attributes + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### phase + +Return the phase exponent of the PauliList. + + + +### qargs + +Return the qargs for the operator. + + + +### settings + +Return settings. + + + +### shape + +The full shape of the `array()` + + + +### size + +The number of Pauli rows in the table. + + + +### x + +The x array for the symplectic representation. + + + +### z + +The z array for the symplectic representation. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of each Pauli in the list. + +### anticommutes + + + +`anticommutes(other, qargs=None)` + +Return `True` if other Pauli that anticommutes with other. + +**Parameters** + +* **other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – another PauliList operator. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits to apply dot product on (default: `None`). + +**Returns** + +`True` if Paulis anticommute, `False` if they commute. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### anticommutes\_with\_all + + + +`anticommutes_with_all(other)` + +Return indexes of rows that commute other. + +If `other` is a multi-row Pauli list the returned vector indexes rows of the current PauliList that anti-commute with *all* Paulis in other. If no rows satisfy the condition the returned array will be empty. + +**Parameters** + +**other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – a single Pauli or multi-row PauliList. + +**Returns** + +index array of the anti-commuting rows. + +**Return type** + +array + +### argsort + + + +`argsort(weight=False, phase=False)` + +Return indices for sorting the rows of the table. + +The default sort method is lexicographic sorting by qubit number. By using the weight kwarg the output can additionally be sorted by the number of non-identity terms in the Pauli, where the set of all Paulis of a given weight are still ordered lexicographically. + +**Parameters** + +* **weight** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optionally sort by weight if `True` (Default: `False`). +* **phase** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optionally sort by phase before weight or order (Default: `False`). + +**Returns** + +the indices for sorting the table. + +**Return type** + +array + +### commutes + + + +`commutes(other, qargs=None)` + +Return True for each Pauli that commutes with other. + +**Parameters** + +* **other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – another PauliList operator. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits to apply dot product on (default: `None`). + +**Returns** + +`True` if Paulis commute, `False` if they anti-commute. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### commutes\_with\_all + + + +`commutes_with_all(other)` + +Return indexes of rows that commute `other`. + +If `other` is a multi-row Pauli list the returned vector indexes rows of the current PauliList that commute with *all* Paulis in other. If no rows satisfy the condition the returned array will be empty. + +**Parameters** + +**other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – a single Pauli or multi-row PauliList. + +**Returns** + +index array of the commuting rows. + +**Return type** + +array + +### compose + + + +`compose(other, qargs=None, front=False, inplace=False)` + +Return the composition self∘other for each Pauli in the list. + +**Parameters** + +* **other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – another PauliList. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits to apply dot product on (Default: `None`). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True use dot composition method \[default: `False`]. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` update in-place (default: `False`). + +**Returns** + +the list of composed Paulis. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to a PauliList, does not have either 1 or the same number of Paulis as the current list, or has the wrong number of qubits for the specified `qargs`. + +### conjugate + + + +`conjugate()` + +Return the conjugate of each Pauli in the list. + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### delete + + + +`delete(ind, qubit=False)` + +Return a copy with Pauli rows deleted from table. + +When deleting qubits the qubit index is the same as the column index of the underlying `X` and `Z` arrays. + +**Parameters** + +* **ind** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – index(es) to delete. +* **qubit** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` delete qubit columns, otherwise delete Pauli rows (Default: `False`). + +**Returns** + +the resulting table with the entries removed. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if `ind` is out of bounds for the array size or number of qubits. + +### dot + + + +`dot(other, qargs=None, inplace=False)` + +Return the composition other∘self for each Pauli in the list. + +**Parameters** + +* **other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – another PauliList. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – qubits to apply dot product on (Default: `None`). +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True update in-place (default: `False`). + +**Returns** + +the list of composed Paulis. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to a PauliList, does not have either 1 or the same number of Paulis as the current list, or has the wrong number of qubits for the specified `qargs`. + +### equiv + + + +`equiv(other)` + +Entrywise comparison of Pauli equivalence up to global phase. + +**Parameters** + +**other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") *or*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – a comparison object. + +**Returns** + +**An array of `True` or `False` for entrywise equivalence** + +of the current table. + +**Return type** + +np.ndarray + +### evolve + + + +`evolve(other, qargs=None, frame='h')` + +Performs either Heisenberg (default) or Schrödinger picture evolution of the Pauli by a Clifford and returns the evolved Pauli. + +Schrödinger picture evolution can be chosen by passing parameter `frame='s'`. This option yields a faster calculation. + +Heisenberg picture evolves the Pauli as $P^\prime = C^\dagger.P.C$. + +Schrödinger picture evolves the Pauli as $P^\prime = C.P.C^\dagger$. + +**Parameters** + +* **other** ([*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – The Clifford operator to evolve by. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a list of qubits to apply the Clifford to. +* **frame** (*string*) – `'h'` for Heisenberg (default) or `'s'` for Schrödinger framework. + +**Returns** + +the Pauli $C^\dagger.P.C$ (Heisenberg picture) or the Pauli $C.P.C^\dagger$ (Schrödinger picture). + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the Clifford number of qubits and qargs don’t match. + +### expand + + + +`expand(other)` + +Return the expand product of each Pauli in the list. + +**Parameters** + +**other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – another PauliList. + +**Returns** + +the list of tensor product Paulis. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to a PauliList, does not have either 1 or the same number of Paulis as the current list. + +### from\_symplectic + + + +`classmethod from_symplectic(z, x, phase=0)` + +Construct a PauliList from a symplectic data. + +**Parameters** + +* **z** (*np.ndarray*) – 2D boolean Numpy array. +* **x** (*np.ndarray*) – 2D boolean Numpy array. +* **phase** (*np.ndarray or None*) – Optional, 1D integer array from Z\_4. + +**Returns** + +the constructed PauliList. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +### group\_commuting + + + +`group_commuting(qubit_wise=False)` + +Partition a PauliList into sets of commuting Pauli strings. + +**Parameters** + +**qubit\_wise** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – + +whether the commutation rule is applied to the whole operator, or on a per-qubit basis. For example: + +```python +>>> from qiskit.quantum_info import PauliList +>>> op = PauliList(["XX", "YY", "IZ", "ZZ"]) +>>> op.group_commuting() +[PauliList(['XX', 'YY']), PauliList(['IZ', 'ZZ'])] +>>> op.group_commuting(qubit_wise=True) +[PauliList(['XX']), PauliList(['YY']), PauliList(['IZ', 'ZZ'])] +``` + +**Returns** + +List of PauliLists where each PauliList contains commuting Pauli operators. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")] + +### group\_qubit\_wise\_commuting + + + +`group_qubit_wise_commuting()` + +Partition a PauliList into sets of mutually qubit-wise commuting Pauli strings. + +**Returns** + +List of PauliLists where each PauliList contains commutable Pauli operators. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")] + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### insert + + + +`insert(ind, value, qubit=False)` + +Insert Paulis into the table. + +When inserting qubits the qubit index is the same as the column index of the underlying `X` and `Z` arrays. + +**Parameters** + +* **ind** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – index to insert at. +* **value** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – values to insert. +* **qubit** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` insert qubit columns, otherwise insert Pauli rows (Default: `False`). + +**Returns** + +the resulting table with the entries inserted. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the insertion index is invalid. + +### inverse + + + +`inverse()` + +Return the inverse of each Pauli in the list. + +### label\_iter + + + +`label_iter()` + +Return a label representation iterator. + +This is a lazy iterator that converts each row into the string label only as it is used. To convert the entire table to labels use the [`to_labels()`](#qiskit.quantum_info.PauliList.to_labels "qiskit.quantum_info.PauliList.to_labels") method. + +**Returns** + +label iterator object for the PauliList. + +**Return type** + +LabelIterator + +### matrix\_iter + + + +`matrix_iter(sparse=False)` + +Return a matrix representation iterator. + +This is a lazy iterator that converts each row into the Pauli matrix representation only as it is used. To convert the entire table to matrices use the [`to_matrix()`](#qiskit.quantum_info.PauliList.to_matrix "qiskit.quantum_info.PauliList.to_matrix") method. + +**Parameters** + +**sparse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – optionally return sparse CSR matrices if `True`, otherwise return Numpy array matrices (Default: `False`) + +**Returns** + +matrix iterator object for the PauliList. + +**Return type** + +MatrixIterator + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the compose of a operator with itself n times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of times to compose with self (n>0). + +**Returns** + +the n-times composed operator. + +**Return type** + +[Clifford](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the operator are not equal, or the power is not a positive integer. + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### sort + + + +`sort(weight=False, phase=False)` + +Sort the rows of the table. + +The default sort method is lexicographic sorting by qubit number. By using the weight kwarg the output can additionally be sorted by the number of non-identity terms in the Pauli, where the set of all Paulis of a given weight are still ordered lexicographically. + +**Example** + +Consider sorting all a random ordering of all 2-qubit Paulis + +```python +from numpy.random import shuffle +from qiskit.quantum_info.operators import PauliList + +# 2-qubit labels +labels = ['II', 'IX', 'IY', 'IZ', 'XI', 'XX', 'XY', 'XZ', + 'YI', 'YX', 'YY', 'YZ', 'ZI', 'ZX', 'ZY', 'ZZ'] +# Shuffle Labels +shuffle(labels) +pt = PauliList(labels) +print('Initial Ordering') +print(pt) + +# Lexicographic Ordering +srt = pt.sort() +print('Lexicographically sorted') +print(srt) + +# Weight Ordering +srt = pt.sort(weight=True) +print('Weight sorted') +print(srt) +``` + +```python +Initial Ordering +['YX', 'ZZ', 'XZ', 'YI', 'YZ', 'II', 'XX', 'XI', 'XY', 'YY', 'IX', 'IZ', + 'ZY', 'ZI', 'ZX', 'IY'] +Lexicographically sorted +['II', 'IX', 'IY', 'IZ', 'XI', 'XX', 'XY', 'XZ', 'YI', 'YX', 'YY', 'YZ', + 'ZI', 'ZX', 'ZY', 'ZZ'] +Weight sorted +['II', 'IX', 'IY', 'IZ', 'XI', 'YI', 'ZI', 'XX', 'XY', 'XZ', 'YX', 'YY', + 'YZ', 'ZX', 'ZY', 'ZZ'] +``` + +**Parameters** + +* **weight** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – optionally sort by weight if `True` (Default: `False`). +* **phase** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optionally sort by phase before weight or order (Default: `False`). + +**Returns** + +a sorted copy of the original table. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +### tensor + + + +`tensor(other)` + +Return the tensor product with each Pauli in the list. + +**Parameters** + +**other** ([*PauliList*](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")) – another PauliList. + +**Returns** + +the list of tensor product Paulis. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to a PauliList, does not have either 1 or the same number of Paulis as the current list. + +### to\_labels + + + +`to_labels(array=False)` + +Convert a PauliList to a list Pauli string labels. + +For large PauliLists converting using the `array=True` kwarg will be more efficient since it allocates memory for the full Numpy array of labels in advance. + +| Label | Symplectic | Matrix | +| ----- | ---------- | ----------------------------------------------- | +| `"I"` | $[0, 0]$ | $\begin{bmatrix} 1 & 0 \\ 0 & 1 \end{bmatrix}$ | +| `"X"` | $[1, 0]$ | $\begin{bmatrix} 0 & 1 \\ 1 & 0 \end{bmatrix}$ | +| `"Y"` | $[1, 1]$ | $\begin{bmatrix} 0 & -i \\ i & 0 \end{bmatrix}$ | +| `"Z"` | $[0, 1]$ | $\begin{bmatrix} 1 & 0 \\ 0 & -1 \end{bmatrix}$ | + +**Parameters** + +**array** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – return a Numpy array if `True`, otherwise return a list (Default: `False`). + +**Returns** + +The rows of the PauliList in label form. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") or array + +### to\_matrix + + + +`to_matrix(sparse=False, array=False)` + +Convert to a list or array of Pauli matrices. + +For large PauliLists converting using the `array=True` kwarg will be more efficient since it allocates memory a full rank-3 Numpy array of matrices in advance. + +| Label | Symplectic | Matrix | +| ----- | ---------- | ----------------------------------------------- | +| `"I"` | $[0, 0]$ | $\begin{bmatrix} 1 & 0 \\ 0 & 1 \end{bmatrix}$ | +| `"X"` | $[1, 0]$ | $\begin{bmatrix} 0 & 1 \\ 1 & 0 \end{bmatrix}$ | +| `"Y"` | $[1, 1]$ | $\begin{bmatrix} 0 & -i \\ i & 0 \end{bmatrix}$ | +| `"Z"` | $[0, 1]$ | $\begin{bmatrix} 1 & 0 \\ 0 & -1 \end{bmatrix}$ | + +**Parameters** + +* **sparse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` return sparse CSR matrices, otherwise return dense Numpy arrays (Default: `False`). +* **array** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – return as rank-3 numpy array if `True`, otherwise return a list of Numpy arrays (Default: `False`). + +**Returns** + +A list of dense Pauli matrices if ```array=False` and ``sparse=False`. list: A list of sparse Pauli matrices if ``array=False``` and `sparse=True`. array: A dense rank-3 array of Pauli matrices if `array=True`. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +### transpose + + + +`transpose()` + +Return the transpose of each Pauli in the list. + +### unique + + + +`unique(return_index=False, return_counts=False)` + +Return unique Paulis from the table. + +**Example** + +```python +from qiskit.quantum_info.operators import PauliList + +pt = PauliList(['X', 'Y', '-X', 'I', 'I', 'Z', 'X', 'iZ']) +unique = pt.unique() +print(unique) +``` + +```python +['X', 'Y', '-X', 'I', 'Z', 'iZ'] +``` + +**Parameters** + +* **return\_index** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, also return the indices that result in the unique array. (Default: `False`) +* **return\_counts** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, also return the number of times each unique item appears in the table. + +**Returns** + +**unique** + +the table of the unique rows. + +**unique\_indices: np.ndarray, optional** + +The indices of the first occurrences of the unique values in the original array. Only provided if `return_index` is `True`. + +**unique\_counts: np.array, optional** + +The number of times each of the unique values comes up in the original array. Only provided if `return_counts` is `True`. + +**Return type** + +[PauliList](#qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Quaternion.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Quaternion.md new file mode 100644 index 00000000000..2612186176d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Quaternion.md @@ -0,0 +1,126 @@ +--- +title: Quaternion +description: API reference for qiskit.quantum_info.Quaternion +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Quaternion +--- + +# Quaternion + + + +`qiskit.quantum_info.Quaternion(data)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/quaternion.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A class representing a Quaternion. + +## Methods + +### from\_axis\_rotation + + + +`classmethod from_axis_rotation(angle, axis)` + +Return quaternion for rotation about given axis. + +**Parameters** + +* **angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Angle in radians. +* **axis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Axis for rotation + +**Returns** + +Quaternion for axis rotation. + +**Return type** + +[Quaternion](#qiskit.quantum_info.Quaternion "qiskit.quantum_info.Quaternion") + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – Invalid input axis. + +### from\_euler + + + +`classmethod from_euler(angles, order='yzy')` + +Generate a quaternion from a set of Euler angles. + +**Parameters** + +* **angles** (*array\_like*) – Array of Euler angles. +* **order** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Order of Euler rotations. ‘yzy’ is default. + +**Returns** + +Quaternion representation of Euler rotation. + +**Return type** + +[Quaternion](#qiskit.quantum_info.Quaternion "qiskit.quantum_info.Quaternion") + +### norm + + + +`norm()` + +Norm of quaternion. + +### normalize + + + +`normalize(inplace=False)` + +Normalizes a Quaternion to unit length so that it represents a valid rotation. + +**Parameters** + +**inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Do an inplace normalization. + +**Returns** + +Normalized quaternion. + +**Return type** + +[Quaternion](#qiskit.quantum_info.Quaternion "qiskit.quantum_info.Quaternion") + +### to\_matrix + + + +`to_matrix()` + +Converts a unit-length quaternion to a rotation matrix. + +**Returns** + +Rotation matrix. + +**Return type** + +ndarray + +### to\_zyz + + + +`to_zyz()` + +Converts a unit-length quaternion to a sequence of ZYZ Euler angles. + +**Returns** + +Array of Euler angles. + +**Return type** + +ndarray + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.ScalarOp.md b/docs/api/qiskit/0.46/qiskit.quantum_info.ScalarOp.md new file mode 100644 index 00000000000..a6cd5c7fc66 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.ScalarOp.md @@ -0,0 +1,302 @@ +--- +title: ScalarOp +description: API reference for qiskit.quantum_info.ScalarOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.ScalarOp +--- + +# ScalarOp + + + +`qiskit.quantum_info.ScalarOp(dims=None, coeff=1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/scalar_op.py "view source code") + +Bases: `LinearOp` + +Scalar identity operator class. + +This is a symbolic representation of an scalar identity operator on multiple subsystems. It may be used to initialize a symbolic scalar multiplication of an identity and then be implicitly converted to other kinds of operator subclasses by using the [`compose()`](#qiskit.quantum_info.ScalarOp.compose "qiskit.quantum_info.ScalarOp.compose"), [`dot()`](#qiskit.quantum_info.ScalarOp.dot "qiskit.quantum_info.ScalarOp.dot"), [`tensor()`](#qiskit.quantum_info.ScalarOp.tensor "qiskit.quantum_info.ScalarOp.tensor"), [`expand()`](#qiskit.quantum_info.ScalarOp.expand "qiskit.quantum_info.ScalarOp.expand") methods. + +Initialize an operator object. + +**Parameters** + +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – subsystem dimensions. +* **coeff** (*Number*) – scalar coefficient for the identity operator (Default: 1). + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the optional coefficient is invalid. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### coeff + +Return the coefficient + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the Operator. + +**Return type** + +*Self* + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another ScalarOp. + +**Parameters** + +* **other** ([*ScalarOp*](#qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp")) – a ScalarOp object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed ScalarOp. + +**Return type** + +[ScalarOp](#qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.ScalarOp.dot "qiskit.quantum_info.ScalarOp.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.ScalarOp.dot "qiskit.quantum_info.ScalarOp.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate of the ScalarOp. + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another ScalarOp. + +**Parameters** + +**other** ([*ScalarOp*](#qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp")) – a ScalarOp object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current ScalarOp, and $b$ is the other ScalarOp. + +**Return type** + +[ScalarOp](#qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if operator is a unitary matrix. + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the power of the ScalarOp. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the exponent for the scalar op. + +**Returns** + +the `coeff ** n` ScalarOp. + +**Return type** + +[ScalarOp](#qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp") + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another ScalarOp. + +**Parameters** + +**other** ([*ScalarOp*](#qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp")) – a ScalarOp object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current ScalarOp, and $b$ is the other ScalarOp. + +**Return type** + +[ScalarOp](#qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_matrix + + + +`to_matrix()` + +Convert to a Numpy matrix. + +### to\_operator + + + +`to_operator()` + +Convert to an Operator object. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose of the ScalarOp. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.SparsePauliOp.md b/docs/api/qiskit/0.46/qiskit.quantum_info.SparsePauliOp.md new file mode 100644 index 00000000000..951973fa0e1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.SparsePauliOp.md @@ -0,0 +1,881 @@ +--- +title: SparsePauliOp +description: API reference for qiskit.quantum_info.SparsePauliOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.SparsePauliOp +--- + +# SparsePauliOp + + + +`qiskit.quantum_info.SparsePauliOp(data, coeffs=None, *, ignore_pauli_phase=False, copy=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/sparse_pauli_op.py "view source code") + +Bases: `LinearOp` + +Sparse N-qubit operator in a Pauli basis representation. + +This is a sparse representation of an N-qubit matrix [`Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") in terms of N-qubit [`PauliList`](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") and complex coefficients. + +It can be used for performing operator arithmetic for hundred of qubits if the number of non-zero Pauli basis terms is sufficiently small. + +The Pauli basis components are stored as a [`PauliList`](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") object and can be accessed using the [`paulis`](#qiskit.quantum_info.SparsePauliOp.paulis "qiskit.quantum_info.SparsePauliOp.paulis") attribute. The coefficients are stored as a complex Numpy array vector and can be accessed using the [`coeffs`](#qiskit.quantum_info.SparsePauliOp.coeffs "qiskit.quantum_info.SparsePauliOp.coeffs") attribute. + +**Data type of coefficients** + +The default `dtype` of the internal `coeffs` Numpy array is `complex128`. Users can configure this by passing `np.ndarray` with a different dtype. For example, a parameterized [`SparsePauliOp`](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") can be made as follows: + +```python +>>> import numpy as np +>>> from qiskit.circuit import ParameterVector +>>> from qiskit.quantum_info import SparsePauliOp + +>>> SparsePauliOp(["II", "XZ"], np.array(ParameterVector("a", 2))) +SparsePauliOp(['II', 'XZ'], + coeffs=[ParameterExpression(1.0*a[0]), ParameterExpression(1.0*a[1])]) +``` + + + Parameterized [`SparsePauliOp`](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") does not support the following methods: + + * `to_matrix(sparse=True)` since `scipy.sparse` cannot have objects as elements. + * `to_operator()` since [`Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") does not support objects. + * `sort`, `argsort` since [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") does not support comparison. + * `equiv` since [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") cannot be converted into complex. + * `chop` since [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") does not support absolute value. + + +Initialize an operator object. + +**Parameters** + +* **data** ([*PauliList*](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") *or*[*SparsePauliOp*](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") *or*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Pauli list of terms. A list of Pauli strings or a Pauli string is also allowed. + +* **coeffs** (*np.ndarray*) – + + complex coefficients for Pauli terms. + + + If `data` is a [`SparsePauliOp`](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") and `coeffs` is not `None`, the value of the `SparsePauliOp.coeffs` will be ignored, and only the passed keyword argument `coeffs` will be used. + + +* **ignore\_pauli\_phase** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if true, any `phase` component of a given [`PauliList`](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") will be assumed to be zero. This is more efficient in cases where a [`PauliList`](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") has been constructed purely for this object, and it is already known that the phases in the ZX-convention are zero. It only makes sense to pass this option when giving [`PauliList`](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") data. (Default: False) + +* **copy** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – copy the input data if True, otherwise assign it directly, if possible. (Default: True) + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the input data or coeffs are invalid. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### coeffs + +Return the Pauli coefficients. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### parameters + +Return the free `Parameter`s in the coefficients. + + + +### paulis + +Return the PauliList. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + + + +### size + +The number of Pauli of Pauli terms in the operator. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint of the Operator. + +### apply\_layout + + + +`apply_layout(layout, num_qubits=None)` + +Apply a transpiler layout to this [`SparsePauliOp`](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +**Parameters** + +* **layout** ([*TranspileLayout*](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") *| List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Either a [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") or a list of integers. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits to expand the operator to. If not provided then if `layout` is a [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") the number of the transpiler output circuit qubits will be used by default. If `layout` is a list of integers the permutation specified will be applied without any expansion. + +**Returns** + +A new [`SparsePauliOp`](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") with the provided layout applied + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +### argsort + + + +`argsort(weight=False)` + +Return indices for sorting the rows of the table. + +Returns the composition of permutations in the order of sorting by coefficient and sorting by Pauli. By using the weight kwarg the output can additionally be sorted by the number of non-identity terms in the Pauli, where the set of all Pauli’s of a given weight are still ordered lexicographically. + +**Example** + +Here is an example of how to use SparsePauliOp argsort. + +```python +import numpy as np +from qiskit.quantum_info import SparsePauliOp + +# 2-qubit labels +labels = ["XX", "XX", "XX", "YI", "II", "XZ", "XY", "XI"] +# coeffs +coeffs = [2.+1.j, 2.+2.j, 3.+0.j, 3.+0.j, 4.+0.j, 5.+0.j, 6.+0.j, 7.+0.j] + +# init +spo = SparsePauliOp(labels, coeffs) +print('Initial Ordering') +print(spo) + +# Lexicographic Ordering +srt = spo.argsort() +print('Lexicographically sorted') +print(srt) + +# Lexicographic Ordering +srt = spo.argsort(weight=False) +print('Lexicographically sorted') +print(srt) + +# Weight Ordering +srt = spo.argsort(weight=True) +print('Weight sorted') +print(srt) +``` + +```python +Initial Ordering +SparsePauliOp(['XX', 'XX', 'XX', 'YI', 'II', 'XZ', 'XY', 'XI'], + coeffs=[2.+1.j, 2.+2.j, 3.+0.j, 3.+0.j, 4.+0.j, 5.+0.j, 6.+0.j, 7.+0.j]) +Lexicographically sorted +[4 7 0 1 2 6 5 3] +Lexicographically sorted +[4 7 0 1 2 6 5 3] +Weight sorted +[4 7 3 0 1 2 6 5] +``` + +**Parameters** + +* **weight** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – optionally sort by weight if True (Default: False). +* **sorted** (*By using the weight kwarg the output can additionally be*) – +* **Pauli.** (*by the number of non-identity terms in the*) – + +**Returns** + +the indices for sorting the table. + +**Return type** + +array + +### assign\_parameters + + + +`assign_parameters(parameters, inplace=False)` + +Bind the free `Parameter`s in the coefficients to provided values. + +**Parameters** + +* **parameters** (*Mapping\[*[*Parameter*](qiskit.circuit.Parameter "qiskit.circuit.Parameter")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*] | Sequence\[*[*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")*]*) – The values to bind the parameters to. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False`, a copy of the operator with the bound parameters is returned. If `True` the operator itself is modified. + +**Returns** + +A copy of the operator with bound parameters, if `inplace` is `False`, otherwise `None`. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") | None + +### chop + + + +`chop(tol=1e-14)` + +Set real and imaginary parts of the coefficients to 0 if `< tol` in magnitude. + +For example, the operator representing `1+1e-17j X + 1e-17 Y` with a tolerance larger than `1e-17` will be reduced to `1 X` whereas [`SparsePauliOp.simplify()`](#qiskit.quantum_info.SparsePauliOp.simplify "qiskit.quantum_info.SparsePauliOp.simplify") would return `1+1e-17j X`. + +If a both the real and imaginary part of a coefficient is 0 after chopping, the corresponding Pauli is removed from the operator. + +**Parameters** + +**tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The absolute tolerance to check whether a real or imaginary part should be set to 0. + +**Returns** + +This operator with chopped coefficients. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another SparsePauliOp. + +**Parameters** + +* **other** ([*SparsePauliOp*](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")) – a SparsePauliOp object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed SparsePauliOp. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.SparsePauliOp.dot "qiskit.quantum_info.SparsePauliOp.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.SparsePauliOp.dot "qiskit.quantum_info.SparsePauliOp.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate of the SparsePauliOp. + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### equiv + + + +`equiv(other, atol=None)` + +Check if two SparsePauliOp operators are equivalent. + +**Parameters** + +* **other** ([*SparsePauliOp*](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")) – an operator object. +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Absolute numerical tolerance for checking equivalence. + +**Returns** + +True if the operator is equivalent to `self`. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another SparsePauliOp. + +**Parameters** + +**other** ([*SparsePauliOp*](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")) – a SparsePauliOp object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current SparsePauliOp, and $b$ is the other SparsePauliOp. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +### from\_list + + + +`static from_list(obj, dtype=, *, num_qubits=None)` + +Construct from a list of Pauli strings and coefficients. + +For example, the 5-qubit Hamiltonian + +$$ +H = Z_1 X_4 + 2 Y_0 Y_3 +$$ + +can be constructed as + +```python +# via tuples and the full Pauli string +op = SparsePauliOp.from_list([("XIIZI", 1), ("IYIIY", 2)]) +``` + +**Parameters** + +* **obj** (*Iterable\[Tuple\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]]*) – The list of 2-tuples specifying the Pauli terms. +* **dtype** ([*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)")) – The dtype of coeffs (Default: complex). +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits of the operator (Default: None). + +**Returns** + +The SparsePauliOp representation of the Pauli terms. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If an empty list is passed and num\_qubits is None. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If num\_qubits and the objects in the input list do not match. + +### from\_operator + + + +`static from_operator(obj, atol=None, rtol=None)` + +Construct from an Operator objector. + +Note that the cost of this construction is exponential as it involves taking inner products with every element of the N-qubit Pauli basis. + +**Parameters** + +* **obj** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an N-qubit operator. +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Optional. Absolute tolerance for checking if coefficients are zero (Default: 1e-8). +* **rtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Optional. relative tolerance for checking if coefficients are zero (Default: 1e-5). + +**Returns** + +the SparsePauliOp representation of the operator. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input operator is not an N-qubit operator. + +### from\_sparse\_list + + + +`static from_sparse_list(obj, num_qubits, do_checks=True, dtype=)` + +Construct from a list of local Pauli strings and coefficients. + +Each list element is a 3-tuple of a local Pauli string, indices where to apply it, and a coefficient. + +For example, the 5-qubit Hamiltonian + +$$ +H = Z_1 X_4 + 2 Y_0 Y_3 +$$ + +can be constructed as + +```python +# via triples and local Paulis with indices +op = SparsePauliOp.from_sparse_list([("ZX", [1, 4], 1), ("YY", [0, 3], 2)], num_qubits=5) + +# equals the following construction from "dense" Paulis +op = SparsePauliOp.from_list([("XIIZI", 1), ("IYIIY", 2)]) +``` + +**Parameters** + +* **obj** (*Iterable\[*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*],* [*complex*](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")*]]*) – The list 3-tuples specifying the Paulis. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits of the operator. +* **do\_checks** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – The flag of checking if the input indices are not duplicated +* \*\*(\*\***Default** – True). +* **dtype** ([*type*](https://docs.python.org/3/library/functions.html#type "(in Python v3.12)")) – The dtype of coeffs (Default: complex). + +**Returns** + +The SparsePauliOp representation of the Pauli terms. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the number of qubits is incompatible with the indices of the Pauli terms. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the designated qubit is already assigned. + +### group\_commuting + + + +`group_commuting(qubit_wise=False)` + +Partition a SparsePauliOp into sets of commuting Pauli strings. + +**Parameters** + +**qubit\_wise** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – + +whether the commutation rule is applied to the whole operator, or on a per-qubit basis. For example: + +```python +>>> op = SparsePauliOp.from_list([("XX", 2), ("YY", 1), ("IZ",2j), ("ZZ",1j)]) +>>> op.group_commuting() +[SparsePauliOp(["IZ", "ZZ"], coeffs=[0.+2.j, 0.+1j]), + SparsePauliOp(["XX", "YY"], coeffs=[2.+0.j, 1.+0.j])] +>>> op.group_commuting(qubit_wise=True) +[SparsePauliOp(['XX'], coeffs=[2.+0.j]), + SparsePauliOp(['YY'], coeffs=[1.+0.j]), + SparsePauliOp(['IZ', 'ZZ'], coeffs=[0.+2.j, 0.+1.j])] +``` + +**Returns** + +**List of SparsePauliOp where each SparsePauliOp contains** + +commuting Pauli operators. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")] + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if operator is a unitary matrix. + +**Parameters** + +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Optional. Absolute tolerance for checking if coefficients are zero (Default: 1e-8). +* **rtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Optional. relative tolerance for checking if coefficients are zero (Default: 1e-5). + +**Returns** + +True if the operator is unitary, False otherwise. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### label\_iter + + + +`label_iter()` + +Return a label representation iterator. + +This is a lazy iterator that converts each term in the SparsePauliOp into a tuple (label, coeff). To convert the entire table to labels use the `to_labels()` method. + +**Returns** + +label iterator object for the SparsePauliOp. + +**Return type** + +LabelIterator + +### matrix\_iter + + + +`matrix_iter(sparse=False)` + +Return a matrix representation iterator. + +This is a lazy iterator that converts each term in the SparsePauliOp into a matrix as it is used. To convert to a single matrix use the [`to_matrix()`](#qiskit.quantum_info.SparsePauliOp.to_matrix "qiskit.quantum_info.SparsePauliOp.to_matrix") method. + +**Parameters** + +**sparse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – optionally return sparse CSR matrices if True, otherwise return Numpy array matrices (Default: False) + +**Returns** + +matrix iterator object for the PauliList. + +**Return type** + +MatrixIterator + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the compose of a operator with itself n times. + +**Parameters** + +**n** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of times to compose with self (n>0). + +**Returns** + +the n-times composed operator. + +**Return type** + +[Clifford](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the operator are not equal, or the power is not a positive integer. + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### simplify + + + +`simplify(atol=None, rtol=None)` + +Simplify PauliList by combining duplicates and removing zeros. + +**Parameters** + +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Optional. Absolute tolerance for checking if coefficients are zero (Default: 1e-8). +* **rtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Optional. relative tolerance for checking if coefficients are zero (Default: 1e-5). + +**Returns** + +the simplified SparsePauliOp operator. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +### sort + + + +`sort(weight=False)` + +Sort the rows of the table. + +After sorting the coefficients using numpy’s argsort, sort by Pauli. Pauli sort takes precedence. If Pauli is the same, it will be sorted by coefficient. By using the weight kwarg the output can additionally be sorted by the number of non-identity terms in the Pauli, where the set of all Pauli’s of a given weight are still ordered lexicographically. + +**Example** + +Here is an example of how to use SparsePauliOp sort. + +```python +import numpy as np +from qiskit.quantum_info import SparsePauliOp + +# 2-qubit labels +labels = ["XX", "XX", "XX", "YI", "II", "XZ", "XY", "XI"] +# coeffs +coeffs = [2.+1.j, 2.+2.j, 3.+0.j, 3.+0.j, 4.+0.j, 5.+0.j, 6.+0.j, 7.+0.j] + +# init +spo = SparsePauliOp(labels, coeffs) +print('Initial Ordering') +print(spo) + +# Lexicographic Ordering +srt = spo.sort() +print('Lexicographically sorted') +print(srt) + +# Lexicographic Ordering +srt = spo.sort(weight=False) +print('Lexicographically sorted') +print(srt) + +# Weight Ordering +srt = spo.sort(weight=True) +print('Weight sorted') +print(srt) +``` + +```python +Initial Ordering +SparsePauliOp(['XX', 'XX', 'XX', 'YI', 'II', 'XZ', 'XY', 'XI'], + coeffs=[2.+1.j, 2.+2.j, 3.+0.j, 3.+0.j, 4.+0.j, 5.+0.j, 6.+0.j, 7.+0.j]) +Lexicographically sorted +SparsePauliOp(['II', 'XI', 'XX', 'XX', 'XX', 'XY', 'XZ', 'YI'], + coeffs=[4.+0.j, 7.+0.j, 2.+1.j, 2.+2.j, 3.+0.j, 6.+0.j, 5.+0.j, 3.+0.j]) +Lexicographically sorted +SparsePauliOp(['II', 'XI', 'XX', 'XX', 'XX', 'XY', 'XZ', 'YI'], + coeffs=[4.+0.j, 7.+0.j, 2.+1.j, 2.+2.j, 3.+0.j, 6.+0.j, 5.+0.j, 3.+0.j]) +Weight sorted +SparsePauliOp(['II', 'XI', 'YI', 'XX', 'XX', 'XX', 'XY', 'XZ'], + coeffs=[4.+0.j, 7.+0.j, 3.+0.j, 2.+1.j, 2.+2.j, 3.+0.j, 6.+0.j, 5.+0.j]) +``` + +**Parameters** + +* **weight** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – optionally sort by weight if True (Default: False). +* **sorted** (*By using the weight kwarg the output can additionally be*) – +* **Pauli.** (*by the number of non-identity terms in the*) – + +**Returns** + +a sorted copy of the original table. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +### sum + + + +`static sum(ops)` + +Sum of SparsePauliOps. + +This is a specialized version of the builtin `sum` function for SparsePauliOp with smaller overhead. + +**Parameters** + +**ops** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*SparsePauliOp*](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")*]*) – a list of SparsePauliOps. + +**Returns** + +the SparsePauliOp representing the sum of the input list. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input list is empty. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input list includes an object that is not SparsePauliOp. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the numbers of qubits of the objects in the input list do not match. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another SparsePauliOp. + +**Parameters** + +**other** ([*SparsePauliOp*](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")) – a SparsePauliOp object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current SparsePauliOp, and $b$ is the other SparsePauliOp. + +**Return type** + +[SparsePauliOp](#qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_list + + + +`to_list(array=False)` + +Convert to a list Pauli string labels and coefficients. + +For operators with a lot of terms converting using the `array=True` kwarg will be more efficient since it allocates memory for the full Numpy array of labels in advance. + +**Parameters** + +**array** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – return a Numpy array if True, otherwise return a list (Default: False). + +**Returns** + +List of pairs (label, coeff) for rows of the PauliList. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") or array + +### to\_matrix + + + +`to_matrix(sparse=False)` + +Convert to a dense or sparse matrix. + +**Parameters** + +**sparse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True return a sparse CSR matrix, otherwise return dense Numpy array (Default: False). + +**Returns** + +A dense matrix if sparse=False. csr\_matrix: A sparse matrix in CSR format if sparse=True. + +**Return type** + +array + +### to\_operator + + + +`to_operator()` + +Convert to a matrix Operator object + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose of the SparsePauliOp. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.StabilizerState.md b/docs/api/qiskit/0.46/qiskit.quantum_info.StabilizerState.md new file mode 100644 index 00000000000..1acb7f476c0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.StabilizerState.md @@ -0,0 +1,438 @@ +--- +title: StabilizerState +description: API reference for qiskit.quantum_info.StabilizerState +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.StabilizerState +--- + +# StabilizerState + + + +`qiskit.quantum_info.StabilizerState(data, validate=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/stabilizerstate.py "view source code") + +Bases: `QuantumState` + +StabilizerState class. Stabilizer simulator using the convention from reference \[1]. Based on the internal class [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford"). + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import StabilizerState, Pauli + +# Bell state generation circuit +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) +stab = StabilizerState(qc) + +# Print the StabilizerState +print(stab) + +# Calculate the StabilizerState measurement probabilities dictionary +print (stab.probabilities_dict()) + +# Calculate expectation value of the StabilizerState +print (stab.expectation_value(Pauli('ZZ'))) +``` + +```python +StabilizerState(StabilizerTable: ['+XX', '+ZZ']) +{'00': 0.5, '11': 0.5} +1 +``` + +**References** + +1. S. Aaronson, D. Gottesman, *Improved Simulation of Stabilizer Circuits*, Phys. Rev. A 70, 052328 (2004). [arXiv:quant-ph/0406196](https://arxiv.org/abs/quant-ph/0406196) + +Initialize a StabilizerState object. + +**Parameters** + +* **or** (*data (*[*StabilizerState*](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") *or*[*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") *or*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – qiskit.circuit.Instruction): Data from which the stabilizer state can be constructed. +* **validate** (*boolean*) – validate that the stabilizer state data is a valid Clifford. + +## Attributes + + + +### clifford + +Return StabilizerState Clifford data + + + +### dim + +Return total state dimension. + + + +### num\_qubits + +Return the number of qubits if a N-qubit state or None otherwise. + +## Methods + +### conjugate + + + +`conjugate()` + +Return the conjugate of the operator. + +### copy + + + +`copy()` + +Make a copy of current operator. + +### dims + + + +`dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### equiv + + + +`equiv(other)` + +Return True if the two generating sets generate the same stabilizer group. + +**Parameters** + +**other** ([*StabilizerState*](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState")) – another StabilizerState. + +**Returns** + +True if other has a generating set that generates the same StabilizerState. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### evolve + + + +`evolve(other, qargs=None)` + +Evolve a stabilizer state by a Clifford operator. + +**Parameters** + +* **other** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")) – The Clifford operator to evolve by. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a list of stabilizer subsystem positions to apply the operator on. + +**Returns** + +the output stabilizer state. + +**Return type** + +[StabilizerState](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a StabilizerState. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the operator dimension does not match the specified StabilizerState subsystem dimensions. + +### expand + + + +`expand(other)` + +Return the tensor product stabilizer state other ⊗ self. + +**Parameters** + +**other** ([*StabilizerState*](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState")) – a stabilizer state object. + +**Returns** + +the tensor product operator other ⊗ self. + +**Return type** + +[StabilizerState](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a StabilizerState. + +### expectation\_value + + + +`expectation_value(oper, qargs=None)` + +Compute the expectation value of a Pauli operator. + +**Parameters** + +* **oper** ([*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")) – a Pauli operator to evaluate expval. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to apply the operator on. + +**Returns** + +the expectation value (only 0 or 1 or -1 or i or -i). + +**Return type** + +[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if oper is not a Pauli operator. + +### is\_valid + + + +`is_valid(atol=None, rtol=None)` + +Return True if a valid StabilizerState. + +### measure + + + +`measure(qargs=None)` + +Measure subsystems and return outcome and post-measure state. + +Note that this function uses the QuantumStates internal random number generator for sampling the measurement outcome. The RNG seed can be set using the [`seed()`](#qiskit.quantum_info.StabilizerState.seed "qiskit.quantum_info.StabilizerState.seed") method. + +**Parameters** + +**qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +**the pair `(outcome, state)` where `outcome` is the** + +measurement outcome string label, and `state` is the collapsed post-measurement stabilizer state for the corresponding outcome. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + +### probabilities + + + +`probabilities(qargs=None, decimals=None)` + +Return the subsystem measurement probability vector. + +Measurement probabilities are with respect to measurement in the computation (diagonal) basis. + +**Parameters** + +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to return probabilities for, if None return for all subsystems (Default: None). +* **decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +The Numpy vector array of probabilities. + +**Return type** + +np.array + +### probabilities\_dict + + + +`probabilities_dict(qargs=None, decimals=None)` + +Return the subsystem measurement probability dictionary. + +Measurement probabilities are with respect to measurement in the computation (diagonal) basis. + +This dictionary representation uses a Ket-like notation where the dictionary keys are qudit strings for the subsystem basis vectors. If any subsystem has a dimension greater than 10 comma delimiters are inserted between integers so that subsystems can be distinguished. + +**Parameters** + +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to return probabilities for, if None return for all subsystems (Default: None). +* **decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +The measurement probabilities in dict (ket) form. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### purity + + + +`purity()` + +Return the purity of the quantum state, which equals to 1, since it is always a pure state. + +**Returns** + +the purity (should equal 1). + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input is not a StabilizerState. + +### reset + + + +`reset(qargs=None)` + +Reset state or subsystems to the 0-state. + +**Parameters** + +**qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – subsystems to reset, if None all subsystems will be reset to their 0-state (Default: None). + +**Returns** + +the reset state. + +**Return type** + +[StabilizerState](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") + +**Additional Information:** + +If all subsystems are reset this will return the ground state on all subsystems. If only some subsystems are reset this function will perform a measurement on those subsystems and evolve the subsystems so that the collapsed post-measurement states are rotated to the 0-state. The RNG seed for this sampling can be set using the [`seed()`](#qiskit.quantum_info.StabilizerState.seed "qiskit.quantum_info.StabilizerState.seed") method. + +### sample\_counts + + + +`sample_counts(shots, qargs=None)` + +Sample a dict of qubit measurement outcomes in the computational basis. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of samples to generate. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +sampled counts dictionary. + +**Return type** + +[Counts](qiskit.result.Counts "qiskit.result.Counts") + +Additional Information: + +> This function *samples* measurement outcomes using the measure [`probabilities()`](#qiskit.quantum_info.StabilizerState.probabilities "qiskit.quantum_info.StabilizerState.probabilities") for the current state and qargs. It does not actually implement the measurement so the current state is not modified. +> +> The seed for random number generator used for sampling can be set to a fixed value by using the stats [`seed()`](#qiskit.quantum_info.StabilizerState.seed "qiskit.quantum_info.StabilizerState.seed") method. + +### sample\_memory + + + +`sample_memory(shots, qargs=None)` + +Sample a list of qubit measurement outcomes in the computational basis. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of samples to generate. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +list of sampled counts if the order sampled. + +**Return type** + +np.array + +Additional Information: + +> This function implements the measurement [`measure()`](#qiskit.quantum_info.StabilizerState.measure "qiskit.quantum_info.StabilizerState.measure") method. +> +> The seed for random number generator used for sampling can be set to a fixed value by using the stats [`seed()`](#qiskit.quantum_info.StabilizerState.seed "qiskit.quantum_info.StabilizerState.seed") method. + +### seed + + + +`seed(value=None)` + +Set the seed for the quantum state RNG. + +### tensor + + + +`tensor(other)` + +Return the tensor product stabilizer state self ⊗ other. + +**Parameters** + +**other** ([*StabilizerState*](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState")) – a stabilizer state object. + +**Returns** + +the tensor product operator self ⊗ other. + +**Return type** + +[StabilizerState](#qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a StabilizerState. + +### to\_operator + + + +`to_operator()` + +Convert state to matrix operator class + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### trace + + + +`trace()` + +Return the trace of the stabilizer state as a density matrix, which equals to 1, since it is always a pure state. + +**Returns** + +the trace (should equal 1). + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input is not a StabilizerState. + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Statevector.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Statevector.md new file mode 100644 index 00000000000..d2fbdbb6bc8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Statevector.md @@ -0,0 +1,732 @@ +--- +title: Statevector +description: API reference for qiskit.quantum_info.Statevector +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Statevector +--- + +# Statevector + + + +`qiskit.quantum_info.Statevector(data, dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/statevector.py "view source code") + +Bases: `QuantumState`, `TolerancesMixin` + +Statevector class + +Initialize a statevector object. + +**Parameters** + +* **or** (*data (np.array or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*Statevector*](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – qiskit.circuit.Instruction): Data from which the statevector can be constructed. This can be either a complex vector, another statevector, a `Operator` with only one column or a `QuantumCircuit` or `Instruction`. If the data is a circuit or instruction, the statevector is constructed by assuming that all qubits are initialized to the zero state. +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Optional. The subsystem dimension of the state (See additional information). + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not valid. + +**Additional Information:** + +The `dims` kwarg can be None, an integer, or an iterable of integers. + +* `Iterable` – the subsystem dimensions are the values in the list with the total number of subsystems given by the length of the list. +* `Int` or `None` – the length of the input vector specifies the total dimension of the density matrix. If it is a power of two the state will be initialized as an N-qubit state. If it is not a power of two the state will have a single d-dimensional subsystem. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +Return data. + + + +### dim + +Return total state dimension. + + + +### num\_qubits + +Return the number of qubits if a N-qubit state or None otherwise. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### conjugate + + + +`conjugate()` + +Return the conjugate of the operator. + +**Return type** + +[*Statevector*](#qiskit.quantum_info.Statevector "qiskit.quantum_info.states.statevector.Statevector") + +### copy + + + +`copy()` + +Make a copy of current operator. + +### dims + + + +`dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### draw + + + +`draw(output=None, **drawer_args)` + +Return a visualization of the Statevector. + +**repr**: ASCII TextMatrix of the state’s `__repr__`. + +**text**: ASCII TextMatrix that can be printed in the console. + +**latex**: An IPython Latex object for displaying in Jupyter Notebooks. + +**latex\_source**: Raw, uncompiled ASCII source to generate array using LaTeX. + +**qsphere**: Matplotlib figure, rendering of statevector using plot\_state\_qsphere(). + +**hinton**: Matplotlib figure, rendering of statevector using plot\_state\_hinton(). + +**bloch**: Matplotlib figure, rendering of statevector using plot\_bloch\_multivector(). + +**city**: Matplotlib figure, rendering of statevector using plot\_state\_city(). + +**paulivec**: Matplotlib figure, rendering of statevector using plot\_state\_paulivec(). + +**Parameters** + +* **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Select the output method to use for drawing the state. Valid choices are repr, text, latex, latex\_source, qsphere, hinton, bloch, city, or paulivec. Default is repr. Default can be changed by adding the line `state_drawer = ` to `~/.qiskit/settings.conf` under `[default]`. +* **drawer\_args** – Arguments to be passed directly to the relevant drawing function or constructor (TextMatrix(), array\_to\_latex(), plot\_state\_qsphere(), plot\_state\_hinton() or plot\_bloch\_multivector()). See the relevant function under qiskit.visualization for that function’s documentation. + +**Returns** + +`matplotlib.Figure` or [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") or `TextMatrix` or `IPython.display.Latex`: Drawing of the Statevector. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – when an invalid output method is selected. + +**Examples** + +Plot one of the Bell states + +```python +from numpy import sqrt +from qiskit.quantum_info import Statevector +sv=Statevector([1/sqrt(2), 0, 0, -1/sqrt(2)]) +sv.draw(output='hinton') +``` + +![../\_images/qiskit-quantum\_info-Statevector-1.png](/images/api/qiskit/0.46/qiskit-quantum_info-Statevector-1.png) + +### equiv + + + +`equiv(other, rtol=None, atol=None)` + +Return True if other is equivalent as a statevector up to global phase. + + + If other is not a Statevector, but can be used to initialize a statevector object, this will check that Statevector(other) is equivalent to the current statevector up to global phase. + + +**Parameters** + +* **other** ([*Statevector*](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")) – an object from which a `Statevector` can be constructed. +* **rtol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – relative tolerance value for comparison. +* **atol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – absolute tolerance value for comparison. + +**Returns** + +True if statevectors are equivalent up to global phase. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### evolve + + + +`evolve(other, qargs=None)` + +Evolve a quantum state by the operator. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *|*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *|*[*circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")) – The operator to evolve by. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a list of Statevector subsystem positions to apply the operator on. + +**Returns** + +the output quantum state. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the operator dimension does not match the specified Statevector subsystem dimensions. + +### expand + + + +`expand(other)` + +Return the tensor product state other ⊗ self. + +**Parameters** + +**other** ([*Statevector*](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")) – a quantum state object. + +**Returns** + +the tensor product state other ⊗ self. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a quantum state. + +### expectation\_value + + + +`expectation_value(oper, qargs=None)` + +Compute the expectation value of an operator. + +**Parameters** + +* **oper** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator to evaluate expval of. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to apply operator on. + +**Returns** + +the expectation value. + +**Return type** + +[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)") + +### from\_instruction + + + +`classmethod from_instruction(instruction)` + +Return the output statevector of an instruction. + +The statevector is initialized in the state $|{0,\ldots,0}\rangle$ of the same number of qubits as the input instruction or circuit, evolved by the input instruction, and the output statevector returned. + +**Parameters** + +**instruction** ([*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – instruction or circuit + +**Returns** + +The final statevector. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the instruction contains invalid instructions for the statevector simulation. + +### from\_int + + + +`static from_int(i, dims)` + +Return a computational basis statevector. + +**Parameters** + +* **i** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the basis state element. +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The subsystem dimensions of the statevector (See additional information). + +**Returns** + +The computational basis state $|i\rangle$. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Additional Information:** + +The `dims` kwarg can be an integer or an iterable of integers. + +* `Iterable` – the subsystem dimensions are the values in the list with the total number of subsystems given by the length of the list. +* `Int` – the integer specifies the total dimension of the state. If it is a power of two the state will be initialized as an N-qubit state. If it is not a power of two the state will have a single d-dimensional subsystem. + +### from\_label + + + +`classmethod from_label(label)` + +Return a tensor product of Pauli X,Y,Z eigenstates. + +| Label | Statevector | +| ----- | ------------------------------- | +| `"0"` | $[1, 0]$ | +| `"1"` | $[0, 1]$ | +| `"+"` | $[1 / \sqrt{2}, 1 / \sqrt{2}]$ | +| `"-"` | $[1 / \sqrt{2}, -1 / \sqrt{2}]$ | +| `"r"` | $[1 / \sqrt{2}, i / \sqrt{2}]$ | +| `"l"` | $[1 / \sqrt{2}, -i / \sqrt{2}]$ | + +**Parameters** + +**label** (*string*) – a eigenstate string ket label (see table for allowed values). + +**Returns** + +The N-qubit basis state density matrix. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the label contains invalid characters, or the length of the label is larger than an explicitly specified num\_qubits. + +### inner + + + +`inner(other)` + +Return the inner product of self and other as $\langle self| other \rangle$. + +**Parameters** + +**other** ([*Statevector*](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")) – a quantum state object. + +**Returns** + +the inner product of self and other, $\langle self| other \rangle$. + +**Return type** + +np.complex128 + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a quantum state or has different dimension. + +### is\_valid + + + +`is_valid(atol=None, rtol=None)` + +Return True if a Statevector has norm 1. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### measure + + + +`measure(qargs=None)` + +Measure subsystems and return outcome and post-measure state. + +Note that this function uses the QuantumStates internal random number generator for sampling the measurement outcome. The RNG seed can be set using the [`seed()`](#qiskit.quantum_info.Statevector.seed "qiskit.quantum_info.Statevector.seed") method. + +**Parameters** + +**qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +**the pair `(outcome, state)` where `outcome` is the** + +measurement outcome string label, and `state` is the collapsed post-measurement state for the corresponding outcome. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + +### probabilities + + + +`probabilities(qargs=None, decimals=None)` + +Return the subsystem measurement probability vector. + +Measurement probabilities are with respect to measurement in the computation (diagonal) basis. + +**Parameters** + +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to return probabilities for, if None return for all subsystems (Default: None). +* **decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +The Numpy vector array of probabilities. + +**Return type** + +np.array + +**Examples** + +Consider a 2-qubit product state $|\psi\rangle=|+\rangle\otimes|0\rangle$. + +```python +from qiskit.quantum_info import Statevector + +psi = Statevector.from_label('+0') + +# Probabilities for measuring both qubits +probs = psi.probabilities() +print('probs: {}'.format(probs)) + +# Probabilities for measuring only qubit-0 +probs_qubit_0 = psi.probabilities([0]) +print('Qubit-0 probs: {}'.format(probs_qubit_0)) + +# Probabilities for measuring only qubit-1 +probs_qubit_1 = psi.probabilities([1]) +print('Qubit-1 probs: {}'.format(probs_qubit_1)) +``` + +```python +probs: [0.5 0. 0.5 0. ] +Qubit-0 probs: [1. 0.] +Qubit-1 probs: [0.5 0.5] +``` + +We can also permute the order of qubits in the `qargs` list to change the qubit position in the probabilities output + +```python +from qiskit.quantum_info import Statevector + +psi = Statevector.from_label('+0') + +# Probabilities for measuring both qubits +probs = psi.probabilities([0, 1]) +print('probs: {}'.format(probs)) + +# Probabilities for measuring both qubits +# but swapping qubits 0 and 1 in output +probs_swapped = psi.probabilities([1, 0]) +print('Swapped probs: {}'.format(probs_swapped)) +``` + +```python +probs: [0.5 0. 0.5 0. ] +Swapped probs: [0.5 0.5 0. 0. ] +``` + +### probabilities\_dict + + + +`probabilities_dict(qargs=None, decimals=None)` + +Return the subsystem measurement probability dictionary. + +Measurement probabilities are with respect to measurement in the computation (diagonal) basis. + +This dictionary representation uses a Ket-like notation where the dictionary keys are qudit strings for the subsystem basis vectors. If any subsystem has a dimension greater than 10 comma delimiters are inserted between integers so that subsystems can be distinguished. + +**Parameters** + +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to return probabilities for, if None return for all subsystems (Default: None). +* **decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +The measurement probabilities in dict (ket) form. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### purity + + + +`purity()` + +Return the purity of the quantum state. + +**Return type** + +*float64* + +### reset + + + +`reset(qargs=None)` + +Reset state or subsystems to the 0-state. + +**Parameters** + +**qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – subsystems to reset, if None all subsystems will be reset to their 0-state (Default: None). + +**Returns** + +the reset state. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Additional Information:** + +If all subsystems are reset this will return the ground state on all subsystems. If only a some subsystems are reset this function will perform a measurement on those subsystems and evolve the subsystems so that the collapsed post-measurement states are rotated to the 0-state. The RNG seed for this sampling can be set using the [`seed()`](#qiskit.quantum_info.Statevector.seed "qiskit.quantum_info.Statevector.seed") method. + +### reverse\_qargs + + + +`reverse_qargs()` + +Return a Statevector with reversed subsystem ordering. + +For a tensor product state this is equivalent to reversing the order of tensor product subsystems. For a statevector $|\psi \rangle = |\psi_{n-1} \rangle \otimes ... \otimes |\psi_0 \rangle$ the returned statevector will be $|\psi_{0} \rangle \otimes ... \otimes |\psi_{n-1} \rangle$. + +**Returns** + +the Statevector with reversed subsystem order. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +### sample\_counts + + + +`sample_counts(shots, qargs=None)` + +Sample a dict of qubit measurement outcomes in the computational basis. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of samples to generate. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +sampled counts dictionary. + +**Return type** + +[Counts](qiskit.result.Counts "qiskit.result.Counts") + +Additional Information: + +> This function *samples* measurement outcomes using the measure [`probabilities()`](#qiskit.quantum_info.Statevector.probabilities "qiskit.quantum_info.Statevector.probabilities") for the current state and qargs. It does not actually implement the measurement so the current state is not modified. +> +> The seed for random number generator used for sampling can be set to a fixed value by using the stats [`seed()`](#qiskit.quantum_info.Statevector.seed "qiskit.quantum_info.Statevector.seed") method. + +### sample\_memory + + + +`sample_memory(shots, qargs=None)` + +Sample a list of qubit measurement outcomes in the computational basis. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of samples to generate. +* **qargs** (*None or* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – subsystems to sample measurements for, if None sample measurement of all subsystems (Default: None). + +**Returns** + +list of sampled counts if the order sampled. + +**Return type** + +np.array + +Additional Information: + +> This function *samples* measurement outcomes using the measure [`probabilities()`](#qiskit.quantum_info.Statevector.probabilities "qiskit.quantum_info.Statevector.probabilities") for the current state and qargs. It does not actually implement the measurement so the current state is not modified. +> +> The seed for random number generator used for sampling can be set to a fixed value by using the stats [`seed()`](#qiskit.quantum_info.Statevector.seed "qiskit.quantum_info.Statevector.seed") method. + +### seed + + + +`seed(value=None)` + +Set the seed for the quantum state RNG. + +### tensor + + + +`tensor(other)` + +Return the tensor product state self ⊗ other. + +**Parameters** + +**other** ([*Statevector*](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")) – a quantum state object. + +**Returns** + +the tensor product operator self ⊗ other. + +**Return type** + +[Statevector](#qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other is not a quantum state. + +### to\_dict + + + +`to_dict(decimals=None)` + +Convert the statevector to dictionary form. + +This dictionary representation uses a Ket-like notation where the dictionary keys are qudit strings for the subsystem basis vectors. If any subsystem has a dimension greater than 10 comma delimiters are inserted between integers so that subsystems can be distinguished. + +**Parameters** + +**decimals** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimal places to round values. If None no rounding is done (Default: None). + +**Returns** + +the dictionary form of the Statevector. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Example** + +The ket-form of a 2-qubit statevector $|\psi\rangle = |-\rangle\otimes |0\rangle$ + +```python +from qiskit.quantum_info import Statevector + +psi = Statevector.from_label('-0') +print(psi.to_dict()) +``` + +```python +{'00': (0.7071067811865475+0j), '10': (-0.7071067811865475+0j)} +``` + +For non-qubit subsystems the integer range can go from 0 to 9. For example in a qutrit system + +```python +import numpy as np +from qiskit.quantum_info import Statevector + +vec = np.zeros(9) +vec[0] = 1 / np.sqrt(2) +vec[-1] = 1 / np.sqrt(2) +psi = Statevector(vec, dims=(3, 3)) +print(psi.to_dict()) +``` + +```python +{'00': (0.7071067811865475+0j), '22': (0.7071067811865475+0j)} +``` + +For large subsystem dimensions delimiters are required. The following example is for a 20-dimensional system consisting of a qubit and 10-dimensional qudit. + +```python +import numpy as np +from qiskit.quantum_info import Statevector + +vec = np.zeros(2 * 10) +vec[0] = 1 / np.sqrt(2) +vec[-1] = 1 / np.sqrt(2) +psi = Statevector(vec, dims=(2, 10)) +print(psi.to_dict()) +``` + +```python +{'00': (0.7071067811865475+0j), '91': (0.7071067811865475+0j)} +``` + +### to\_operator + + + +`to_operator()` + +Convert state to a rank-1 projector operator + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### trace + + + +`trace()` + +Return the trace of the quantum state as a density matrix. + +**Return type** + +*float64* + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Stinespring.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Stinespring.md new file mode 100644 index 00000000000..b4f3bdcff37 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Stinespring.md @@ -0,0 +1,399 @@ +--- +title: Stinespring +description: API reference for qiskit.quantum_info.Stinespring +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Stinespring +--- + +# Stinespring + + + +`qiskit.quantum_info.Stinespring(data, input_dims=None, output_dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/channel/stinespring.py "view source code") + +Bases: `QuantumChannel` + +Stinespring representation of a quantum channel. + +The Stinespring representation of a quantum channel $\mathcal{E}$ is a rectangular matrix $A$ such that the evolution of a [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") $\rho$ is given by + +$$ +\mathcal{E}(ρ) = \mbox{Tr}_2\left[A ρ A^\dagger\right] +$$ + +where $\mbox{Tr}_2$ is the [`partial_trace()`](quantum_info#qiskit.quantum_info.partial_trace "qiskit.quantum_info.partial_trace") over subsystem 2. + +A general operator map $\mathcal{G}$ can also be written using the generalized Stinespring representation which is given by two matrices $A$, $B$ such that + +$$ +\mathcal{G}(ρ) = \mbox{Tr}_2\left[A ρ B^\dagger\right] +$$ + +See reference \[1] for further details. + +**References** + +1. C.J. Wood, J.D. Biamonte, D.G. Cory, *Tensor networks and graphical calculus for open quantum systems*, Quant. Inf. Comp. 15, 0579-0811 (2015). [arXiv:1111.6950 \[quant-ph\]](https://arxiv.org/abs/1111.6950) + +Initialize a quantum channel Stinespring operator. + +**Parameters** + +* **or** (*data (*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Instruction or BaseOperator or matrix): data to initialize superoperator. +* **input\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input subsystem dimensions. \[Default: None] +* **output\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the output subsystem dimensions. \[Default: None] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data cannot be initialized as a a list of Kraus matrices. + +**Additional Information:** + +If the input or output dimensions are None, they will be automatically determined from the input data. This can fail for the Stinespring operator if the output dimension cannot be automatically determined. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint quantum channel. + + + This is equivalent to the matrix Hermitian conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the adjoint channel $\mathcal{{E}}^\dagger$ is $S_{\mathcal{E}^\dagger} = S_{\mathcal{E}}^\dagger$. + + +**Return type** + +*Self* + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another Stinespring. + +**Parameters** + +* **other** ([*Stinespring*](#qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring")) – a Stinespring object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed Stinespring. + +**Return type** + +[Stinespring](#qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.Stinespring.dot "qiskit.quantum_info.Stinespring.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.Stinespring.dot "qiskit.quantum_info.Stinespring.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate quantum channel. + + + This is equivalent to the matrix complex conjugate in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the conjugate channel $\overline{{\mathcal{{E}}}}$ is $S_{\overline{\mathcal{E}^\dagger}} = \overline{S_{\mathcal{E}}}$. + + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another Stinespring. + +**Parameters** + +**other** ([*Stinespring*](#qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring")) – a Stinespring object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current Stinespring, and $b$ is the other Stinespring. + +**Return type** + +[Stinespring](#qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_cp + + + +`is_cp(atol=None, rtol=None)` + +Test if Choi-matrix is completely-positive (CP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_cptp + + + +`is_cptp(atol=None, rtol=None)` + +Return True if completely-positive trace-preserving. + +### is\_tp + + + +`is_tp(atol=None, rtol=None)` + +Test if a channel is trace-preserving (TP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if QuantumChannel is a unitary channel. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the power of the quantum channel. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power exponent. + +**Returns** + +the channel $\mathcal{{E}} ^n$. + +**Return type** + +[SuperOp](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the SuperOp are not equal. + + + For non-positive or non-integer exponents the power is defined as the matrix power of the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{{E}}$, the SuperOp of the powered channel $\mathcal{{E}}^\n$ is $S_{{\mathcal{{E}}^n}} = S_{{\mathcal{{E}}}}^n$. + + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another Stinespring. + +**Parameters** + +**other** ([*Stinespring*](#qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring")) – a Stinespring object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current Stinespring, and $b$ is the other Stinespring. + +**Return type** + +[Stinespring](#qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to a Kraus or UnitaryGate circuit instruction. + +If the channel is unitary it will be added as a unitary gate, otherwise it will be added as a kraus simulator instruction. + +**Returns** + +A kraus instruction for the channel. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit CPTP quantum channel. + +### to\_operator + + + +`to_operator()` + +Try to convert channel to a unitary representation Operator. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose quantum channel. + + + This is equivalent to the matrix transpose in the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation, ie. for a channel $\mathcal{E}$, the SuperOp of the transpose channel $\mathcal{{E}}^T$ is $S_{mathcal{E}^T} = S_{\mathcal{E}}^T$. + + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.SuperOp.md b/docs/api/qiskit/0.46/qiskit.quantum_info.SuperOp.md new file mode 100644 index 00000000000..f52c92569a8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.SuperOp.md @@ -0,0 +1,395 @@ +--- +title: SuperOp +description: API reference for qiskit.quantum_info.SuperOp +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.SuperOp +--- + +# SuperOp + + + +`qiskit.quantum_info.SuperOp(data, input_dims=None, output_dims=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/channel/superop.py "view source code") + +Bases: `QuantumChannel` + +Superoperator representation of a quantum channel. + +The Superoperator representation of a quantum channel $\mathcal{E}$ is a matrix $S$ such that the evolution of a [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") $\rho$ is given by + +$$ +|\mathcal{E}(\rho)\rangle\!\rangle = S |\rho\rangle\!\rangle +$$ + +where the double-ket notation $|A\rangle\!\rangle$ denotes a vector formed by stacking the columns of the matrix $A$ *(column-vectorization)*. + +See reference \[1] for further details. + +**References** + +1. C.J. Wood, J.D. Biamonte, D.G. Cory, *Tensor networks and graphical calculus for open quantum systems*, Quant. Inf. Comp. 15, 0579-0811 (2015). [arXiv:1111.6950 \[quant-ph\]](https://arxiv.org/abs/1111.6950) + +Initialize a quantum channel Superoperator operator. + +**Parameters** + +* **or** (*data (*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Instruction or BaseOperator or matrix): data to initialize superoperator. +* **input\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input subsystem dimensions. \[Default: None] +* **output\_dims** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the output subsystem dimensions. \[Default: None] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data cannot be initialized as a superoperator. + +**Additional Information:** + +If the input or output dimensions are None, they will be automatically determined from the input data. If the input data is a Numpy array of shape (4\*\*N, 4\*\*N) qubit systems will be used. If the input operator is not an N-qubit operator, it will assign a single subsystem with dimension specified by the shape of the input. + +## Attributes + + + +### atol + +`= 1e-08` + + + +### data + +Return data. + + + +### dim + +Return tuple (input\_shape, output\_shape). + + + +### num\_qubits + +Return the number of qubits if a N-qubit operator or None otherwise. + + + +### qargs + +Return the qargs for the operator. + + + +### rtol + +`= 1e-05` + + + +### settings + +Return settings. + +## Methods + +### adjoint + + + +`adjoint()` + +Return the adjoint quantum channel. + + + This is equivalent to the matrix Hermitian conjugate in the [`SuperOp`](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the adjoint channel $\mathcal{{E}}^\dagger$ is $S_{\mathcal{E}^\dagger} = S_{\mathcal{E}}^\dagger$. + + +### compose + + + +`compose(other, qargs=None, front=False)` + +Return the operator composition with another SuperOp. + +**Parameters** + +* **other** ([*SuperOp*](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp")) – a SuperOp object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). +* **front** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True compose using right operator multiplication, instead of left multiplication \[default: False]. + +**Returns** + +The composed SuperOp. + +**Return type** + +[SuperOp](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if other cannot be converted to an operator, or has incompatible dimensions for specified subsystems. + + + Composition (`&`) by default is defined as left matrix multiplication for matrix operators, while `@` (equivalent to [`dot()`](#qiskit.quantum_info.SuperOp.dot "qiskit.quantum_info.SuperOp.dot")) is defined as right matrix multiplication. That is that `A & B == A.compose(B)` is equivalent to `B @ A == B.dot(A)` when `A` and `B` are of the same type. + + Setting the `front=True` kwarg changes this to right matrix multiplication and is equivalent to the [`dot()`](#qiskit.quantum_info.SuperOp.dot "qiskit.quantum_info.SuperOp.dot") method `A.dot(B) == A.compose(B, front=True)`. + + +### conjugate + + + +`conjugate()` + +Return the conjugate quantum channel. + + + This is equivalent to the matrix complex conjugate in the [`SuperOp`](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{E}$, the SuperOp of the conjugate channel $\overline{{\mathcal{{E}}}}$ is $S_{\overline{\mathcal{E}^\dagger}} = \overline{S_{\mathcal{E}}}$. + + +### copy + + + +`copy()` + +Make a deep copy of current operator. + +### dot + + + +`dot(other, qargs=None)` + +Return the right multiplied operator self \* other. + +**Parameters** + +* **other** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – an operator object. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – Optional, a list of subsystem positions to apply other on. If None apply on all subsystems (default: None). + +**Returns** + +The right matrix multiplied Operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + + + The dot product can be obtained using the `@` binary operator. Hence `a.dot(b)` is equivalent to `a @ b`. + + +### expand + + + +`expand(other)` + +Return the reverse-order tensor product with another SuperOp. + +**Parameters** + +**other** ([*SuperOp*](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp")) – a SuperOp object. + +**Returns** + +**the tensor product $b \otimes a$, where $a$** + +is the current SuperOp, and $b$ is the other SuperOp. + +**Return type** + +[SuperOp](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +### input\_dims + + + +`input_dims(qargs=None)` + +Return tuple of input dimension for specified subsystems. + +### is\_cp + + + +`is_cp(atol=None, rtol=None)` + +Test if Choi-matrix is completely-positive (CP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_cptp + + + +`is_cptp(atol=None, rtol=None)` + +Return True if completely-positive trace-preserving (CPTP). + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_tp + + + +`is_tp(atol=None, rtol=None)` + +Test if a channel is trace-preserving (TP) + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### is\_unitary + + + +`is_unitary(atol=None, rtol=None)` + +Return True if QuantumChannel is a unitary channel. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### output\_dims + + + +`output_dims(qargs=None)` + +Return tuple of output dimension for specified subsystems. + +### power + + + +`power(n)` + +Return the power of the quantum channel. + +**Parameters** + +**n** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – the power exponent. + +**Returns** + +the channel $\mathcal{{E}} ^n$. + +**Return type** + +[SuperOp](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input and output dimensions of the SuperOp are not equal. + + + For non-positive or non-integer exponents the power is defined as the matrix power of the [`SuperOp`](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation ie. for a channel $\mathcal{{E}}$, the SuperOp of the powered channel $\mathcal{{E}}^\n$ is $S_{{\mathcal{{E}}^n}} = S_{{\mathcal{{E}}}}^n$. + + +### reshape + + + +`reshape(input_dims=None, output_dims=None, num_qubits=None)` + +Return a shallow copy with reshaped input and output subsystem dimensions. + +**Parameters** + +* **input\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem input dimensions. If None the original input dims will be preserved \[Default: None]. +* **output\_dims** (*None or* [*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – new subsystem output dimensions. If None the original output dims will be preserved \[Default: None]. +* **num\_qubits** (*None or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – reshape to an N-qubit operator \[Default: None]. + +**Returns** + +returns self with reshaped input and output dimensions. + +**Return type** + +BaseOperator + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if combined size of all subsystem input dimension or subsystem output dimensions is not constant. + +### tensor + + + +`tensor(other)` + +Return the tensor product with another SuperOp. + +**Parameters** + +**other** ([*SuperOp*](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp")) – a SuperOp object. + +**Returns** + +**the tensor product $a \otimes b$, where $a$** + +is the current SuperOp, and $b$ is the other SuperOp. + +**Return type** + +[SuperOp](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") + + + The tensor product can be obtained using the `^` binary operator. Hence `a.tensor(b)` is equivalent to `a ^ b`. + + +### to\_instruction + + + +`to_instruction()` + +Convert to a Kraus or UnitaryGate circuit instruction. + +If the channel is unitary it will be added as a unitary gate, otherwise it will be added as a kraus simulator instruction. + +**Returns** + +A kraus instruction for the channel. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input data is not an N-qubit CPTP quantum channel. + +### to\_operator + + + +`to_operator()` + +Try to convert channel to a unitary representation Operator. + +**Return type** + +[*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.operators.operator.Operator") + +### transpose + + + +`transpose()` + +Return the transpose quantum channel. + + + This is equivalent to the matrix transpose in the [`SuperOp`](#qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") representation, ie. for a channel $\mathcal{E}$, the SuperOp of the transpose channel $\mathcal{{E}}^T$ is $S_{mathcal{E}^T} = S_{\mathcal{E}}^T$. + + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.Z2Symmetries.md b/docs/api/qiskit/0.46/qiskit.quantum_info.Z2Symmetries.md new file mode 100644 index 00000000000..c409ad4063e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.Z2Symmetries.md @@ -0,0 +1,192 @@ +--- +title: Z2Symmetries +description: API reference for qiskit.quantum_info.Z2Symmetries +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.quantum_info.Z2Symmetries +--- + +# Z2Symmetries + + + +`qiskit.quantum_info.Z2Symmetries(symmetries, sq_paulis, sq_list, tapering_values=None, *, tol=1e-14)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/analysis/z2_symmetries.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +The \$Z\_2\$ symmetry converter identifies symmetries from the problem hamiltonian and uses them to provide a tapered - more efficient - representation of operators as Paulis for this problem. For each identified symmetry, one qubit can be eliminated in the Pauli representation at the cost of having to test two symmetry sectors (for the two possible eigenvalues - tapering values - of the symmetry). In certain problems such as the finding of the main operator’s ground state, one can a priori identify the symmetry sector of the solution and thus effectively reduce the computational overhead. + +The following attributes can be read and updated once the `Z2Symmetries` object has been constructed. + + + +### tapering\_values + +Values determining the sector. + +**Type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] or None + + + +### tol + +The tolerance threshold for ignoring real and complex parts of a coefficient. + +**Type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**References** + +**\[1]: Bravyi, S., et al, “Tapering off qubits to simulate fermionic Hamiltonians”** + +[arXiv:1701.08213](https://arxiv.org/abs/1701.08213) + +**Parameters** + +* **symmetries** (*Iterable\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")*]*) – Object representing the list of \$Z\_2\$ symmetries. These correspond to the generators of the symmetry group \$langle tau\_1, tau\_2dots rangle>\$. +* **sq\_paulis** (*Iterable\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")*]*) – Object representing the list of single-qubit Pauli \$sigma^x\_\{q(i)}\$ anti-commuting with the symmetry \$tau\_i\$ and commuting with all the other symmetries \$tau\_\{jneq i}\$. These operators are used to construct the unitary Clifford operators. +* **sq\_list** (*Iterable\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – The list of indices \$q(i)\$ of the single-qubit Pauli operators used to build the Clifford operators. +* **tapering\_values** (*Iterable\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – List of eigenvalues determining the symmetry sector for each symmetry. +* **tol** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Tolerance threshold for ignoring real and complex parts of a coefficient. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – Invalid paulis. The lists of symmetries, single-qubit paulis support paulis and tapering values must be of equal length. This length is the number of applied symmetries and translates directly to the number of eliminated qubits. + +## Attributes + + + +### cliffords + +Get clifford operators, built based on symmetries and single-qubit X. + +**Returns** + +A list of unitaries used to diagonalize the Hamiltonian. + + + +### settings + +Return operator settings. + + + +### sq\_list + +Return sq list. + + + +### sq\_paulis + +Return sq paulis. + + + +### symmetries + +Return symmetries. + +## Methods + +### convert\_clifford + + + +`convert_clifford(operator)` + +This method operates the first part of the tapering. It converts the operator by composing it with the clifford unitaries defined in the current symmetry. + +**Parameters** + +**operator** ([*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")) – The to-be-tapered operator. + +**Returns** + +`SparsePauliOp` corresponding to the converted operator. + +**Return type** + +[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp") + +### find\_z2\_symmetries + + + +`classmethod find_z2_symmetries(operator)` + +Finds Z2 Pauli-type symmetries of a [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"). + +**Returns** + +A `Z2Symmetries` instance. + +**Return type** + +[*Z2Symmetries*](#qiskit.quantum_info.Z2Symmetries "qiskit.quantum_info.analysis.z2_symmetries.Z2Symmetries") + +### is\_empty + + + +`is_empty()` + +Check the z2\_symmetries is empty or not. + +**Returns** + +Empty or not. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### taper + + + +`taper(operator)` + +Taper an operator based on the z2\_symmetries info and sector defined by tapering\_values. Returns operator if the symmetry object is empty. + +The tapering is a two-step algorithm which first converts the operator into a [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp") with same eigenvalues but where some qubits are only acted upon with the Pauli operators I or X. The number M of these redundant qubits is equal to the number M of identified symmetries. + +The second step of the reduction consists in replacing these qubits with the possible eigenvalues of the corresponding Pauli X, giving 2^M new operators with M less qubits. If an eigenvalue sector was previously identified for the solution, then this reduces to 1 new operator with M less qubits. + +**Parameters** + +**operator** ([*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")) – The to-be-tapered operator. + +**Returns** + +\[[`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")]; otherwise, [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"). + +**Return type** + +If tapering\_values is None + +### taper\_clifford + + + +`taper_clifford(operator)` + +Operate the second part of the tapering. This function assumes that the input operators have already been transformed using [`convert_clifford()`](#qiskit.quantum_info.Z2Symmetries.convert_clifford "qiskit.quantum_info.Z2Symmetries.convert_clifford"). The redundant qubits due to the symmetries are dropped and replaced by their two possible eigenvalues. + +**Parameters** + +**operator** ([*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")) – Partially tapered operator resulting from a call to [`convert_clifford()`](#qiskit.quantum_info.Z2Symmetries.convert_clifford "qiskit.quantum_info.Z2Symmetries.convert_clifford"). + +**Returns** + +\[[`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")]; otherwise, [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"). + +**Return type** + +If tapering\_values is None + diff --git a/docs/api/qiskit/0.46/qiskit.quantum_info.pauli_basis.md b/docs/api/qiskit/0.46/qiskit.quantum_info.pauli_basis.md new file mode 100644 index 00000000000..7f4330f3aea --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.quantum_info.pauli_basis.md @@ -0,0 +1,31 @@ +--- +title: pauli_basis +description: API reference for qiskit.quantum_info.pauli_basis +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.quantum_info.pauli_basis +--- + + + +# qiskit.quantum\_info.pauli\_basis + + + +`qiskit.quantum_info.pauli_basis(num_qubits, weight=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/pauli_utils.py "view source code") + +Return the ordered PauliList for the n-qubit Pauli basis. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits +* **weight** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True optionally return the basis sorted by Pauli weight rather than lexicographic order (Default: False) + +**Returns** + +the Paulis for the basis + +**Return type** + +[PauliList](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + diff --git a/docs/api/qiskit/0.46/qiskit.result.BaseReadoutMitigator.md b/docs/api/qiskit/0.46/qiskit.result.BaseReadoutMitigator.md new file mode 100644 index 00000000000..e10e4871916 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.BaseReadoutMitigator.md @@ -0,0 +1,69 @@ +--- +title: BaseReadoutMitigator +description: API reference for qiskit.result.BaseReadoutMitigator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.result.BaseReadoutMitigator +--- + +# BaseReadoutMitigator + + + +`qiskit.result.BaseReadoutMitigator`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/mitigation/base_readout_mitigator.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Base readout error mitigator class. + +## Methods + +### expectation\_value + + + +`abstract expectation_value(data, diagonal, qubits=None, clbits=None, shots=None)` + +Calculate the expectation value of a diagonal Hermitian operator. + +**Parameters** + +* **data** ([*Counts*](qiskit.result.Counts "qiskit.result.counts.Counts")) – Counts object to be mitigated. +* **diagonal** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – the diagonal operator. This may either be specified as a string containing I,Z,0,1 characters, or as a real valued 1D array\_like object supplying the full diagonal, or as a dictionary, or as Callable. +* **qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – the physical qubits measured to obtain the counts clbits. If None these are assumed to be qubits \[0, …, N-1] for N-bit counts. +* **clbits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, marginalize counts to just these bits. +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional, the total number of shots, if None shots will be calculated as the sum of all counts. + +**Returns** + +The mean and an upper bound of the standard deviation of operator expectation value calculated from the current counts. + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] + +### quasi\_probabilities + + + +`abstract quasi_probabilities(data, qubits=None, clbits=None, shots=None)` + +Convert counts to a dictionary of quasi-probabilities + +**Parameters** + +* **data** ([*Counts*](qiskit.result.Counts "qiskit.result.counts.Counts")) – Counts to be mitigated. +* **qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – the physical qubits measured to obtain the counts clbits. If None these are assumed to be qubits \[0, …, N-1] for N-bit counts. +* **clbits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, marginalize counts to just these bits. +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional, the total number of shots, if None shots will be calculated as the sum of all counts. + +**Returns** + +**A dictionary containing pairs of \[output, mean] where “output”** + +is the key in the dictionaries, which is the length-N bitstring of a measured standard basis state, and “mean” is the mean of non-zero quasi-probability estimates. + +**Return type** + +[QuasiDistribution](qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution") + diff --git a/docs/api/qiskit/0.46/qiskit.result.CorrelatedReadoutMitigator.md b/docs/api/qiskit/0.46/qiskit.result.CorrelatedReadoutMitigator.md new file mode 100644 index 00000000000..9f9c36d2f35 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.CorrelatedReadoutMitigator.md @@ -0,0 +1,166 @@ +--- +title: CorrelatedReadoutMitigator +description: API reference for qiskit.result.CorrelatedReadoutMitigator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.result.CorrelatedReadoutMitigator +--- + +# CorrelatedReadoutMitigator + + + +`qiskit.result.CorrelatedReadoutMitigator(assignment_matrix, qubits=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/mitigation/correlated_readout_mitigator.py "view source code") + +Bases: [`BaseReadoutMitigator`](qiskit.result.BaseReadoutMitigator "qiskit.result.mitigation.base_readout_mitigator.BaseReadoutMitigator") + +N-qubit readout error mitigator. + +Mitigates [`expectation_value()`](#qiskit.result.CorrelatedReadoutMitigator.expectation_value "qiskit.result.CorrelatedReadoutMitigator.expectation_value") and [`quasi_probabilities()`](#qiskit.result.CorrelatedReadoutMitigator.quasi_probabilities "qiskit.result.CorrelatedReadoutMitigator.quasi_probabilities"). The mitigation\_matrix should be calibrated using qiskit experiments. This mitigation method should be used in case the readout errors of the qubits are assumed to be correlated. The mitigation\_matrix of *N* qubits is of size $2^N x 2^N$ so the mitigation complexity is $O(4^N)$. + +Initialize a CorrelatedReadoutMitigator + +**Parameters** + +* **assignment\_matrix** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – readout error assignment matrix. +* **qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, the measured physical qubits for mitigation. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – matrix size does not agree with number of qubits + +## Attributes + + + +### qubits + +The device qubits for this mitigator + + + +### settings + +Return settings. + +## Methods + +### assignment\_matrix + + + +`assignment_matrix(qubits=None)` + +Return the readout assignment matrix for specified qubits. + +The assignment matrix is the stochastic matrix $A$ which assigns a noisy readout probability distribution to an ideal input readout distribution: $P(i|j) = \langle i | A | j \rangle$. + +**Parameters** + +**qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, qubits being measured. + +**Returns** + +the assignment matrix A. + +**Return type** + +np.ndarray + +### expectation\_value + + + +`expectation_value(data, diagonal=None, qubits=None, clbits=None, shots=None)` + +Compute the mitigated expectation value of a diagonal observable. + +This computes the mitigated estimator of $\langle O \rangle = \mbox{Tr}[\rho. O]$ of a diagonal observable $O = \sum_{x\in\{0, 1\}^n} O(x)|x\rangle\!\langle x|$. + +**Parameters** + +* **data** ([*Counts*](qiskit.result.Counts "qiskit.result.counts.Counts")) – Counts object +* **diagonal** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *| None*) – Optional, the vector of diagonal values for summing the expectation value. If `None` the default value is $[1, -1]^\otimes n$. +* **qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, the measured physical qubits the count bitstrings correspond to. If None qubits are assumed to be $[0, ..., n-1]$. +* **clbits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, if not None marginalize counts to the specified bits. +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – the number of shots. + +**Returns** + +the expectation value and an upper bound of the standard deviation. + +**Return type** + +([float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) + +**Additional Information:** + +The diagonal observable $O$ is input using the `diagonal` kwarg as a list or Numpy array $[O(0), ..., O(2^n -1)]$. If no diagonal is specified the diagonal of the Pauli operator :math\`O = mbox\{diag}(Z^\{otimes n}) = \[1, -1]^\{otimes n}\` is used. The `clbits` kwarg is used to marginalize the input counts dictionary over the specified bit-values, and the `qubits` kwarg is used to specify which physical qubits these bit-values correspond to as `circuit.measure(qubits, clbits)`. + +### mitigation\_matrix + + + +`mitigation_matrix(qubits=None)` + +Return the readout mitigation matrix for the specified qubits. + +The mitigation matrix $A^{-1}$ is defined as the inverse of the [`assignment_matrix()`](#qiskit.result.CorrelatedReadoutMitigator.assignment_matrix "qiskit.result.CorrelatedReadoutMitigator.assignment_matrix") $A$. + +**Parameters** + +**qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, qubits being measured. + +**Returns** + +the measurement error mitigation matrix $A^{-1}$. + +**Return type** + +np.ndarray + +### quasi\_probabilities + + + +`quasi_probabilities(data, qubits=None, clbits=None, shots=None)` + +Compute mitigated quasi probabilities value. + +**Parameters** + +* **data** ([*Counts*](qiskit.result.Counts "qiskit.result.counts.Counts")) – counts object +* **qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – qubits the count bitstrings correspond to. +* **clbits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, marginalize counts to just these bits. +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional, the total number of shots, if None shots will be calculated as the sum of all counts. + +**Returns** + +**A dictionary containing pairs of \[output, mean] where “output”** + +is the key in the dictionaries, which is the length-N bitstring of a measured standard basis state, and “mean” is the mean of non-zero quasi-probability estimates. + +**Return type** + +[QuasiDistribution](qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution") + +### stddev\_upper\_bound + + + +`stddev_upper_bound(shots)` + +Return an upper bound on standard deviation of expval estimator. + +**Parameters** + +**shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of shots used for expectation value measurement. + +**Returns** + +the standard deviation upper bound. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.result.Counts.md b/docs/api/qiskit/0.46/qiskit.result.Counts.md new file mode 100644 index 00000000000..2463622a5b4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.Counts.md @@ -0,0 +1,204 @@ +--- +title: Counts +description: API reference for qiskit.result.Counts +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.result.Counts +--- + +# Counts + + + +`qiskit.result.Counts(data, time_taken=None, creg_sizes=None, memory_slots=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/counts.py "view source code") + +Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +A class to store a counts result from a circuit execution. + +Build a counts object + +**Parameters** + +* **data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + + The dictionary input for the counts. Where the keys represent a measured classical value and the value is an integer the number of shots with that result. The keys can be one of several formats: + + > * A hexadecimal string of the form `'0x4a'` + > * A bit string prefixed with `0b` for example `'0b1011'` + > * A bit string formatted across register and memory slots. For example, `'00 10'`. + > * A dit string, for example `'02'`. Note for objects created with dit strings the `creg_sizes` and `memory_slots` kwargs don’t work and [`hex_outcomes()`](#qiskit.result.Counts.hex_outcomes "qiskit.result.Counts.hex_outcomes") and [`int_outcomes()`](#qiskit.result.Counts.int_outcomes "qiskit.result.Counts.int_outcomes") also do not work. + +* **time\_taken** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The duration of the experiment that generated the counts in seconds. + +* **creg\_sizes** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a nested list where the inner element is a list of tuples containing both the classical register name and classical register size. For example, `[('c_reg', 2), ('my_creg', 4)]`. + +* **memory\_slots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of total `memory_slots` in the experiment. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the input key type is not an `int` or `str`. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a dit string key is input with `creg_sizes` and/or `memory_slots`. + +## Attributes + + + +### bitstring\_regex + +`= re.compile('^[01\\s]+$')` + +## Methods + +### clear + + + +`clear() → None.  Remove all items from D.` + +### copy + + + +`copy() → a shallow copy of D` + +### fromkeys + + + +`fromkeys(value=None, /)` + +Create a new dictionary with keys from iterable and values set to value. + +### get + + + +`get(key, default=None, /)` + +Return the value for key if key is in the dictionary, else default. + +### hex\_outcomes + + + +`hex_outcomes()` + +Return a counts dictionary with hexadecimal string keys + +**Returns** + +**A dictionary with the keys as hexadecimal strings instead of** + +bitstrings + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the Counts object contains counts for dit strings + +### int\_outcomes + + + +`int_outcomes()` + +Build a counts dictionary with integer keys instead of count strings + +**Returns** + +A dictionary with the keys as integers instead of bitstrings + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the Counts object contains counts for dit strings + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### most\_frequent + + + +`most_frequent()` + +Return the most frequent count + +**Returns** + +The bit string for the most frequent result + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – when there is >1 count with the same max counts, or an empty object. + +### pop + + + +`pop(k[, d]) → v, remove specified key and return the corresponding value.` + +If key is not found, default is returned if given, otherwise KeyError is raised + +### popitem + + + +`popitem()` + +Remove and return a (key, value) pair as a 2-tuple. + +Pairs are returned in LIFO (last-in, first-out) order. Raises KeyError if the dict is empty. + +### setdefault + + + +`setdefault(key, default=None, /)` + +Insert key with a value of default if key is not in the dictionary. + +Return the value for key if key is in the dictionary, else default. + +### shots + + + +`shots()` + +Return the number of shots + +### update + + + +`update([E, ]**F) → None.  Update D from dict/iterable E and F.` + +If E is present and has a .keys() method, then does: for k in E: D\[k] = E\[k] If E is present and lacks a .keys() method, then does: for k, v in E: D\[k] = v In either case, this is followed by: for k in F: D\[k] = F\[k] + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.result.LocalReadoutMitigator.md b/docs/api/qiskit/0.46/qiskit.result.LocalReadoutMitigator.md new file mode 100644 index 00000000000..8889015fe0e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.LocalReadoutMitigator.md @@ -0,0 +1,172 @@ +--- +title: LocalReadoutMitigator +description: API reference for qiskit.result.LocalReadoutMitigator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.result.LocalReadoutMitigator +--- + +# LocalReadoutMitigator + + + +`qiskit.result.LocalReadoutMitigator(assignment_matrices=None, qubits=None, backend=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/mitigation/local_readout_mitigator.py "view source code") + +Bases: [`BaseReadoutMitigator`](qiskit.result.BaseReadoutMitigator "qiskit.result.mitigation.base_readout_mitigator.BaseReadoutMitigator") + +1-qubit tensor product readout error mitigator. + +Mitigates [`expectation_value()`](#qiskit.result.LocalReadoutMitigator.expectation_value "qiskit.result.LocalReadoutMitigator.expectation_value") and [`quasi_probabilities()`](#qiskit.result.LocalReadoutMitigator.quasi_probabilities "qiskit.result.LocalReadoutMitigator.quasi_probabilities"). The mitigator should either be calibrated using qiskit experiments, or calculated directly from the backend properties. This mitigation method should be used in case the readout errors of the qubits are assumed to be uncorrelated. For *N* qubits there are *N* mitigation matrices, each of size $2 x 2$ and the mitigation complexity is $O(2^N)$, so it is more efficient than the [`CorrelatedReadoutMitigator`](qiskit.result.CorrelatedReadoutMitigator "qiskit.result.CorrelatedReadoutMitigator") class. + +Initialize a LocalReadoutMitigator + +**Parameters** + +* **assignment\_matrices** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")*] | None*) – Optional, list of single-qubit readout error assignment matrices. +* **qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, the measured physical qubits for mitigation. +* **backend** – Optional, backend name. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – matrices sizes do not agree with number of qubits + +## Attributes + + + +### qubits + +The device qubits for this mitigator + + + +### settings + +Return settings. + +## Methods + +### assignment\_matrix + + + +`assignment_matrix(qubits=None)` + +Return the measurement assignment matrix for specified qubits. + +The assignment matrix is the stochastic matrix $A$ which assigns a noisy measurement probability distribution to an ideal input measurement distribution: $P(i|j) = \langle i | A | j \rangle$. + +**Parameters** + +**qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, qubits being measured for operator expval. + +**Returns** + +the assignment matrix A. + +**Return type** + +np.ndarray + +### expectation\_value + + + +`expectation_value(data, diagonal=None, qubits=None, clbits=None, shots=None)` + +Compute the mitigated expectation value of a diagonal observable. + +This computes the mitigated estimator of $\langle O \rangle = \mbox{Tr}[\rho. O]$ of a diagonal observable $O = \sum_{x\in\{0, 1\}^n} O(x)|x\rangle\!\langle x|$. + +**Parameters** + +* **data** ([*Counts*](qiskit.result.Counts "qiskit.result.counts.Counts")) – Counts object +* **diagonal** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") *| None*) – Optional, the vector of diagonal values for summing the expectation value. If `None` the default value is $[1, -1]^\otimes n$. +* **qubits** ([*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, the measured physical qubits the count bitstrings correspond to. If None qubits are assumed to be $[0, ..., n-1]$. +* **clbits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, if not None marginalize counts to the specified bits. +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – the number of shots. + +**Returns** + +the expectation value and an upper bound of the standard deviation. + +**Return type** + +([float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) + +**Additional Information:** + +The diagonal observable $O$ is input using the `diagonal` kwarg as a list or Numpy array $[O(0), ..., O(2^n -1)]$. If no diagonal is specified the diagonal of the Pauli operator :math\`O = mbox\{diag}(Z^\{otimes n}) = \[1, -1]^\{otimes n}\` is used. The `clbits` kwarg is used to marginalize the input counts dictionary over the specified bit-values, and the `qubits` kwarg is used to specify which physical qubits these bit-values correspond to as `circuit.measure(qubits, clbits)`. + +### mitigation\_matrix + + + +`mitigation_matrix(qubits=None)` + +Return the measurement mitigation matrix for the specified qubits. + +The mitigation matrix $A^{-1}$ is defined as the inverse of the [`assignment_matrix()`](#qiskit.result.LocalReadoutMitigator.assignment_matrix "qiskit.result.LocalReadoutMitigator.assignment_matrix") $A$. + +**Parameters** + +**qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] |* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional, qubits being measured for operator expval. if a single int is given, it is assumed to be the index of the qubit in self.\_qubits + +**Returns** + +the measurement error mitigation matrix $A^{-1}$. + +**Return type** + +np.ndarray + +### quasi\_probabilities + + + +`quasi_probabilities(data, qubits=None, clbits=None, shots=None)` + +Compute mitigated quasi probabilities value. + +**Parameters** + +* **data** ([*Counts*](qiskit.result.Counts "qiskit.result.counts.Counts")) – counts object +* **qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – qubits the count bitstrings correspond to. +* **clbits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Optional, marginalize counts to just these bits. +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional, the total number of shots, if None shots will be calculated as the sum of all counts. + +**Returns** + +**A dictionary containing pairs of \[output, mean] where “output”** + +is the key in the dictionaries, which is the length-N bitstring of a measured standard basis state, and “mean” is the mean of non-zero quasi-probability estimates. + +**Return type** + +[QuasiDistribution](qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if qubit and clbit kwargs are not valid. + +### stddev\_upper\_bound + + + +`stddev_upper_bound(shots, qubits=None)` + +Return an upper bound on standard deviation of expval estimator. + +**Parameters** + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of shots used for expectation value measurement. +* **qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – qubits being measured for operator expval. + +**Returns** + +the standard deviation upper bound. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.result.ProbDistribution.md b/docs/api/qiskit/0.46/qiskit.result.ProbDistribution.md new file mode 100644 index 00000000000..6147752712f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.ProbDistribution.md @@ -0,0 +1,161 @@ +--- +title: ProbDistribution +description: API reference for qiskit.result.ProbDistribution +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.result.ProbDistribution +--- + +# ProbDistribution + + + +`qiskit.result.ProbDistribution(data, shots=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/distributions/probability.py "view source code") + +Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +A generic dict-like class for probability distributions. + +Builds a probability distribution object. + +**Parameters** + +* **data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + + Input probability data. Where the keys represent a measured classical value and the value is a float for the probability of that result. The keys can be one of several formats: + + > * A hexadecimal string of the form `"0x4a"` + > * A bit string e.g. `'0b1011'` or `"01011"` + > * An integer + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of shots the distribution was derived from. + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the input keys are not a string or int +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the string format of the keys is incorrect + +## Methods + +### binary\_probabilities + + + +`binary_probabilities(num_bits=None)` + +Build a probabilities dictionary with binary string keys + +**Parameters** + +**num\_bits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of bits in the binary bitstrings (leading zeros will be padded). If None, a default value will be used. If keys are given as integers or strings with binary or hex prefix, the default value will be derived from the largest key present. If keys are given as bitstrings without prefix, the default value will be derived from the largest key length. + +**Returns** + +**A dictionary where the keys are binary strings in the format** + +`"0110"` + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### clear + + + +`clear() → None.  Remove all items from D.` + +### copy + + + +`copy() → a shallow copy of D` + +### fromkeys + + + +`fromkeys(value=None, /)` + +Create a new dictionary with keys from iterable and values set to value. + +### get + + + +`get(key, default=None, /)` + +Return the value for key if key is in the dictionary, else default. + +### hex\_probabilities + + + +`hex_probabilities()` + +Build a probabilities dictionary with hexadecimal string keys + +**Returns** + +**A dictionary where the keys are hexadecimal strings in the** + +format `"0x1a"` + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### pop + + + +`pop(k[, d]) → v, remove specified key and return the corresponding value.` + +If key is not found, default is returned if given, otherwise KeyError is raised + +### popitem + + + +`popitem()` + +Remove and return a (key, value) pair as a 2-tuple. + +Pairs are returned in LIFO (last-in, first-out) order. Raises KeyError if the dict is empty. + +### setdefault + + + +`setdefault(key, default=None, /)` + +Insert key with a value of default if key is not in the dictionary. + +Return the value for key if key is in the dictionary, else default. + +### update + + + +`update([E, ]**F) → None.  Update D from dict/iterable E and F.` + +If E is present and has a .keys() method, then does: for k in E: D\[k] = E\[k] If E is present and lacks a .keys() method, then does: for k, v in E: D\[k] = v In either case, this is followed by: for k in F: D\[k] = F\[k] + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.result.QuasiDistribution.md b/docs/api/qiskit/0.46/qiskit.result.QuasiDistribution.md new file mode 100644 index 00000000000..8dfd0625c64 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.QuasiDistribution.md @@ -0,0 +1,199 @@ +--- +title: QuasiDistribution +description: API reference for qiskit.result.QuasiDistribution +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.result.QuasiDistribution +--- + +# QuasiDistribution + + + +`qiskit.result.QuasiDistribution(data, shots=None, stddev_upper_bound=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/distributions/quasi.py "view source code") + +Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +A dict-like class for representing quasi-probabilities. + +Builds a quasiprobability distribution object. + + + The quasiprobability values might include floating-point errors. `QuasiDistribution.__repr__` rounds using `numpy.round()` and the parameter `ndigits` can be manipulated with the class attribute `__ndigits__`. The default is `15`. + + +**Parameters** + +* **data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + + Input quasiprobability data. Where the keys represent a measured classical value and the value is a float for the quasiprobability of that result. The keys can be one of several formats: + + > * A hexadecimal string of the form `"0x4a"` + > * A bit string e.g. `'0b1011'` or `"01011"` + > * An integer + +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of shots the distribution was derived from. + +* **stddev\_upper\_bound** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – An upper bound for the standard deviation + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If the input keys are not a string or int +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the string format of the keys is incorrect + +## Attributes + + + +### stddev\_upper\_bound + +Return an upper bound on standard deviation of expval estimator. + +## Methods + +### binary\_probabilities + + + +`binary_probabilities(num_bits=None)` + +Build a quasi-probabilities dictionary with binary string keys + +**Parameters** + +**num\_bits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of bits in the binary bitstrings (leading zeros will be padded). If None, a default value will be used. If keys are given as integers or strings with binary or hex prefix, the default value will be derived from the largest key present. If keys are given as bitstrings without prefix, the default value will be derived from the largest key length. + +**Returns** + +**A dictionary where the keys are binary strings in the format** + +`"0110"` + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### clear + + + +`clear() → None.  Remove all items from D.` + +### copy + + + +`copy() → a shallow copy of D` + +### fromkeys + + + +`fromkeys(value=None, /)` + +Create a new dictionary with keys from iterable and values set to value. + +### get + + + +`get(key, default=None, /)` + +Return the value for key if key is in the dictionary, else default. + +### hex\_probabilities + + + +`hex_probabilities()` + +Build a quasi-probabilities dictionary with hexadecimal string keys + +**Returns** + +**A dictionary where the keys are hexadecimal strings in the** + +format `"0x1a"` + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### nearest\_probability\_distribution + + + +`nearest_probability_distribution(return_distance=False)` + +Takes a quasiprobability distribution and maps it to the closest probability distribution as defined by the L2-norm. + +**Parameters** + +**return\_distance** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Return the L2 distance between distributions. + +**Returns** + +Nearest probability distribution. float: Euclidean (L2) distance of distributions. + +**Return type** + +[ProbDistribution](qiskit.result.ProbDistribution "qiskit.result.ProbDistribution") + +**Notes** + +Method from Smolin et al., Phys. Rev. Lett. 108, 070502 (2012). + +### pop + + + +`pop(k[, d]) → v, remove specified key and return the corresponding value.` + +If key is not found, default is returned if given, otherwise KeyError is raised + +### popitem + + + +`popitem()` + +Remove and return a (key, value) pair as a 2-tuple. + +Pairs are returned in LIFO (last-in, first-out) order. Raises KeyError if the dict is empty. + +### setdefault + + + +`setdefault(key, default=None, /)` + +Insert key with a value of default if key is not in the dictionary. + +Return the value for key if key is in the dictionary, else default. + +### update + + + +`update([E, ]**F) → None.  Update D from dict/iterable E and F.` + +If E is present and has a .keys() method, then does: for k in E: D\[k] = E\[k] If E is present and lacks a .keys() method, then does: for k, v in E: D\[k] = v In either case, this is followed by: for k in F: D\[k] = F\[k] + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.result.Result.md b/docs/api/qiskit/0.46/qiskit.result.Result.md new file mode 100644 index 00000000000..4f6ea159e19 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.Result.md @@ -0,0 +1,258 @@ +--- +title: Result +description: API reference for qiskit.result.Result +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.result.Result +--- + +# Result + + + +`qiskit.result.Result(backend_name, backend_version, qobj_id, job_id, success, results, date=None, status=None, header=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/result.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Model for Results. + + + +### backend\_name + +backend name. + +**Type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + +### backend\_version + +backend version, in the form X.Y.Z. + +**Type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + +### qobj\_id + +user-generated Qobj id. + +**Type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + +### job\_id + +unique execution id from the backend. + +**Type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + + + +### success + +True if complete input qobj executed correctly. (Implies each experiment success) + +**Type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + + + +### results + +corresponding results for array of experiments of the input qobj + +**Type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[ExperimentResult] + +## Methods + +### data + + + +`data(experiment=None)` + +Get the raw data for an experiment. + +Note this data will be a single classical and quantum register and in a format required by the results schema. We recommend that most users use the get\_xxx method, and the data will be post-processed for the data type. + +**Parameters** + +**experiment** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or None*) – the index of the experiment. Several types are accepted for convenience:: \* str: the name of the experiment. \* QuantumCircuit: the name of the circuit instance will be used. \* Schedule: the name of the schedule instance will be used. \* int: the position of the experiment. \* None: if there is only one experiment, returns it. + +**Returns** + +A dictionary of results data for an experiment. The data depends on the backend it ran on and the settings of meas\_level, meas\_return and memory. + +OpenQASM backends return a dictionary of dictionary with the key ‘counts’ and with the counts, with the second dictionary keys containing a string in hex format (`0x123`) and values equal to the number of times this outcome was measured. + +Statevector backends return a dictionary with key ‘statevector’ and values being a list\[list\[complex components]] list of 2^num\_qubits complex amplitudes. Where each complex number is represented as a 2 entry list for each component. For example, a list of \[0.5+1j, 0-1j] would be represented as \[\[0.5, 1], \[0, -1]]. + +Unitary backends return a dictionary with key ‘unitary’ and values being a list\[list\[list\[complex components]]] list of 2^num\_qubits x 2^num\_qubits complex amplitudes in a two entry list for each component. For example if the amplitude is \[\[0.5+0j, 0-1j], …] the value returned will be \[\[\[0.5, 0], \[0, -1]], …]. + +The simulator backends also have an optional key ‘snapshots’ which returns a dict of snapshots specified by the simulator backend. The value is of the form dict\[slot: dict\[str: array]] where the keys are the requested snapshot slots, and the values are a dictionary of the snapshots. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if data for the experiment could not be retrieved. + +### from\_dict + + + +`classmethod from_dict(data)` + +Create a new ExperimentResultData object from a dictionary. + +**Parameters** + +**data** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary representing the Result to create. It will be in the same format as output by [`to_dict()`](#qiskit.result.Result.to_dict "qiskit.result.Result.to_dict"). + +**Returns** + +The `Result` object from the input dictionary. + +**Return type** + +[Result](#qiskit.result.Result "qiskit.result.Result") + +### get\_counts + + + +`get_counts(experiment=None)` + +Get the histogram data of an experiment. + +**Parameters** + +**experiment** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or None*) – the index of the experiment, as specified by `data([experiment])`. + +**Returns** + +a dictionary or a list of dictionaries. A dictionary has the counts for each qubit with the keys containing a string in binary format and separated according to the registers in circuit (e.g. `0100 1110`). The string is little-endian (cr\[0] on the right hand side). + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] or [list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")]] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if there are no counts for the experiment. + +### get\_memory + + + +`get_memory(experiment=None)` + +Get the sequence of memory states (readouts) for each shot The data from the experiment is a list of format \[‘00000’, ‘01000’, ‘10100’, ‘10100’, ‘11101’, ‘11100’, ‘00101’, …, ‘01010’] + +**Parameters** + +**experiment** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or None*) – the index of the experiment, as specified by `data()`. + +**Returns** + +Either the list of each outcome, formatted according to registers in circuit or a complex numpy np.ndarray with shape: + +> | meas\_level | meas\_return | shape | +> | ----------- | ------------ | ----------------------------------------------------- | +> | 0 | single | np.ndarray\[shots, memory\_slots, memory\_slot\_size] | +> | 0 | avg | np.ndarray\[memory\_slots, memory\_slot\_size] | +> | 1 | single | np.ndarray\[shots, memory\_slots] | +> | 1 | avg | np.ndarray\[memory\_slots] | +> | 2 | memory=True | list | + +**Return type** + +List\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] or np.ndarray + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if there is no memory data for the circuit. + +### get\_statevector + + + +`get_statevector(experiment=None, decimals=None)` + +Get the final statevector of an experiment. + +**Parameters** + +* **experiment** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or None*) – the index of the experiment, as specified by `data()`. +* **decimals** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimals in the statevector. If None, does not round. + +**Returns** + +list of 2^num\_qubits complex amplitudes. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if there is no statevector for the experiment. + +### get\_unitary + + + +`get_unitary(experiment=None, decimals=None)` + +Get the final unitary of an experiment. + +**Parameters** + +* **experiment** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or None*) – the index of the experiment, as specified by `data()`. +* **decimals** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of decimals in the unitary. If None, does not round. + +**Returns** + +**list of 2^num\_qubits x 2^num\_qubits complex** + +amplitudes. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[complex](https://docs.python.org/3/library/functions.html#complex "(in Python v3.12)")]] + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if there is no unitary for the experiment. + +### to\_dict + + + +`to_dict()` + +Return a dictionary format representation of the Result + +**Returns** + +The dictionary form of the Result + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.result.ResultError.md b/docs/api/qiskit/0.46/qiskit.result.ResultError.md new file mode 100644 index 00000000000..0b85c4263fa --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.result.ResultError.md @@ -0,0 +1,34 @@ +--- +title: ResultError +description: API reference for qiskit.result.ResultError +in_page_toc_min_heading_level: 1 +python_api_type: exception +python_api_name: qiskit.result.ResultError +--- + + + +# qiskit.result.ResultError + + + +`qiskit.result.ResultError(error)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/exceptions.py "view source code") + +Exceptions raised due to errors in result output. + +It may be better for the Qiskit API to raise this exception. + +**Parameters** + +**error** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + +This is the error record as it comes back from the API. The format is like: + +```python +error = {'status': 403, + 'message': 'Your credits are not enough.', + 'code': 'MAX_CREDITS_EXCEEDED'} +``` + +Set the error message. + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.EvolutionSynthesis.md b/docs/api/qiskit/0.46/qiskit.synthesis.EvolutionSynthesis.md new file mode 100644 index 00000000000..38f188708e5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.EvolutionSynthesis.md @@ -0,0 +1,56 @@ +--- +title: EvolutionSynthesis +description: API reference for qiskit.synthesis.EvolutionSynthesis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.EvolutionSynthesis +--- + +# EvolutionSynthesis + + + +`qiskit.synthesis.EvolutionSynthesis`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/evolution/evolution_synthesis.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Interface for evolution synthesis algorithms. + +## Attributes + + + +### settings + +Return the settings in a dictionary, which can be used to reconstruct the object. + +**Returns** + +A dictionary containing the settings of this product formula. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – The interface does not implement this method. + +## Methods + +### synthesize + + + +`abstract synthesize(evolution)` + +Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. + +**Parameters** + +**evolution** ([*PauliEvolutionGate*](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate")) – The evolution gate to synthesize. + +**Returns** + +A circuit implementing the evolution. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.LieTrotter.md b/docs/api/qiskit/0.46/qiskit.synthesis.LieTrotter.md new file mode 100644 index 00000000000..c2a67d99289 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.LieTrotter.md @@ -0,0 +1,79 @@ +--- +title: LieTrotter +description: API reference for qiskit.synthesis.LieTrotter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.LieTrotter +--- + +# LieTrotter + + + +`qiskit.synthesis.LieTrotter(reps=1, insert_barriers=False, cx_structure='chain', atomic_evolution=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/evolution/lie_trotter.py "view source code") + +Bases: [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.evolution.product_formula.ProductFormula") + +The Lie-Trotter product formula. + +The Lie-Trotter formula approximates the exponential of two non-commuting operators with products of their exponentials up to a second order error: + +$$ +e^{A + B} \approx e^{A}e^{B}. +$$ + +In this implementation, the operators are provided as sum terms of a Pauli operator. For example, we approximate + +$$ +e^{-it(XX + ZZ)} = e^{-it XX}e^{-it ZZ} + \mathcal{O}(t^2). +$$ + +**References** + +\[1]: D. Berry, G. Ahokas, R. Cleve and B. Sanders, “Efficient quantum algorithms for simulating sparse Hamiltonians” (2006). [arXiv:quant-ph/0508139](https://arxiv.org/abs/quant-ph/0508139) \[2]: N. Hatano and M. Suzuki, “Finding Exponential Product Formulas of Higher Orders” (2005). [arXiv:math-ph/0506007](https://arxiv.org/pdf/math-ph/0506007.pdf) + +**Parameters** + +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of time steps. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to insert barriers between the atomic evolutions. +* **cx\_structure** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – How to arrange the CX gates for the Pauli evolutions, can be “chain”, where next neighbor connections are used, or “fountain”, where all qubits are connected to one. +* **atomic\_evolution** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*] | None*) – A function to construct the circuit for the evolution of single Pauli string. Per default, a single Pauli evolution is decomposed in a CX chain and a single qubit Z rotation. + +## Attributes + + + +### settings + +Return the settings in a dictionary, which can be used to reconstruct the object. + +**Returns** + +A dictionary containing the settings of this product formula. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If a custom atomic evolution is set, which cannot be serialized. + +## Methods + +### synthesize + + + +`synthesize(evolution)` + +Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. + +**Parameters** + +**evolution** ([*PauliEvolutionGate*](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate")) – The evolution gate to synthesize. + +**Returns** + +A circuit implementing the evolution. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.MatrixExponential.md b/docs/api/qiskit/0.46/qiskit.synthesis.MatrixExponential.md new file mode 100644 index 00000000000..176cc0dc69c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.MatrixExponential.md @@ -0,0 +1,58 @@ +--- +title: MatrixExponential +description: API reference for qiskit.synthesis.MatrixExponential +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.MatrixExponential +--- + +# MatrixExponential + + + +`qiskit.synthesis.MatrixExponential`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/evolution/matrix_synthesis.py "view source code") + +Bases: [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.evolution.evolution_synthesis.EvolutionSynthesis") + +Exact operator evolution via matrix exponentiation and unitary synthesis. + +This class synthesis the exponential of operators by calculating their exponentially-sized matrix representation and using exact matrix exponentiation followed by unitary synthesis to obtain a circuit. This process is not scalable and serves as comparison or benchmark for small systems. + +## Attributes + + + +### settings + +Return the settings in a dictionary, which can be used to reconstruct the object. + +**Returns** + +A dictionary containing the settings of this product formula. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – The interface does not implement this method. + +## Methods + +### synthesize + + + +`synthesize(evolution)` + +Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. + +**Parameters** + +**evolution** ([*PauliEvolutionGate*](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate")) – The evolution gate to synthesize. + +**Returns** + +A circuit implementing the evolution. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.OneQubitEulerDecomposer.md b/docs/api/qiskit/0.46/qiskit.synthesis.OneQubitEulerDecomposer.md new file mode 100644 index 00000000000..60fcee0838a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.OneQubitEulerDecomposer.md @@ -0,0 +1,106 @@ +--- +title: OneQubitEulerDecomposer +description: API reference for qiskit.synthesis.OneQubitEulerDecomposer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.OneQubitEulerDecomposer +--- + +# OneQubitEulerDecomposer + + + +`qiskit.synthesis.OneQubitEulerDecomposer(basis='U3', use_dag=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/one_qubit/one_qubit_decompose.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A class for decomposing 1-qubit unitaries into Euler angle rotations. + +The resulting decomposition is parameterized by 3 Euler rotation angle parameters $(\theta, \phi, \lambda)$, and a phase parameter $\gamma$. The value of the parameters for an input unitary depends on the decomposition basis. Allowed bases and the resulting circuits are shown in the following table. Note that for the non-Euler bases (U3, U1X, RR), the ZYZ Euler parameters are used. + +| Basis | Euler Angle Basis | Decomposition Circuit | +| ------ | ------------------------------ | ------------------------------------------------------------------------------------------------------------------------ | +| ‘ZYZ’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} R_Z(\phi).R_Y(\theta).R_Z(\lambda)$ | +| ‘ZXZ’ | $Z(\phi) X(\theta) Z(\lambda)$ | $e^{i\gamma} R_Z(\phi).R_X(\theta).R_Z(\lambda)$ | +| ‘XYX’ | $X(\phi) Y(\theta) X(\lambda)$ | $e^{i\gamma} R_X(\phi).R_Y(\theta).R_X(\lambda)$ | +| ‘XZX’ | $X(\phi) Z(\theta) X(\lambda)$ | $e^{i\gamma} R_X(\phi).R_Z(\theta).R_X(\lambda)$ | +| ‘U3’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} U_3(\theta,\phi,\lambda)$ | +| ‘U321’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} U_3(\theta,\phi,\lambda)$ | +| ‘U’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} U_3(\theta,\phi,\lambda)$ | +| ‘PSX’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} U_1(\phi+\pi).R_X\left(\frac{\pi}{2}\right).$ $U_1(\theta+\pi).R_X\left(\frac{\pi}{2}\right).U_1(\lambda)$ | +| ‘ZSX’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} R_Z(\phi+\pi).\sqrt{X}.$ $R_Z(\theta+\pi).\sqrt{X}.R_Z(\lambda)$ | +| ‘ZSXX’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} R_Z(\phi+\pi).\sqrt{X}.R_Z(\theta+\pi).\sqrt{X}.R_Z(\lambda)$ or $e^{i\gamma} R_Z(\phi+\pi).X.R_Z(\lambda)$ | +| ‘U1X’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} U_1(\phi+\pi).R_X\left(\frac{\pi}{2}\right).$ $U_1(\theta+\pi).R_X\left(\frac{\pi}{2}\right).U_1(\lambda)$ | +| ‘RR’ | $Z(\phi) Y(\theta) Z(\lambda)$ | $e^{i\gamma} R\left(-\pi,\frac{\phi-\lambda+\pi}{2}\right).$ $R\left(\theta+\pi,\frac{\pi}{2}-\lambda\right)$ | + +Initialize decomposer + +Supported bases are: ‘U’, ‘PSX’, ‘ZSXX’, ‘ZSX’, ‘U321’, ‘U3’, ‘U1X’, ‘RR’, ‘ZYZ’, ‘ZXZ’, ‘XYX’, ‘XZX’. + +**Parameters** + +* **basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the decomposition basis \[Default: ‘U3’] +* **use\_dag** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If true the output from calls to the decomposer will be a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object instead of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If input basis is not recognized. + +## Attributes + + + +### basis + +The decomposition basis. + +## Methods + +### angles + + + +`angles(unitary)` + +Return the Euler angles for input array. + +**Parameters** + +**unitary** (*np.ndarray*) – 2x2 unitary matrix. + +**Returns** + +(theta, phi, lambda). + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + +### angles\_and\_phase + + + +`angles_and_phase(unitary)` + +Return the Euler angles and phase for input array. + +**Parameters** + +**unitary** (*np.ndarray*) – 2x2 unitary matrix. + +**Returns** + +(theta, phi, lambda, phase). + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") + +### build\_circuit + + + +`build_circuit(gates, global_phase)` + +Return the circuit or dag object from a list of gates. + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.ProductFormula.md b/docs/api/qiskit/0.46/qiskit.synthesis.ProductFormula.md new file mode 100644 index 00000000000..6f394b17856 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.ProductFormula.md @@ -0,0 +1,66 @@ +--- +title: ProductFormula +description: API reference for qiskit.synthesis.ProductFormula +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.ProductFormula +--- + +# ProductFormula + + + +`qiskit.synthesis.ProductFormula(order, reps=1, insert_barriers=False, cx_structure='chain', atomic_evolution=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/evolution/product_formula.py "view source code") + +Bases: [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.evolution.evolution_synthesis.EvolutionSynthesis") + +Product formula base class for the decomposition of non-commuting operator exponentials. + +[`LieTrotter`](qiskit.synthesis.LieTrotter "qiskit.synthesis.LieTrotter") and [`SuzukiTrotter`](qiskit.synthesis.SuzukiTrotter "qiskit.synthesis.SuzukiTrotter") inherit from this class. + +**Parameters** + +* **order** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The order of the product formula. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of time steps. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to insert barriers between the atomic evolutions. +* **cx\_structure** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – How to arrange the CX gates for the Pauli evolutions, can be “chain”, where next neighbor connections are used, or “fountain”, where all qubits are connected to one. +* **atomic\_evolution** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*] | None*) – A function to construct the circuit for the evolution of single Pauli string. Per default, a single Pauli evolution is decomposed in a CX chain and a single qubit Z rotation. + +## Attributes + + + +### settings + +Return the settings in a dictionary, which can be used to reconstruct the object. + +**Returns** + +A dictionary containing the settings of this product formula. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If a custom atomic evolution is set, which cannot be serialized. + +## Methods + +### synthesize + + + +`abstract synthesize(evolution)` + +Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. + +**Parameters** + +**evolution** ([*PauliEvolutionGate*](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate")) – The evolution gate to synthesize. + +**Returns** + +A circuit implementing the evolution. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.QDrift.md b/docs/api/qiskit/0.46/qiskit.synthesis.QDrift.md new file mode 100644 index 00000000000..4d721a710ec --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.QDrift.md @@ -0,0 +1,68 @@ +--- +title: QDrift +description: API reference for qiskit.synthesis.QDrift +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.QDrift +--- + +# QDrift + + + +`qiskit.synthesis.QDrift(reps=1, insert_barriers=False, cx_structure='chain', atomic_evolution=None, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/evolution/qdrift.py "view source code") + +Bases: [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.evolution.product_formula.ProductFormula") + +The QDrift Trotterization method, which selects each each term in the Trotterization randomly, with a probability proportional to its weight. Based on the work of Earl Campbell in Ref. \[1]. + +**References** + +\[1]: E. Campbell, “A random compiler for fast Hamiltonian simulation” (2018). [arXiv:quant-ph/1811.08017](https://arxiv.org/abs/1811.08017) + +**Parameters** + +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of times to repeat the Trotterization circuit. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to insert barriers between the atomic evolutions. +* **cx\_structure** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – How to arrange the CX gates for the Pauli evolutions, can be “chain”, where next neighbor connections are used, or “fountain”, where all qubits are connected to one. +* **atomic\_evolution** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*] | None*) – A function to construct the circuit for the evolution of single Pauli string. Per default, a single Pauli evolution is decomposed in a CX chain and a single qubit Z rotation. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – An optional seed for reproducibility of the random sampling process. + +## Attributes + + + +### settings + +Return the settings in a dictionary, which can be used to reconstruct the object. + +**Returns** + +A dictionary containing the settings of this product formula. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If a custom atomic evolution is set, which cannot be serialized. + +## Methods + +### synthesize + + + +`synthesize(evolution)` + +Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. + +**Parameters** + +**evolution** ([*PauliEvolutionGate*](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate")) – The evolution gate to synthesize. + +**Returns** + +A circuit implementing the evolution. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.SolovayKitaevDecomposition.md b/docs/api/qiskit/0.46/qiskit.synthesis.SolovayKitaevDecomposition.md new file mode 100644 index 00000000000..1fd4a0c057e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.SolovayKitaevDecomposition.md @@ -0,0 +1,93 @@ +--- +title: SolovayKitaevDecomposition +description: API reference for qiskit.synthesis.SolovayKitaevDecomposition +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.SolovayKitaevDecomposition +--- + +# SolovayKitaevDecomposition + + + +`qiskit.synthesis.SolovayKitaevDecomposition(basic_approximations=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/discrete_basis/solovay_kitaev.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +The Solovay Kitaev discrete decomposition algorithm. + +This class is called recursively by the transpiler pass, which is why it is separeted. See [`qiskit.transpiler.passes.SolovayKitaev`](qiskit.transpiler.passes.SolovayKitaev "qiskit.transpiler.passes.SolovayKitaev") for more information. + +**Parameters** + +**basic\_approximations** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, np.ndarray] |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[GateSequence] | None*) – A specification of the basic SU(2) approximations in terms of discrete gates. At each iteration this algorithm, the remaining error is approximated with the closest sequence of gates in this set. If a `str`, this specifies a `.npy` filename from which to load the approximation. If a `dict`, then this contains `{gates: effective_SO3_matrix}` pairs, e.g. `{"h t": np.array([[0, 0.7071, -0.7071], [0, -0.7071, -0.7071], [-1, 0, 0]]}`. If a list, this contains the same information as the dict, but already converted to `GateSequence` objects, which contain the SO(3) matrix and gates. + +## Methods + +### find\_basic\_approximation + + + +`find_basic_approximation(sequence)` + +Finds gate in `self._basic_approximations` that best represents `sequence`. + +**Parameters** + +**sequence** (*GateSequence*) – The gate to find the approximation to. + +**Returns** + +Gate in basic approximations that is closest to `sequence`. + +**Return type** + +[*Gate*](qiskit.circuit.Gate "qiskit.circuit.gate.Gate") + +### load\_basic\_approximations + + + +`load_basic_approximations(data)` + +Load basic approximations. + +**Parameters** + +**data** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *|*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – If a string, specifies the path to the file from where to load the data. If a dictionary, directly specifies the decompositions as `{gates: matrix}`. There `gates` are the names of the gates producing the SO(3) matrix `matrix`, e.g. `{"h t": np.array([[0, 0.7071, -0.7071], [0, -0.7071, -0.7071], [-1, 0, 0]]}`. + +**Returns** + +A list of basic approximations as type `GateSequence`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the number of gate combinations and associated matrices does not match. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[GateSequence] + +### run + + + +`run(gate_matrix, recursion_degree, return_dag=False, check_input=True)` + +Run the algorithm. + +**Parameters** + +* **gate\_matrix** (*np.ndarray*) – The 2x2 matrix representing the gate. This matrix has to be SU(2) up to global phase. +* **recursion\_degree** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The recursion degree, called $n$ in the paper. +* **return\_dag** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` return a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit"), else a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"). +* **check\_input** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` check that the input matrix is valid for the decomposition. + +**Returns** + +A one-qubit circuit approximating the `gate_matrix` in the specified discrete basis. + +**Return type** + +QuantumCircuit’ | ‘DAGCircuit + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.SuzukiTrotter.md b/docs/api/qiskit/0.46/qiskit.synthesis.SuzukiTrotter.md new file mode 100644 index 00000000000..46fc16e05ae --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.SuzukiTrotter.md @@ -0,0 +1,86 @@ +--- +title: SuzukiTrotter +description: API reference for qiskit.synthesis.SuzukiTrotter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.SuzukiTrotter +--- + +# SuzukiTrotter + + + +`qiskit.synthesis.SuzukiTrotter(order=2, reps=1, insert_barriers=False, cx_structure='chain', atomic_evolution=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/evolution/suzuki_trotter.py "view source code") + +Bases: [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.evolution.product_formula.ProductFormula") + +The (higher order) Suzuki-Trotter product formula. + +The Suzuki-Trotter formulas improve the error of the Lie-Trotter approximation. For example, the second order decomposition is + +$$ +e^{A + B} \approx e^{B/2} e^{A} e^{B/2}. +$$ + +Higher order decompositions are based on recursions, see Ref. \[1] for more details. + +In this implementation, the operators are provided as sum terms of a Pauli operator. For example, in the second order Suzuki-Trotter decomposition we approximate + +$$ +e^{-it(XX + ZZ)} = e^{-it/2 ZZ}e^{-it XX}e^{-it/2 ZZ} + \mathcal{O}(t^3). +$$ + +**References** + +\[1]: D. Berry, G. Ahokas, R. Cleve and B. Sanders, “Efficient quantum algorithms for simulating sparse Hamiltonians” (2006). [arXiv:quant-ph/0508139](https://arxiv.org/abs/quant-ph/0508139) \[2]: N. Hatano and M. Suzuki, “Finding Exponential Product Formulas of Higher Orders” (2005). [arXiv:math-ph/0506007](https://arxiv.org/pdf/math-ph/0506007.pdf) + +**Parameters** + +* **order** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The order of the product formula. +* **reps** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of time steps. +* **insert\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to insert barriers between the atomic evolutions. +* **cx\_structure** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – How to arrange the CX gates for the Pauli evolutions, can be “chain”, where next neighbor connections are used, or “fountain”, where all qubits are connected to one. +* **atomic\_evolution** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)")*\[\[*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.operators.symplectic.pauli.Pauli") *|*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.operators.symplectic.sparse_pauli_op.SparsePauliOp")*,* [*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")*] | None*) – A function to construct the circuit for the evolution of single Pauli string. Per default, a single Pauli evolution is decomposed in a CX chain and a single qubit Z rotation. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If order is not even + +## Attributes + + + +### settings + +Return the settings in a dictionary, which can be used to reconstruct the object. + +**Returns** + +A dictionary containing the settings of this product formula. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – If a custom atomic evolution is set, which cannot be serialized. + +## Methods + +### synthesize + + + +`synthesize(evolution)` + +Synthesize an `qiskit.circuit.library.PauliEvolutionGate`. + +**Parameters** + +**evolution** ([*PauliEvolutionGate*](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate")) – The evolution gate to synthesize. + +**Returns** + +A circuit implementing the evolution. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.TwoQubitBasisDecomposer.md b/docs/api/qiskit/0.46/qiskit.synthesis.TwoQubitBasisDecomposer.md new file mode 100644 index 00000000000..d1ee81b4345 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.TwoQubitBasisDecomposer.md @@ -0,0 +1,89 @@ +--- +title: TwoQubitBasisDecomposer +description: API reference for qiskit.synthesis.TwoQubitBasisDecomposer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.TwoQubitBasisDecomposer +--- + +# TwoQubitBasisDecomposer + + + +`qiskit.synthesis.TwoQubitBasisDecomposer(gate, basis_fidelity=1.0, euler_basis='U', pulse_optimize=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/two_qubit/two_qubit_decompose.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A class for decomposing 2-qubit unitaries into minimal number of uses of a 2-qubit basis gate. + +**Parameters** + +* **gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")) – Two-qubit gate to be used in the KAK decomposition. +* **basis\_fidelity** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Fidelity to be assumed for applications of KAK Gate. Default 1.0. +* **euler\_basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Basis string to be provided to OneQubitEulerDecomposer for 1Q synthesis. Valid options are \[‘ZYZ’, ‘ZXZ’, ‘XYX’, ‘U’, ‘U3’, ‘U1X’, ‘PSX’, ‘ZSX’, ‘RR’]. +* **pulse\_optimize** (*None or* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, try to do decomposition which minimizes local unitaries in between entangling gates. This will raise an exception if an optimal decomposition is not implemented. Currently, only \[\{CX, SX, RZ}] is known. If False, don’t attempt optimization. If None, attempt optimization but don’t raise if unknown. + +## Methods + +### decomp0 + + + +`static decomp0(target)` + +Decompose target \~Ud(x, y, z) with 0 uses of the basis gate. Result Ur has trace: $|Tr(Ur.Utarget^dag)| = 4|(cos(x)cos(y)cos(z)+ j sin(x)sin(y)sin(z)|$, which is optimal for all targets and bases + +### decomp1 + + + +`decomp1(target)` + +Decompose target \~Ud(x, y, z) with 1 uses of the basis gate \~Ud(a, b, c). Result Ur has trace: .. math: + +```python +|Tr(Ur.Utarget^dag)| = 4|cos(x-a)cos(y-b)cos(z-c) + j sin(x-a)sin(y-b)sin(z-c)| +``` + +which is optimal for all targets and bases with z==0 or c==0 + +### decomp2\_supercontrolled + + + +`decomp2_supercontrolled(target)` + +Decompose target \~Ud(x, y, z) with 2 uses of the basis gate. + +For supercontrolled basis \~Ud(pi/4, b, 0), all b, result Ur has trace .. math: + +```python +|Tr(Ur.Utarget^dag)| = 4cos(z) +``` + +which is the optimal approximation for basis of CNOT-class `~Ud(pi/4, 0, 0)` or DCNOT-class `~Ud(pi/4, pi/4, 0)` and any target. May be sub-optimal for b!=0 (e.g. there exists exact decomposition for any target using B `B~Ud(pi/4, pi/8, 0)`, but not this decomposition.) This is an exact decomposition for supercontrolled basis and target `~Ud(x, y, 0)`. No guarantees for non-supercontrolled basis. + +### decomp3\_supercontrolled + + + +`decomp3_supercontrolled(target)` + +Decompose target with 3 uses of the basis. This is an exact decomposition for supercontrolled basis \~Ud(pi/4, b, 0), all b, and any target. No guarantees for non-supercontrolled basis. + +### num\_basis\_gates + + + +`num_basis_gates(unitary)` + +Computes the number of basis gates needed in a decomposition of input unitary + +### traces + + + +`traces(target)` + +Give the expected traces $|Tr(U \cdot Utarget^dag)|$ for different number of basis gates. + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.XXDecomposer.md b/docs/api/qiskit/0.46/qiskit.synthesis.XXDecomposer.md new file mode 100644 index 00000000000..1e5bfa6e0f8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.XXDecomposer.md @@ -0,0 +1,41 @@ +--- +title: XXDecomposer +description: API reference for qiskit.synthesis.XXDecomposer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.XXDecomposer +--- + +# XXDecomposer + + + +`qiskit.synthesis.XXDecomposer(basis_fidelity=1.0, euler_basis='U', embodiments=None, backup_optimizer=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/two_qubit/xx_decompose/decomposer.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A class for optimal decomposition of 2-qubit unitaries into 2-qubit basis gates of XX type (i.e., each locally equivalent to CAN(alpha, 0, 0) for a possibly varying alpha). + +**Parameters** + +* **basis\_fidelity** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – available strengths and fidelity of each. Can be either (1) a dictionary mapping XX angle values to fidelity at that angle; or (2) a single float f, interpreted as \{pi: f, pi/2: f/2, pi/3: f/3}. +* **euler\_basis** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Basis string provided to OneQubitEulerDecomposer for 1Q synthesis. Defaults to “U”. +* **embodiments** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*,* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – A dictionary mapping interaction strengths alpha to native circuits which embody the gate CAN(alpha, 0, 0). Strengths are taken so that pi/2 represents the class of a full CX. +* **backup\_optimizer** (*Callable\[...,* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – If supplied, defers synthesis to this callable when XXDecomposer has no efficient decomposition of its own. Useful for special cases involving 2 or 3 applications of XX(pi/2), in which case standard synthesis methods provide lower 1Q gate count. + + + If `embodiments` is not passed, or if an entry is missing, it will be populated as needed using the method `_default_embodiment`. + + +## Methods + +### num\_basis\_gates + + + +`num_basis_gates(unitary)` + +Counts the number of gates that would be emitted during re-synthesis. + +NOTE: Used by ConsolidateBlocks. + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.AQC.md b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.AQC.md new file mode 100644 index 00000000000..bb201f84f14 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.AQC.md @@ -0,0 +1,49 @@ +--- +title: AQC +description: API reference for qiskit.synthesis.unitary.aqc.AQC +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.unitary.aqc.AQC +--- + +# AQC + + + +`qiskit.synthesis.unitary.aqc.AQC(optimizer=None, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/aqc.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A generic implementation of the Approximate Quantum Compiler. This implementation is agnostic of the underlying implementation of the approximate circuit, objective, and optimizer. Users may pass corresponding implementations of the abstract classes: + +* The *optimizer* is an implementation of the [`Minimizer`](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") protocol, a callable used to run the optimization process. The choice of optimizer may affect overall convergence, required time for the optimization process and achieved objective value. +* The *approximate circuit* represents a template which parameters we want to optimize. Currently, there’s only one implementation based on 4-rotations CNOT unit blocks: [`CNOTUnitCircuit`](qiskit.synthesis.unitary.aqc.CNOTUnitCircuit "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit"). See the paper for more details. +* The *approximate objective* is tightly coupled with the approximate circuit implementation and provides two methods for computing objective function and gradient with respect to approximate circuit parameters. This objective is passed to the optimizer. Currently, there are two implementations based on 4-rotations CNOT unit blocks: [`DefaultCNOTUnitObjective`](qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective "qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective") and its accelerated version [`FastCNOTUnitObjective`](qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective "qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective"). Both implementations share the same idea of maximization the Hilbert-Schmidt product between the target matrix and its approximation. The former implementation approach should be considered as a baseline one. It may suffer from performance issues, and is mostly suitable for a small number of qubits (up to 5 or 6), whereas the latter, accelerated one, can be applied to larger problems. +* One should take into consideration the exponential growth of matrix size with the number of qubits because the implementation not only creates a potentially large target matrix, but also allocates a number of temporary memory buffers comparable in size to the target matrix. + + + Setting the optimizer argument to an instance of qiskit.algorithms.optimizers.Optimizer is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0 release. Please, submit a callable that follows the Minimizer protocol instead. + + +**Parameters** + +* **optimizer** ([*Minimizer*](qiskit.algorithms.optimizers.Minimizer "qiskit.algorithms.optimizers.Minimizer") *|*[*Optimizer*](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer") *| None*) – an optimizer to be used in the optimization procedure of the search for the best approximate circuit. By default, the scipy minimizer with the `L-BFGS-B` method is used with max iterations set to 1000. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – a seed value to be used by a random number generator. + +## Methods + +### compile\_unitary + + + +`compile_unitary(target_matrix, approximate_circuit, approximating_objective, initial_point=None)` + +Approximately compiles a circuit represented as a unitary matrix by solving an optimization problem defined by `approximating_objective` and using `approximate_circuit` as a template for the approximate circuit. + +**Parameters** + +* **target\_matrix** (*np.ndarray*) – a unitary matrix to approximate. +* **approximate\_circuit** ([*ApproximateCircuit*](qiskit.synthesis.unitary.aqc.ApproximateCircuit "qiskit.synthesis.unitary.aqc.ApproximateCircuit")) – a template circuit that will be filled with the parameter values obtained in the optimization procedure. +* **approximating\_objective** ([*ApproximatingObjective*](qiskit.synthesis.unitary.aqc.ApproximatingObjective "qiskit.synthesis.unitary.aqc.ApproximatingObjective")) – a definition of the optimization problem. +* **initial\_point** (*np.ndarray | None*) – initial values of angles/parameters to start optimization from. + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximateCircuit.md b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximateCircuit.md new file mode 100644 index 00000000000..926e2370bfe --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximateCircuit.md @@ -0,0 +1,240 @@ +--- +title: ApproximateCircuit +description: API reference for qiskit.synthesis.unitary.aqc.ApproximateCircuit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.unitary.aqc.ApproximateCircuit +--- + +# ApproximateCircuit + + + +`qiskit.synthesis.unitary.aqc.ApproximateCircuit(num_qubits, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/approximate.py "view source code") + +Bases: [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +A base class that represents an approximate circuit. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubit this circuit will span. +* **name** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – a name of the circuit. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### thetas + +The property is not implemented and raises a `NotImplementedException` exception. + +**Returns** + +a vector of parameters of this circuit. + +## Methods + +### build + + + +`abstract build(thetas)` + +**Constructs this circuit out of the parameters(thetas). Parameter values must be set before** + +constructing the circuit. + +**Parameters** + +**thetas** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a vector of parameters to be set in this circuit. + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximatingObjective.md b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximatingObjective.md new file mode 100644 index 00000000000..6fb56ec00a0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.ApproximatingObjective.md @@ -0,0 +1,74 @@ +--- +title: ApproximatingObjective +description: API reference for qiskit.synthesis.unitary.aqc.ApproximatingObjective +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.unitary.aqc.ApproximatingObjective +--- + +# ApproximatingObjective + + + +`qiskit.synthesis.unitary.aqc.ApproximatingObjective`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/approximate.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +A base class for an optimization problem definition. An implementing class must provide at least an implementation of the `objective` method. In such case only gradient free optimizers can be used. Both method, `objective` and `gradient`, preferable to have in an implementation. + +## Attributes + + + +### num\_thetas + +Returns: the number of parameters in this optimization problem. + + + +### target\_matrix + +Returns: a matrix being approximated + +## Methods + +### gradient + + + +`abstract gradient(param_values)` + +Computes a gradient with respect to parameters given a vector of parameter values. + +**Parameters** + +**param\_values** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a vector of parameter values for the optimization problem. + +**Returns** + +an array of gradient values. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### objective + + + +`abstract objective(param_values)` + +Computes a value of the objective function given a vector of parameter values. + +**Parameters** + +**param\_values** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a vector of parameter values for the optimization problem. + +**Returns** + +a float value of the objective function. + +**Return type** + +[*SupportsFloat*](https://docs.python.org/3/library/typing.html#typing.SupportsFloat "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.md b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.md new file mode 100644 index 00000000000..86133578291 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitCircuit.md @@ -0,0 +1,242 @@ +--- +title: CNOTUnitCircuit +description: API reference for qiskit.synthesis.unitary.aqc.CNOTUnitCircuit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitCircuit +--- + +# CNOTUnitCircuit + + + +`qiskit.synthesis.unitary.aqc.CNOTUnitCircuit(num_qubits, cnots, tol=0.0, name=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/cnot_unit_circuit.py "view source code") + +Bases: [`ApproximateCircuit`](qiskit.synthesis.unitary.aqc.ApproximateCircuit "qiskit.synthesis.unitary.aqc.approximate.ApproximateCircuit") + +A class that represents an approximate circuit based on CNOT unit blocks. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits in this circuit. +* **cnots** (*np.ndarray*) – an array of dimensions `(2, L)` indicating where the CNOT units will be placed. +* **tol** (*Optional\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – angle parameter less or equal this (small) value is considered equal zero and corresponding gate is not inserted into the output circuit (because it becomes identity one in this case). +* **name** (*Optional\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – name of this circuit + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if an unsupported parameter is passed. + +## Attributes + + + +### ancillas + +Returns a list of ancilla bits in the order that the registers were added. + + + +### calibrations + +Return calibration dictionary. + +The custom pulse definition of a given gate is of the form `{'gate_name': {(qubits, params): schedule}}` + + + +### clbits + +Returns a list of classical bits in the order that the registers were added. + + + +### data + +Return the circuit data (instructions and context). + +**Returns** + +a list-like object containing the [`CircuitInstruction`](qiskit.circuit.CircuitInstruction "qiskit.circuit.CircuitInstruction")s for each instruction. + +**Return type** + +QuantumCircuitData + + + +### extension\_lib + +`= 'include "qelib1.inc";'` + + + +### global\_phase + +Return the global phase of the current circuit scope in radians. + + + +### header + +`= 'OPENQASM 2.0;'` + + + +### instances + +`= 159` + + + +### layout + +Return any associated layout information about the circuit + +This attribute contains an optional [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object. This is typically set on the output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`PassManager.run()`](qiskit.transpiler.PassManager#run "qiskit.transpiler.PassManager.run") to retain information about the permutations caused on the input circuit by transpilation. + +There are two types of permutations caused by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function, an initial layout which permutes the qubits based on the selected physical qubits on the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"), and a final layout which is an output permutation caused by [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted during routing. + + + +### metadata + +The user provided metadata associated with the circuit. + +The metadata for the circuit is a user provided `dict` of metadata for the circuit. It will not be used to influence the execution or operation of the circuit, but it is expected to be passed between all transforms of the circuit (ie transpilation) and that providers will associate any circuit metadata with the results it returns from execution of that circuit. + + + +### num\_ancillas + +Return the number of ancilla qubits. + + + +### num\_clbits + +Return number of classical bits. + + + +### num\_parameters + +The number of parameter objects in the circuit. + + + +### num\_qubits + +Return number of qubits. + + + +### op\_start\_times + +Return a list of operation start times. + +This attribute is enabled once one of scheduling analysis passes runs on the quantum circuit. + +**Returns** + +List of integers representing instruction start times. The index corresponds to the index of instruction in `QuantumCircuit.data`. + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – When circuit is not scheduled. + + + +### parameters + +The parameters defined in the circuit. + +This attribute returns the [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit sorted alphabetically. Note that parameters instantiated with a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") are still sorted numerically. + +**Examples** + +The snippet below shows that insertion order of parameters does not matter. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> a, b, elephant = Parameter("a"), Parameter("b"), Parameter("elephant") +>>> circuit = QuantumCircuit(1) +>>> circuit.rx(b, 0) +>>> circuit.rz(elephant, 0) +>>> circuit.ry(a, 0) +>>> circuit.parameters # sorted alphabetically! +ParameterView([Parameter(a), Parameter(b), Parameter(elephant)]) +``` + +Bear in mind that alphabetical sorting might be unintuitive when it comes to numbers. The literal “10” comes before “2” in strict alphabetical sorting. + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter +>>> angles = [Parameter("angle_1"), Parameter("angle_2"), Parameter("angle_10")] +>>> circuit = QuantumCircuit(1) +>>> circuit.u(*angles, 0) +>>> circuit.draw() + ┌─────────────────────────────┐ +q: ┤ U(angle_1,angle_2,angle_10) ├ + └─────────────────────────────┘ +>>> circuit.parameters +ParameterView([Parameter(angle_1), Parameter(angle_10), Parameter(angle_2)]) +``` + +To respect numerical sorting, a [`ParameterVector`](qiskit.circuit.ParameterVector "qiskit.circuit.ParameterVector") can be used. + +```python +``` + +```python +>>> from qiskit.circuit import QuantumCircuit, Parameter, ParameterVector +>>> x = ParameterVector("x", 12) +>>> circuit = QuantumCircuit(1) +>>> for x_i in x: +... circuit.rx(x_i, 0) +>>> circuit.parameters +ParameterView([ + ParameterVectorElement(x[0]), ParameterVectorElement(x[1]), + ParameterVectorElement(x[2]), ParameterVectorElement(x[3]), + ..., ParameterVectorElement(x[11]) +]) +``` + +**Returns** + +The sorted [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the circuit. + + + +### prefix + +`= 'circuit'` + + + +### qubits + +Returns a list of quantum bits in the order that the registers were added. + + + +### thetas + +Returns a vector of rotation angles used by CNOT units in this circuit. + +**Returns** + +Parameters of the rotation gates in this circuit. + +## Methods + +### build + + + +`build(thetas)` + +**Constructs a Qiskit quantum circuit out of the parameters (angles) of this circuit. If a** + +parameter value is less in absolute value than the specified tolerance then the corresponding rotation gate will be skipped in the circuit. + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.md b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.md new file mode 100644 index 00000000000..c9aa658137f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.CNOTUnitObjective.md @@ -0,0 +1,43 @@ +--- +title: CNOTUnitObjective +description: API reference for qiskit.synthesis.unitary.aqc.CNOTUnitObjective +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.unitary.aqc.CNOTUnitObjective +--- + +# CNOTUnitObjective + + + +`qiskit.synthesis.unitary.aqc.CNOTUnitObjective(num_qubits, cnots)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/cnot_unit_objective.py "view source code") + +Bases: [`ApproximatingObjective`](qiskit.synthesis.unitary.aqc.ApproximatingObjective "qiskit.synthesis.unitary.aqc.approximate.ApproximatingObjective"), [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +A base class for a problem definition based on CNOT unit. This class may have different subclasses for objective and gradient computations. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **cnots** (*np.ndarray*) – a CNOT structure to be used in the optimization procedure. + +## Attributes + + + +### num\_cnots + +Returns: A number of CNOT units to be used by the approximate circuit. + + + +### num\_thetas + +Returns: Number of parameters (angles) of rotation gates in this circuit. + + + +### target\_matrix + +Returns: a matrix being approximated + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.md b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.md new file mode 100644 index 00000000000..6065f3509f5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective.md @@ -0,0 +1,85 @@ +--- +title: DefaultCNOTUnitObjective +description: API reference for qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective +--- + +# DefaultCNOTUnitObjective + + + +`qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective(num_qubits, cnots)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/cnot_unit_objective.py "view source code") + +Bases: [`CNOTUnitObjective`](qiskit.synthesis.unitary.aqc.CNOTUnitObjective "qiskit.synthesis.unitary.aqc.cnot_unit_objective.CNOTUnitObjective") + +A naive implementation of the objective function based on CNOT units. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **cnots** (*np.ndarray*) – a CNOT structure to be used in the optimization procedure. + +## Attributes + + + +### num\_cnots + +Returns: A number of CNOT units to be used by the approximate circuit. + + + +### num\_thetas + +Returns: Number of parameters (angles) of rotation gates in this circuit. + + + +### target\_matrix + +Returns: a matrix being approximated + +## Methods + +### gradient + + + +`gradient(param_values)` + +Computes a gradient with respect to parameters given a vector of parameter values. + +**Parameters** + +**param\_values** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a vector of parameter values for the optimization problem. + +**Returns** + +an array of gradient values. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### objective + + + +`objective(param_values)` + +Computes a value of the objective function given a vector of parameter values. + +**Parameters** + +**param\_values** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a vector of parameter values for the optimization problem. + +**Returns** + +a float value of the objective function. + +**Return type** + +[*SupportsFloat*](https://docs.python.org/3/library/typing.html#typing.SupportsFloat "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.md b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.md new file mode 100644 index 00000000000..54c624849c8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective.md @@ -0,0 +1,69 @@ +--- +title: FastCNOTUnitObjective +description: API reference for qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective +--- + +# FastCNOTUnitObjective + + + +`qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective(num_qubits, cnots)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/fast_gradient/fast_gradient.py "view source code") + +Bases: [`CNOTUnitObjective`](qiskit.synthesis.unitary.aqc.CNOTUnitObjective "qiskit.synthesis.unitary.aqc.cnot_unit_objective.CNOTUnitObjective") + +Implementation of objective function and gradient calculator, which is similar to `DefaultCNOTUnitObjective` but several times faster. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **cnots** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a CNOT structure to be used in the optimization procedure. + +## Attributes + + + +### num\_cnots + +Returns: A number of CNOT units to be used by the approximate circuit. + + + +### num\_thetas + +Returns: Number of parameters (angles) of rotation gates in this circuit. + + + +### target\_matrix + +Returns: a matrix being approximated + +## Methods + +### gradient + + + +`gradient(param_values)` + +Computes the gradient of objective function. See description of the base class method. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +### objective + + + +`objective(param_values)` + +Computes the objective function and some intermediate data for the subsequent gradient computation. See description of the base class method. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.AnalysisPass.md b/docs/api/qiskit/0.46/qiskit.transpiler.AnalysisPass.md new file mode 100644 index 00000000000..326e3ef21ed --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.AnalysisPass.md @@ -0,0 +1,109 @@ +--- +title: AnalysisPass +description: API reference for qiskit.transpiler.AnalysisPass +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.AnalysisPass +--- + +# AnalysisPass + + + +`qiskit.transpiler.AnalysisPass(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/basepasses.py "view source code") + +Bases: `BasePass` + +An analysis pass: change property set, not DAG. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`abstract run(dag)` + +Run a pass on the DAGCircuit. This is implemented by the pass developer. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – the dag on which the pass is run. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – when this is left unimplemented for a pass. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.CouplingMap.md b/docs/api/qiskit/0.46/qiskit.transpiler.CouplingMap.md new file mode 100644 index 00000000000..b17f0563e20 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.CouplingMap.md @@ -0,0 +1,426 @@ +--- +title: CouplingMap +description: API reference for qiskit.transpiler.CouplingMap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.CouplingMap +--- + +# CouplingMap + + + +`qiskit.transpiler.CouplingMap(couplinglist=None, description=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/coupling.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Directed graph specifying fixed coupling. + +Nodes correspond to physical qubits (integers) and directed edges correspond to permitted CNOT gates, with source and destination corresponding to control and target qubits, respectively. + +Create coupling graph. By default, the generated coupling has no nodes. + +**Parameters** + +* **couplinglist** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or None*) – An initial coupling graph, specified as an adjacency list containing couplings, e.g. \[\[0,1], \[0,2], \[1,2]]. It is required that nodes are contiguously indexed starting at 0. Missed nodes will be added as isolated nodes in the coupling map. +* **description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A string to describe the coupling map. + +## Attributes + + + +### description + + + +### graph + + + +### distance\_matrix + +Return the distance matrix for the coupling map. + +For any qubits where there isn’t a path available between them the value in this position of the distance matrix will be `math.inf`. + + + +### is\_symmetric + +Test if the graph is symmetric. + +Return True if symmetric, False otherwise + + + +### physical\_qubits + +Returns a sorted list of physical\_qubits + +## Methods + +### add\_edge + + + +`add_edge(src, dst)` + +Add directed edge to coupling graph. + +src (int): source physical qubit dst (int): destination physical qubit + +### add\_physical\_qubit + + + +`add_physical_qubit(physical_qubit)` + +Add a physical qubit to the coupling graph as a node. + +physical\_qubit (int): An integer representing a physical qubit. + +**Raises** + +[**CouplingError**](transpiler#qiskit.transpiler.CouplingError "qiskit.transpiler.CouplingError") – if trying to add duplicate qubit + +### compute\_distance\_matrix + + + +`compute_distance_matrix()` + +Compute the full distance matrix on pairs of nodes. + +The distance map self.\_dist\_matrix is computed from the graph using all\_pairs\_shortest\_path\_length. This is normally handled internally by the [`distance_matrix`](#qiskit.transpiler.CouplingMap.distance_matrix "qiskit.transpiler.CouplingMap.distance_matrix") attribute or the [`distance()`](#qiskit.transpiler.CouplingMap.distance "qiskit.transpiler.CouplingMap.distance") method but can be called if you’re accessing the distance matrix outside of those or want to pre-generate it. + +### connected\_components + + + +`connected_components()` + +Separate a [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") into subgraph [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") for each connected component. + +The connected components of a [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") are the subgraphs that are not part of any larger subgraph. For example, if you had a coupling map that looked like: + +```python +0 --> 1 4 --> 5 ---> 6 --> 7 +| | +| | +V V +2 --> 3 +``` + +then the connected components of that graph are the subgraphs: + +```python +0 --> 1 +| | +| | +V V +2 --> 3 +``` + +and: + +```python +4 --> 5 ---> 6 --> 7 +``` + +For a connected [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object there is only a single connected component, the entire [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap"). + +This method will return a list of [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") objects, one for each connected component in this [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap"). The data payload of each node in the [`graph`](#qiskit.transpiler.CouplingMap.graph "qiskit.transpiler.CouplingMap.graph") attribute will contain the qubit number in the original graph. This will enables mapping the qubit index in a component subgraph to the original qubit in the combined [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap"). For example: + +```python +from qiskit.transpiler import CouplingMap + +cmap = CouplingMap([[0, 1], [1, 2], [2, 0], [3, 4], [4, 5], [5, 3]]) +component_cmaps = cmap.connected_components() +print(component_cmaps[1].graph[0]) +``` + +will print `3` as index `0` in the second component is qubit 3 in the original cmap. + +**Returns** + +**A list of [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") objects for each connected** + +components. The order of this list is deterministic but implementation specific and shouldn’t be relied upon as part of the API. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +### distance + + + +`distance(physical_qubit1, physical_qubit2)` + +Returns the undirected distance between physical\_qubit1 and physical\_qubit2. + +**Parameters** + +* **physical\_qubit1** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – A physical qubit +* **physical\_qubit2** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Another physical qubit + +**Returns** + +The undirected distance + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +**Raises** + +[**CouplingError**](transpiler#qiskit.transpiler.CouplingError "qiskit.transpiler.CouplingError") – if the qubits do not exist in the CouplingMap + +### draw + + + +`draw()` + +Draws the coupling map. + +This function calls the [`graphviz_draw()`](https://www.rustworkx.org/apiref/rustworkx.visualization.graphviz_draw.html#rustworkx.visualization.graphviz_draw "(in rustworkx v0.14.0)") function from the `rustworkx` package to draw the [`CouplingMap`](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object. + +**Returns** + +Drawn coupling map. + +**Return type** + +PIL.Image + +### from\_full + + + +`classmethod from_full(num_qubits, bidirectional=True)` + +Return a fully connected coupling map on n qubits. + +**Return type** + +[*CouplingMap*](#qiskit.transpiler.CouplingMap "qiskit.transpiler.coupling.CouplingMap") + +### from\_grid + + + +`classmethod from_grid(num_rows, num_columns, bidirectional=True)` + +Return a coupling map of qubits connected on a grid of num\_rows x num\_columns. + +**Return type** + +[*CouplingMap*](#qiskit.transpiler.CouplingMap "qiskit.transpiler.coupling.CouplingMap") + +### from\_heavy\_hex + + + +`classmethod from_heavy_hex(distance, bidirectional=True)` + +Return a heavy hexagon graph coupling map. + +A heavy hexagon graph is described in: + +[https://journals.aps.org/prx/abstract/10.1103/PhysRevX.10.011022](https://journals.aps.org/prx/abstract/10.1103/PhysRevX.10.011022) + +**Parameters** + +* **distance** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The code distance for the generated heavy hex graph. The value for distance can be any odd positive integer. The distance relates to the number of qubits by: $n = \frac{5d^2 - 2d - 1}{2}$ where $n$ is the number of qubits and $d$ is the `distance` parameter. +* **bidirectional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the edges in the output coupling graph are bidirectional or not. By default this is set to `True` + +**Returns** + +A heavy hex coupling graph + +**Return type** + +[CouplingMap](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") + +### from\_heavy\_square + + + +`classmethod from_heavy_square(distance, bidirectional=True)` + +Return a heavy square graph coupling map. + +A heavy square graph is described in: + +[https://journals.aps.org/prx/abstract/10.1103/PhysRevX.10.011022](https://journals.aps.org/prx/abstract/10.1103/PhysRevX.10.011022) + +**Parameters** + +* **distance** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The code distance for the generated heavy square graph. The value for distance can be any odd positive integer. The distance relates to the number of qubits by: $n = 3d^2 - 2d$ where $n$ is the number of qubits and $d$ is the `distance` parameter. +* **bidirectional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the edges in the output coupling graph are bidirectional or not. By default this is set to `True` + +**Returns** + +A heavy square coupling graph + +**Return type** + +[CouplingMap](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") + +### from\_hexagonal\_lattice + + + +`classmethod from_hexagonal_lattice(rows, cols, bidirectional=True)` + +Return a hexagonal lattice graph coupling map. + +**Parameters** + +* **rows** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of rows to generate the graph with. +* **cols** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of columns to generate the graph with. +* **bidirectional** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the edges in the output coupling graph are bidirectional or not. By default this is set to `True` + +**Returns** + +A hexagonal lattice coupling graph + +**Return type** + +[CouplingMap](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") + +### from\_line + + + +`classmethod from_line(num_qubits, bidirectional=True)` + +Return a coupling map of n qubits connected in a line. + +**Return type** + +[*CouplingMap*](#qiskit.transpiler.CouplingMap "qiskit.transpiler.coupling.CouplingMap") + +### from\_ring + + + +`classmethod from_ring(num_qubits, bidirectional=True)` + +Return a coupling map of n qubits connected to each of their neighbors in a ring. + +**Return type** + +[*CouplingMap*](#qiskit.transpiler.CouplingMap "qiskit.transpiler.coupling.CouplingMap") + +### get\_edges + + + +`get_edges()` + +Gets the list of edges in the coupling graph. + +**Returns** + +Each edge is a pair of physical qubits. + +**Return type** + +Tuple([int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)"),[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) + +### is\_connected + + + +`is_connected()` + +Test if the graph is connected. + +Return True if connected, False otherwise + +### largest\_connected\_component + + + +`largest_connected_component()` + +Return a set of qubits in the largest connected component. + +### make\_symmetric + + + +`make_symmetric()` + +Convert uni-directional edges into bi-directional. + +### neighbors + + + +`neighbors(physical_qubit)` + +Return the nearest neighbors of a physical qubit. + +Directionality matters, i.e. a neighbor must be reachable by going one hop in the direction of an edge. + +### reduce + + + +`reduce(mapping, check_if_connected=True)` + +Returns a reduced coupling map that corresponds to the subgraph of qubits selected in the mapping. + +**Parameters** + +* **mapping** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A mapping of reduced qubits to device qubits. +* **check\_if\_connected** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, checks that the reduced coupling map is connected. + +**Returns** + +A reduced coupling\_map for the selected qubits. + +**Return type** + +[CouplingMap](#qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") + +**Raises** + +[**CouplingError**](transpiler#qiskit.transpiler.CouplingError "qiskit.transpiler.CouplingError") – Reduced coupling map must be connected. + +### shortest\_undirected\_path + + + +`shortest_undirected_path(physical_qubit1, physical_qubit2)` + +Returns the shortest undirected path between physical\_qubit1 and physical\_qubit2. + +**Parameters** + +* **physical\_qubit1** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – A physical qubit +* **physical\_qubit2** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Another physical qubit + +**Returns** + +The shortest undirected path + +**Return type** + +List + +**Raises** + +[**CouplingError**](transpiler#qiskit.transpiler.CouplingError "qiskit.transpiler.CouplingError") – When there is no path between physical\_qubit1, physical\_qubit2. + +### size + + + +`size()` + +Return the number of physical qubits in this graph. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.FencedDAGCircuit.md b/docs/api/qiskit/0.46/qiskit.transpiler.FencedDAGCircuit.md new file mode 100644 index 00000000000..bc4cff65e23 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.FencedDAGCircuit.md @@ -0,0 +1,22 @@ +--- +title: FencedDAGCircuit +description: API reference for qiskit.transpiler.FencedDAGCircuit +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.FencedDAGCircuit +--- + +# FencedDAGCircuit + + + +`qiskit.transpiler.FencedDAGCircuit(dag_circuit_instance)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/fencedobjs.py "view source code") + +Bases: `FencedObject` + +A dag circuit that cannot be modified (via remove\_op\_node) + + + The class `qiskit.transpiler.fencedobjs.FencedDAGCircuit` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0 release. Internal use of FencedObject is already removed from pass manager. Implementation of a task subclass with protection for input object modification is now responsibility of the developer. + + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.FencedPropertySet.md b/docs/api/qiskit/0.46/qiskit.transpiler.FencedPropertySet.md new file mode 100644 index 00000000000..d83dd5e8f66 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.FencedPropertySet.md @@ -0,0 +1,22 @@ +--- +title: FencedPropertySet +description: API reference for qiskit.transpiler.FencedPropertySet +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.FencedPropertySet +--- + +# FencedPropertySet + + + +`qiskit.transpiler.FencedPropertySet(property_set_instance)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/fencedobjs.py "view source code") + +Bases: `FencedObject` + +A property set that cannot be written (via \_\_setitem\_\_) + + + The class `qiskit.transpiler.fencedobjs.FencedPropertySet` is deprecated as of qiskit 0.46.0. It will be removed in the 1.0 release. Internal use of FencedObject is already removed from pass manager. Implementation of a task subclass with protection for input object modification is now responsibility of the developer. + + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.InstructionDurations.md b/docs/api/qiskit/0.46/qiskit.transpiler.InstructionDurations.md new file mode 100644 index 00000000000..e97bb79a815 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.InstructionDurations.md @@ -0,0 +1,116 @@ +--- +title: InstructionDurations +description: API reference for qiskit.transpiler.InstructionDurations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.InstructionDurations +--- + +# InstructionDurations + + + +`qiskit.transpiler.InstructionDurations(instruction_durations=None, dt=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/instruction_durations.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Helper class to provide durations of instructions for scheduling. + +It stores durations (gate lengths) and dt to be used at the scheduling stage of transpiling. It can be constructed from `backend` or `instruction_durations`, which is an argument of `transpile()`. The duration of an instruction depends on the instruction (given by name), the qubits, and optionally the parameters of the instruction. Note that these fields are used as keys in dictionaries that are used to retrieve the instruction durations. Therefore, users must use the exact same parameter value to retrieve an instruction duration as the value with which it was added. + +## Methods + +### from\_backend + + + +`classmethod from_backend(backend)` + +Construct an [`InstructionDurations`](#qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") object from the backend. + +**Parameters** + +**backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend")) – backend from which durations (gate lengths) and dt are extracted. + +**Returns** + +The InstructionDurations constructed from backend. + +**Return type** + +[InstructionDurations](#qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If dt and dtm is different in the backend. + +### get + + + +`get(inst, qubits, unit='dt', parameters=None)` + +Get the duration of the instruction with the name, qubits, and parameters. + +Some instructions may have a parameter dependent duration. + +**Parameters** + +* **inst** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")) – An instruction or its name to be queried. +* **qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *|*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – Qubit indices that the instruction acts on. +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unit of duration to be returned. It must be ‘s’ or ‘dt’. +* **parameters** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*] | None*) – The value of the parameters of the desired instruction. + +**Returns** + +The duration of the instruction on the qubits. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")|[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – No duration is defined for the instruction. + +### units\_used + + + +`units_used()` + +Get the set of all units used in this instruction durations. + +**Returns** + +Set of units used in this instruction durations. + +**Return type** + +[set](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### update + + + +`update(inst_durations, dt=None)` + +Update self with inst\_durations (inst\_durations overwrite self). + +**Parameters** + +* **inst\_durations** (*'InstructionDurationsType' | None*) – Instruction durations to be merged into self (overwriting self). +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Sampling duration in seconds of the target backend. + +**Returns** + +The updated InstructionDurations. + +**Return type** + +[InstructionDurations](#qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the format of instruction\_durations is invalid. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.InstructionProperties.md b/docs/api/qiskit/0.46/qiskit.transpiler.InstructionProperties.md new file mode 100644 index 00000000000..cc076285d7e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.InstructionProperties.md @@ -0,0 +1,52 @@ +--- +title: InstructionProperties +description: API reference for qiskit.transpiler.InstructionProperties +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.InstructionProperties +--- + +# InstructionProperties + + + +`qiskit.transpiler.InstructionProperties(duration=None, error=None, calibration=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/target.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +A representation of the properties of a gate implementation. + +This class provides the optional properties that a backend can provide about an instruction. These represent the set that the transpiler can currently work with if present. However, if your backend provides additional properties for instructions you should subclass this to add additional custom attributes for those custom/additional properties by the backend. + +Create a new `InstructionProperties` object + +**Parameters** + +* **duration** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The duration, in seconds, of the instruction on the specified set of qubits +* **error** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The average error rate for the instruction on the specified set of qubits. +* **calibration** ([*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") *| CalibrationEntry | None*) – The pulse representation of the instruction. + +## Attributes + + + +### duration + + + +### error + + + +### calibration + +The pulse representation of the instruction. + + + This attribute always returns a Qiskit pulse program, but it is internally wrapped by the `CalibrationEntry` to manage unbound parameters and to uniformly handle different data representation, for example, un-parsed Pulse Qobj JSON that a backend provider may provide. + + This value can be overridden through the property setter in following manner. When you set either [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") or [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") this is always treated as a user-defined (custom) calibration and the transpiler may automatically attach the calibration data to the output circuit. This calibration data may appear in the wire format as an inline calibration, which may further update the backend standard instruction set architecture. + + If you are a backend provider who provides a default calibration data that is not needed to be attached to the transpiled quantum circuit, you can directly set `CalibrationEntry` instance to this attribute, in which you should set `user_provided=False` when you define calibration data for the entry. End users can still intentionally utilize the calibration data, for example, to run pulse-level simulation of the circuit. However, such entry doesn’t appear in the wire format, and backend must use own definition to compile the circuit down to the execution format. + + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.Layout.md b/docs/api/qiskit/0.46/qiskit.transpiler.Layout.md new file mode 100644 index 00000000000..964fb521c22 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.Layout.md @@ -0,0 +1,267 @@ +--- +title: Layout +description: API reference for qiskit.transpiler.Layout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.Layout +--- + +# Layout + + + +`qiskit.transpiler.Layout(input_dict=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/layout.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Two-ways dict to represent a Layout. + +construct a Layout from a bijective dictionary, mapping virtual qubits to physical qubits + +## Methods + +### add + + + +`add(virtual_bit, physical_bit=None)` + +Adds a map element between bit and physical\_bit. If physical\_bit is not defined, bit will be mapped to a new physical bit. + +**Parameters** + +* **virtual\_bit** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – A (qu)bit. For example, (QuantumRegister(3, ‘qr’), 2). +* **physical\_bit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – A physical bit. For example, 3. + +### add\_register + + + +`add_register(reg)` + +Adds at the end physical\_qubits that map each bit in reg. + +**Parameters** + +**reg** ([*Register*](qiskit.circuit.Register "qiskit.circuit.Register")) – A (qu)bit Register. For example, QuantumRegister(3, ‘qr’). + +### combine\_into\_edge\_map + + + +`combine_into_edge_map(another_layout)` + +Combines self and another\_layout into an “edge map”. + +For example: + +```python + self another_layout resulting edge map +qr_1 -> 0 0 <- q_2 qr_1 -> q_2 +qr_2 -> 2 2 <- q_1 qr_2 -> q_1 +qr_3 -> 3 3 <- q_0 qr_3 -> q_0 +``` + +The edge map is used to compose dags via, for example, compose. + +**Parameters** + +**another\_layout** ([*Layout*](#qiskit.transpiler.Layout "qiskit.transpiler.Layout")) – The other layout to combine. + +**Returns** + +A “edge map”. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**LayoutError**](transpiler#qiskit.transpiler.LayoutError "qiskit.transpiler.LayoutError") – another\_layout can be bigger than self, but not smaller. Otherwise, raises. + +### copy + + + +`copy()` + +Returns a copy of a Layout instance. + +### from\_dict + + + +`from_dict(input_dict)` + +Populates a Layout from a dictionary. + +The dictionary must be a bijective mapping between virtual qubits (tuple) and physical qubits (int). + +**Parameters** + +**input\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + +e.g.: + +```python +{(QuantumRegister(3, 'qr'), 0): 0, + (QuantumRegister(3, 'qr'), 1): 1, + (QuantumRegister(3, 'qr'), 2): 2} + +Can be written more concisely as follows: + +* virtual to physical:: + + {qr[0]: 0, + qr[1]: 1, + qr[2]: 2} + +* physical to virtual:: + + {0: qr[0], + 1: qr[1], + 2: qr[2]} +``` + +### from\_intlist + + + +`static from_intlist(int_list, *qregs)` + +Converts a list of integers to a Layout mapping virtual qubits (index of the list) to physical qubits (the list values). + +**Parameters** + +* **int\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of integers. +* **\*qregs** (*QuantumRegisters*) – The quantum registers to apply the layout to. + +**Returns** + +The corresponding Layout object. + +**Return type** + +[Layout](#qiskit.transpiler.Layout "qiskit.transpiler.Layout") + +**Raises** + +[**LayoutError**](transpiler#qiskit.transpiler.LayoutError "qiskit.transpiler.LayoutError") – Invalid input layout. + +### from\_qubit\_list + + + +`static from_qubit_list(qubit_list, *qregs)` + +Populates a Layout from a list containing virtual qubits, Qubit or None. + +**Parameters** + +* **qubit\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – e.g.: \[qr\[0], None, qr\[2], qr\[3]] +* **\*qregs** (*QuantumRegisters*) – The quantum registers to apply the layout to. + +**Returns** + +the corresponding Layout object + +**Return type** + +[Layout](#qiskit.transpiler.Layout "qiskit.transpiler.Layout") + +**Raises** + +[**LayoutError**](transpiler#qiskit.transpiler.LayoutError "qiskit.transpiler.LayoutError") – If the elements are not Qubit or None + +### generate\_trivial\_layout + + + +`static generate_trivial_layout(*regs)` + +Creates a trivial (“one-to-one”) Layout with the registers and qubits in regs. + +**Parameters** + +**\*regs** (*Registers, Qubits*) – registers and qubits to include in the layout. + +**Returns** + +A layout with all the regs in the given order. + +**Return type** + +[Layout](#qiskit.transpiler.Layout "qiskit.transpiler.Layout") + +### get\_physical\_bits + + + +`get_physical_bits()` + +Returns the dictionary where the keys are physical (qu)bits and the values are virtual (qu)bits. + +### get\_registers + + + +`get_registers()` + +Returns the registers in the layout \[QuantumRegister(2, ‘qr0’), QuantumRegister(3, ‘qr1’)] :returns: A set of Registers in the layout :rtype: Set + +### get\_virtual\_bits + + + +`get_virtual_bits()` + +Returns the dictionary where the keys are virtual (qu)bits and the values are physical (qu)bits. + +### order\_based\_on\_type + + + +`static order_based_on_type(value1, value2)` + +decides which one is physical/virtual based on the type. Returns (virtual, physical) + +### reorder\_bits + + + +`reorder_bits(bits)` + +Given an ordered list of bits, reorder them according to this layout. + +The list of bits must exactly match the virtual bits in this layout. + +**Parameters** + +**bits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Bit*](qiskit.circuit.Bit "qiskit.circuit.Bit")*]*) – the bits to reorder. + +**Returns** + +ordered bits. + +**Return type** + +List + +### swap + + + +`swap(left, right)` + +Swaps the map between left and right. + +**Parameters** + +* **left** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Item to swap with right. +* **right** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)") *or*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Item to swap with left. + +**Raises** + +[**LayoutError**](transpiler#qiskit.transpiler.LayoutError "qiskit.transpiler.LayoutError") – If left and right have not the same type. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.PassManager.md b/docs/api/qiskit/0.46/qiskit.transpiler.PassManager.md new file mode 100644 index 00000000000..e9f1ca16c72 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.PassManager.md @@ -0,0 +1,217 @@ +--- +title: PassManager +description: API reference for qiskit.transpiler.PassManager +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.PassManager +--- + +# PassManager + + + +`qiskit.transpiler.PassManager(passes=(), max_iteration=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passmanager.py "view source code") + +Bases: [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.passmanager.BasePassManager") + +Manager for a set of Passes and their scheduling during transpilation. + +Initialize an empty pass manager object. + +**Parameters** + +* **passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A pass set to be added to the pass manager schedule. +* **max\_iteration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of iterations the schedule will be looped if the condition is not met. + +## Methods + +### append + + + +`append(passes, max_iteration=None, **flow_controller_conditions)` + +Append a Pass Set to the schedule of passes. + + + Creating flow controllers with `flow_controller_conditions` keyword arguments was deprecated. Instead, you must explicitly instantiate a controller and set the controller to `passes` argument. + + + + `qiskit.transpiler.passmanager.PassManager.append()`’s argument `max_iteration` is deprecated as of qiskit 0.46. It will be removed in the 1.0 release. ‘max\_iteration’ can be set in the constructor. + + +**Parameters** + +* **passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A set of passes (a pass set) to be added to schedule. A pass set is a list of passes that are controlled by the same flow controller. If a single pass is provided, the pass set will only have that pass a single element. It is also possible to append a `BaseFlowController` instance and the rest of the parameter will be ignored. + +* **max\_iteration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max number of iterations of passes. + +* **flow\_controller\_conditions** (*Any*) – + + Dictionary of control flow plugins. Following built-in controllers are available by default: + + * do\_while: The passes repeat until the callable returns False. Corresponds to [`DoWhileController`](qiskit.passmanager.DoWhileController "qiskit.passmanager.DoWhileController"). + * condition: The passes run only if the callable returns True. Corresponds to [`ConditionalController`](qiskit.passmanager.ConditionalController "qiskit.passmanager.ConditionalController"). + + In general, you have more control simply by creating the controller you want and passing it to [`append()`](#qiskit.transpiler.PassManager.append "qiskit.transpiler.PassManager.append"). + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if a pass in passes is not a proper pass. + +### draw + + + +`draw(filename=None, style=None, raw=False)` + +Draw the pass manager. + +This function needs [pydot](https://github.com/erocarrera/pydot), which in turn needs [Graphviz](https://www.graphviz.org/) to be installed. + +**Parameters** + +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. +* **style** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – keys are the pass classes and the values are the colors to make them. An example can be seen in the DEFAULT\_STYLE. An ordered dict can be used to ensure a priority coloring when pass falls into multiple categories. Any values not included in the provided dict will be filled in from the default dict. +* **raw** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True`, save the raw Dot output instead of the image. + +**Returns** + +an in-memory representation of the pass manager, or `None` if no image was generated or [Pillow](https://pypi.org/project/Pillow/) is not installed. + +**Return type** + +Optional\[[PassManager](#qiskit.transpiler.PassManager "qiskit.transpiler.PassManager")] + +**Raises** + +[**ImportError**](https://docs.python.org/3/library/exceptions.html#ImportError "(in Python v3.12)") – when nxpd or pydot not installed. + +### passes + + + +`passes()` + +Return a list structure of the appended passes and its options. + + + The method `qiskit.transpiler.passmanager.PassManager.passes()` is deprecated as of qiskit 0.46. It will be removed in the 1.0 release. Use .to\_flow\_controller().tasks instead. This returns a sequence of linearized base task instances in tuple format. + + +**Returns** + +A list of pass sets, as defined in `append()`. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), qiskit.transpiler.basepasses.BasePass]] + +### remove + + + +`remove(index)` + +Removes a particular pass in the scheduler. + +**Parameters** + +**index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Pass index to remove, based on the position in [`passes()`](transpiler_passes#module-qiskit.transpiler.passes "qiskit.transpiler.passes"). + +**Raises** + +[**PassManagerError**](passmanager#qiskit.passmanager.PassManagerError "qiskit.passmanager.PassManagerError") – If the index is not found. + +### replace + + + +`replace(index, passes, max_iteration=None, **flow_controller_conditions)` + +Replace a particular pass in the scheduler. + + + Creating flow controllers with `flow_controller_conditions` keyword arguments was deprecated. Instead, you must explicitly instantiate a controller and set the controller to `passes` argument. + + + + `qiskit.transpiler.passmanager.PassManager.replace()`’s argument `max_iteration` is deprecated as of qiskit 0.46. It will be removed in the 1.0 release. ‘max\_iteration’ can be set in the constructor. + + +**Parameters** + +* **index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Pass index to replace, based on the position in passes(). +* **passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A pass set to be added to the pass manager schedule. +* **max\_iteration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max number of iterations of passes. +* **flow\_controller\_conditions** (*Any*) – Dictionary of control flow plugins. See [`qiskit.transpiler.PassManager.append()`](#qiskit.transpiler.PassManager.append "qiskit.transpiler.PassManager.append") for details. + +### run + + + +`run(circuits, output_name=None, callback=None)` + +Run all the passes on the specified `circuits`. + +**Parameters** + +* **circuits** (*\_CircuitsT*) – Circuit(s) to transform via all the registered passes. + +* **output\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The output circuit name. If `None`, it will be set to the same as the input circuit name. + +* **callback** (*Callable*) – + + A callback function that will be called after each pass execution. The function will be called with 5 keyword arguments: + + ```python + pass_ (Pass): the pass being run + dag (DAGCircuit): the dag output of the pass + time (float): the time to execute the pass + property_set (PropertySet): the property set + count (int): the index for the pass execution + ``` + + + Beware that the keyword arguments here are different to those used by the generic [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.BasePassManager"). This pass manager will translate those arguments into the form described above. + + + The exact arguments pass expose the internals of the pass manager and are subject to change as the pass manager internals change. If you intend to reuse a callback function over multiple releases be sure to check that the arguments being passed are the same. + + To use the callback feature you define a function that will take in kwargs dict and access the variables. For example: + + ```python + def callback_func(**kwargs): + pass_ = kwargs['pass_'] + dag = kwargs['dag'] + time = kwargs['time'] + property_set = kwargs['property_set'] + count = kwargs['count'] + ... + ``` + +**Returns** + +The transformed circuit(s). + +**Return type** + +\_CircuitsT + +### to\_flow\_controller + + + +`to_flow_controller()` + +Linearize this manager into a single [`FlowControllerLinear`](qiskit.passmanager.FlowControllerLinear "qiskit.passmanager.FlowControllerLinear"), so that it can be nested inside another pass manager. + +**Returns** + +A linearized pass manager. + +**Return type** + +*RunningPassManager* + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.PassManagerConfig.md b/docs/api/qiskit/0.46/qiskit.transpiler.PassManagerConfig.md new file mode 100644 index 00000000000..92dc8eebf0a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.PassManagerConfig.md @@ -0,0 +1,70 @@ +--- +title: PassManagerConfig +description: API reference for qiskit.transpiler.PassManagerConfig +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.PassManagerConfig +--- + +# PassManagerConfig + + + +`qiskit.transpiler.PassManagerConfig(initial_layout=None, basis_gates=None, inst_map=None, coupling_map=None, layout_method=None, routing_method=None, translation_method=None, scheduling_method=None, instruction_durations=None, backend_properties=None, approximation_degree=None, seed_transpiler=None, timing_constraints=None, unitary_synthesis_method='default', unitary_synthesis_plugin_config=None, target=None, hls_config=None, init_method=None, optimization_method=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passmanager_config.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Pass Manager Configuration. + +Initialize a PassManagerConfig object + +**Parameters** + +* **initial\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout")) – Initial position of virtual qubits on physical qubits. +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of basis gate names to unroll to. +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap")) – Mapping object that maps gate to schedule. +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – Directed graph represented a coupling map. +* **layout\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the pass to use for choosing initial qubit placement. This will be the plugin name if an external layout stage plugin is being used. +* **routing\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the pass to use for routing qubits on the architecture. This will be a plugin name if an external routing stage plugin is being used. +* **translation\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the pass to use for translating gates to basis\_gates. This will be a plugin name if an external translation stage plugin is being used. +* **scheduling\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the pass to use for scheduling instructions. This will be a plugin name if an external scheduling stage plugin is being used. +* **instruction\_durations** ([*InstructionDurations*](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations")) – Dictionary of duration (in dt) for each instruction. +* **backend\_properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – Properties returned by a backend, including information on gate errors, readout errors, qubit coherence times, etc. +* **approximation\_degree** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – heuristic dial used for circuit approximation (1.0=no approximation, 0.0=maximal approximation) +* **seed\_transpiler** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Sets random seed for the stochastic parts of the transpiler. +* **timing\_constraints** (*TimingConstraints*) – Hardware time alignment restrictions. +* **unitary\_synthesis\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The string method to use for the [`UnitarySynthesis`](qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") pass. Will search installed plugins for a valid method. You can see a list of installed plugins with [`unitary_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names"). +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The backend target +* **hls\_config** (*HLSConfig*) – An optional configuration class to use for [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") pass. Specifies how to synthesize various high-level objects. +* **init\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The plugin name for the init stage plugin to use +* **optimization\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The plugin name for the optimization stage plugin to use. + +## Methods + +### from\_backend + + + +`classmethod from_backend(backend, _skip_target=False, **pass_manager_options)` + +Construct a configuration based on a backend and user input. + +This method automatically gererates a PassManagerConfig object based on the backend’s features. User options can be used to overwrite the configuration. + +**Parameters** + +* **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.BackendV1")) – The backend that provides the configuration. +* **pass\_manager\_options** – User-defined option-value pairs. + +**Returns** + +The configuration generated based on the arguments. + +**Return type** + +[PassManagerConfig](#qiskit.transpiler.PassManagerConfig "qiskit.transpiler.PassManagerConfig") + +**Raises** + +[**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If the backend does not support a configuration() method. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.StagedPassManager.md b/docs/api/qiskit/0.46/qiskit.transpiler.StagedPassManager.md new file mode 100644 index 00000000000..298d0cd655f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.StagedPassManager.md @@ -0,0 +1,241 @@ +--- +title: StagedPassManager +description: API reference for qiskit.transpiler.StagedPassManager +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.StagedPassManager +--- + +# StagedPassManager + + + +`qiskit.transpiler.StagedPassManager(stages=None, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passmanager.py "view source code") + +Bases: [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.passmanager.PassManager") + +A pass manager pipeline built from individual stages. + +This class enables building a compilation pipeline out of fixed stages. Each `StagedPassManager` defines a list of stages which are executed in a fixed order, and each stage is defined as a standalone [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") instance. There are also `pre_` and `post_` stages for each defined stage. This enables easily composing and replacing different stages and also adding hook points to enable programmatic modifications to a pipeline. When using a staged pass manager you are not able to modify the individual passes and are only able to modify stages. + +By default, instances of `StagedPassManager` define a typical full compilation pipeline from an abstract virtual circuit to one that is optimized and capable of running on the specified backend. The default pre-defined stages are: + +1. `init` - Initial passes to run before embedding the circuit to the backend. +2. `layout` - Maps the virtual qubits in the circuit to the physical qubits on the backend. +3. `routing` - Inserts gates as needed to move the qubit states around until the circuit can be run with the chosen layout on the backend’s coupling map. +4. `translation` - Translates the gates in the circuit to the target backend’s basis gate set. +5. `optimization` - Optimizes the circuit to reduce the cost of executing it. These passes will typically run in a loop until a convergence criteria is met. For example, the convergence criteria might be that the circuit depth does not decrease in successive iterations. +6. `scheduling` - Hardware-aware passes that schedule the operations in the circuit. + + + For backwards compatibility the relative positioning of these default stages will remain stable moving forward. However, new stages may be added to the default stage list in between current stages. For example, in a future release a new phase, something like `logical_optimization`, could be added immediately after the existing `init` stage in the default stage list. This would preserve compatibility for pre-existing `StagedPassManager` users as the relative positions of the stage are preserved so the behavior will not change between releases. + + +These stages will be executed in order and any stage set to `None` will be skipped. If a stage is provided multiple times (i.e. at diferent relative positions), the associated passes, including pre and post, will run once per declaration. If a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") input is being used for more than 1 stage here (for example in the case of a `Pass` that covers both Layout and Routing) you will want to set that to the earliest stage in sequence that it covers. + +Initialize a new StagedPassManager object + +**Parameters** + +* **stages** (*Iterable\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – An optional list of stages to use for this instance. If this is not specified the default stages list `['init', 'layout', 'routing', 'translation', 'optimization', 'scheduling']` is used. After instantiation, the final list will be immutable and stored as tuple. If a stage is provided multiple times (i.e. at diferent relative positions), the associated passes, including pre and post, will run once per declaration. +* **kwargs** – The initial [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") values for any stages defined in `stages`. If a argument is not defined the stages will default to `None` indicating an empty/undefined stage. + +**Raises** + +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If a stage in the input keyword arguments is not defined. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If an invalid stage name is specified. + +## Attributes + + + +### expanded\_stages + +Expanded Pass manager stages including `pre_` and `post_` phases. + + + +### invalid\_stage\_regex = re.compile('\\\s|\\\\+|\\\\-|\\\\\*|\\\\/|\\\\\\\\|\\\\%|\\\\\<|\\\\>|\\\\@|\\\\!|\\\\\~|\\\\^|\\\\&|\\\\ + +`= re.compile('\\s|\\+|\\-|\\*|\\/|\\\\|\\%|\\<|\\>|\\@|\\!|\\~|\\^|\\&|\\:` + +`= re.compile('\\s|\\+|\\-|\\*|\\/|\\\\|\\%|\\<|\\>|\\@|\\!|\\~|\\^|\\&|\\:|\\[|\\]|\\{|\\}|\\(|\\)')` + + + +### stages + +Pass manager stages + +## Methods + +### append + + + +`append(passes, max_iteration=None, **flow_controller_conditions)` + +Append a Pass Set to the schedule of passes. + + + Creating flow controllers with `flow_controller_conditions` keyword arguments was deprecated. Instead, you must explicitly instantiate a controller and set the controller to `passes` argument. + + + + `qiskit.transpiler.passmanager.PassManager.append()`’s argument `max_iteration` is deprecated as of qiskit 0.46. It will be removed in the 1.0 release. ‘max\_iteration’ can be set in the constructor. + + +**Parameters** + +* **passes** (*Task |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[Task]*) – A set of passes (a pass set) to be added to schedule. A pass set is a list of passes that are controlled by the same flow controller. If a single pass is provided, the pass set will only have that pass a single element. It is also possible to append a `BaseFlowController` instance and the rest of the parameter will be ignored. + +* **max\_iteration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max number of iterations of passes. + +* **flow\_controller\_conditions** (*Any*) – + + Dictionary of control flow plugins. Following built-in controllers are available by default: + + * do\_while: The passes repeat until the callable returns False. Corresponds to [`DoWhileController`](qiskit.passmanager.DoWhileController "qiskit.passmanager.DoWhileController"). + * condition: The passes run only if the callable returns True. Corresponds to [`ConditionalController`](qiskit.passmanager.ConditionalController "qiskit.passmanager.ConditionalController"). + + In general, you have more control simply by creating the controller you want and passing it to [`append()`](#qiskit.transpiler.StagedPassManager.append "qiskit.transpiler.StagedPassManager.append"). + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if a pass in passes is not a proper pass. + +### draw + + + +`draw(filename=None, style=None, raw=False)` + +Draw the staged pass manager. + +### passes + + + +`passes()` + +Return a list structure of the appended passes and its options. + + + The method `qiskit.transpiler.passmanager.PassManager.passes()` is deprecated as of qiskit 0.46. It will be removed in the 1.0 release. Use .to\_flow\_controller().tasks instead. This returns a sequence of linearized base task instances in tuple format. + + +**Returns** + +A list of pass sets, as defined in `append()`. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), qiskit.transpiler.basepasses.BasePass]] + +### remove + + + +`remove(index)` + +Removes a particular pass in the scheduler. + +**Parameters** + +**index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Pass index to remove, based on the position in [`passes()`](transpiler_passes#module-qiskit.transpiler.passes "qiskit.transpiler.passes"). + +**Raises** + +[**PassManagerError**](passmanager#qiskit.passmanager.PassManagerError "qiskit.passmanager.PassManagerError") – If the index is not found. + +### replace + + + +`replace(index, passes, max_iteration=None, **flow_controller_conditions)` + +Replace a particular pass in the scheduler. + + + Creating flow controllers with `flow_controller_conditions` keyword arguments was deprecated. Instead, you must explicitly instantiate a controller and set the controller to `passes` argument. + + + + `qiskit.transpiler.passmanager.PassManager.replace()`’s argument `max_iteration` is deprecated as of qiskit 0.46. It will be removed in the 1.0 release. ‘max\_iteration’ can be set in the constructor. + + +**Parameters** + +* **index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Pass index to replace, based on the position in passes(). +* **passes** (*BasePass |* [*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[BasePass]*) – A pass set to be added to the pass manager schedule. +* **max\_iteration** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – max number of iterations of passes. +* **flow\_controller\_conditions** (*Any*) – Dictionary of control flow plugins. See [`qiskit.transpiler.PassManager.append()`](qiskit.transpiler.PassManager#append "qiskit.transpiler.PassManager.append") for details. + +### run + + + +`run(circuits, output_name=None, callback=None)` + +Run all the passes on the specified `circuits`. + +**Parameters** + +* **circuits** (*\_CircuitsT*) – Circuit(s) to transform via all the registered passes. + +* **output\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The output circuit name. If `None`, it will be set to the same as the input circuit name. + +* **callback** (*Callable | None*) – + + A callback function that will be called after each pass execution. The function will be called with 5 keyword arguments: + + ```python + pass_ (Pass): the pass being run + dag (DAGCircuit): the dag output of the pass + time (float): the time to execute the pass + property_set (PropertySet): the property set + count (int): the index for the pass execution + ``` + + + Beware that the keyword arguments here are different to those used by the generic [`BasePassManager`](qiskit.passmanager.BasePassManager "qiskit.passmanager.BasePassManager"). This pass manager will translate those arguments into the form described above. + + + The exact arguments pass expose the internals of the pass manager and are subject to change as the pass manager internals change. If you intend to reuse a callback function over multiple releases be sure to check that the arguments being passed are the same. + + To use the callback feature you define a function that will take in kwargs dict and access the variables. For example: + + ```python + def callback_func(**kwargs): + pass_ = kwargs['pass_'] + dag = kwargs['dag'] + time = kwargs['time'] + property_set = kwargs['property_set'] + count = kwargs['count'] + ... + ``` + +**Returns** + +The transformed circuit(s). + +**Return type** + +\_CircuitsT + +### to\_flow\_controller + + + +`to_flow_controller()` + +Linearize this manager into a single [`FlowControllerLinear`](qiskit.passmanager.FlowControllerLinear "qiskit.passmanager.FlowControllerLinear"), so that it can be nested inside another pass manager. + +**Returns** + +A linearized pass manager. + +**Return type** + +*RunningPassManager* + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.Target.md b/docs/api/qiskit/0.46/qiskit.transpiler.Target.md new file mode 100644 index 00000000000..445a2c3af39 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.Target.md @@ -0,0 +1,649 @@ +--- +title: Target +description: API reference for qiskit.transpiler.Target +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.Target +--- + +# Target + + + +`qiskit.transpiler.Target(description=None, num_qubits=0, dt=None, granularity=1, min_length=1, pulse_alignment=1, acquire_alignment=1, qubit_properties=None, concurrent_measurements=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/target.py "view source code") + +Bases: [`Mapping`](https://docs.python.org/3/library/collections.abc.html#collections.abc.Mapping "(in Python v3.12)") + +The intent of the `Target` object is to inform Qiskit’s compiler about the constraints of a particular backend so the compiler can compile an input circuit to something that works and is optimized for a device. It currently contains a description of instructions on a backend and their properties as well as some timing information. However, this exact interface may evolve over time as the needs of the compiler change. These changes will be done in a backwards compatible and controlled manner when they are made (either through versioning, subclassing, or mixins) to add on to the set of information exposed by a target. + +As a basic example, let’s assume backend has two qubits, supports [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate") on both qubits and [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") in both directions. To model this you would create the target like: + +```python +from qiskit.transpiler import Target, InstructionProperties +from qiskit.circuit.library import UGate, CXGate +from qiskit.circuit import Parameter + +gmap = Target() +theta = Parameter('theta') +phi = Parameter('phi') +lam = Parameter('lambda') +u_props = { + (0,): InstructionProperties(duration=5.23e-8, error=0.00038115), + (1,): InstructionProperties(duration=4.52e-8, error=0.00032115), +} +gmap.add_instruction(UGate(theta, phi, lam), u_props) +cx_props = { + (0,1): InstructionProperties(duration=5.23e-7, error=0.00098115), + (1,0): InstructionProperties(duration=4.52e-7, error=0.00132115), +} +gmap.add_instruction(CXGate(), cx_props) +``` + +Each instruction in the `Target` is indexed by a unique string name that uniquely identifies that instance of an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") object in the Target. There is a 1:1 mapping between a name and an [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instance in the target and each name must be unique. By default, the name is the [`name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") attribute of the instruction, but can be set to anything. This lets a single target have multiple instances of the same instruction class with different parameters. For example, if a backend target has two instances of an [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") one is parameterized over any theta while the other is tuned up for a theta of pi/6 you can add these by doing something like: + +```python +import math + +from qiskit.transpiler import Target, InstructionProperties +from qiskit.circuit.library import RXGate +from qiskit.circuit import Parameter + +target = Target() +theta = Parameter('theta') +rx_props = { + (0,): InstructionProperties(duration=5.23e-8, error=0.00038115), +} +target.add_instruction(RXGate(theta), rx_props) +rx_30_props = { + (0,): InstructionProperties(duration=1.74e-6, error=.00012) +} +target.add_instruction(RXGate(math.pi / 6), rx_30_props, name='rx_30') +``` + +Then in the `target` object accessing by `rx_30` will get the fixed angle [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") while `rx` will get the parameterized [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"). + + + This class assumes that qubit indices start at 0 and are a contiguous set if you want a submapping the bits will need to be reindexed in a new\`\`Target\`\` object. + + + + This class only supports additions of gates, qargs, and qubits. If you need to remove one of these the best option is to iterate over an existing object and create a new subset (or use one of the methods to do this). The object internally caches different views and these would potentially be invalidated by removals. + + +Create a new `Target` object + + + `qiskit.transpiler.target.Target.__init__()`’s argument `aquire_alignment` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. Instead, use the argument `acquire_alignment`, which behaves identically. + + +**Parameters** + +* **description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional string to describe the Target. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – An optional int to specify the number of qubits the backend target has. If not set it will be implicitly set based on the qargs when `add_instruction()` is called. Note this must be set if the backend target is for a noiseless simulator that doesn’t have constraints on the instructions so the transpiler knows how many qubits are available. +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The system time resolution of input signals in seconds +* **granularity** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – An integer value representing minimum pulse gate resolution in units of `dt`. A user-defined pulse gate should have duration of a multiple of this granularity value. +* **min\_length** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – An integer value representing minimum pulse gate length in units of `dt`. A user-defined pulse gate should be longer than this length. +* **pulse\_alignment** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – An integer value representing a time resolution of gate instruction starting time. Gate instruction should start at time which is a multiple of the alignment value. +* **acquire\_alignment** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – An integer value representing a time resolution of measure instruction starting time. Measure instruction should start at time which is a multiple of the alignment value. +* **qubit\_properties** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of [`QubitProperties`](qiskit.providers.QubitProperties "qiskit.providers.QubitProperties") objects defining the characteristics of each qubit on the target device. If specified the length of this list must match the number of qubits in the target, where the index in the list matches the qubit number the properties are defined for. If some qubits don’t have properties available you can set that entry to `None` +* **concurrent\_measurements** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of sets of qubits that must be measured together. This must be provided as a nested list like `[[0, 1], [2, 3, 4]]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If both `num_qubits` and `qubit_properties` are both defined and the value of `num_qubits` differs from the length of `qubit_properties`. + +## Attributes + + + +### num\_qubits + + + +### description + + + +### dt + + + +### granularity + + + +### min\_length + + + +### pulse\_alignment + + + +### acquire\_alignment + + + +### qubit\_properties + + + +### concurrent\_measurements + + + +### aquire\_alignment + +Alias of deprecated name. This will be removed. + + + The property `qiskit.transpiler.target.Target.aquire_alignment` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. Use the property `acquire_alignment` instead. + + + + +### instructions + +Get the list of tuples ``(:class:`~qiskit.circuit.Instruction`, (qargs))`` for the target + +For globally defined variable width operations the tuple will be of the form `(class, None)` where class is the actual operation class that is globally defined. + + + +### operation\_names + +Get the operation names in the target. + + + +### operations + +Get the operation class objects in the target. + + + +### physical\_qubits + +Returns a sorted list of physical\_qubits + + + +### qargs + +The set of qargs in the target. + +## Methods + +### add\_instruction + + + +`add_instruction(instruction, properties=None, name=None)` + +Add a new instruction to the [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target") + +As `Target` objects are strictly additive this is the primary method for modifying a `Target`. Typically, you will use this to fully populate a `Target` before using it in [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2"). For example: + +```python +from qiskit.circuit.library import CXGate +from qiskit.transpiler import Target, InstructionProperties + +target = Target() +cx_properties = { + (0, 1): None, + (1, 0): None, + (0, 2): None, + (2, 0): None, + (0, 3): None, + (2, 3): None, + (3, 0): None, + (3, 2): None +} +target.add_instruction(CXGate(), cx_properties) +``` + +Will add a [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") to the target with no properties (duration, error, etc) with the coupling edge list: `(0, 1), (1, 0), (0, 2), (2, 0), (0, 3), (2, 3), (3, 0), (3, 2)`. If there are properties available for the instruction you can replace the `None` value in the properties dictionary with an [`InstructionProperties`](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties") object. This pattern is repeated for each [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") the target supports. + +**Parameters** + +* **instruction** ([*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")) – The operation object to add to the map. If it’s parameterized any value of the parameter can be set. Optionally for variable width instructions (such as control flow operations such as `ForLoop` or `MCXGate`) you can specify the class. If the class is specified than the `name` argument must be specified. When a class is used the gate is treated as global and not having any properties set. +* **properties** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – A dictionary of qarg entries to an [`InstructionProperties`](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties") object for that instruction implementation on the backend. Properties are optional for any instruction implementation, if there are no [`InstructionProperties`](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties") available for the backend the value can be None. If there are no constraints on the instruction (as in a noiseless/ideal simulation) this can be set to `{None, None}` which will indicate it runs on all qubits (or all available permutations of qubits for multi-qubit gates). The first `None` indicates it applies to all qubits and the second `None` indicates there are no [`InstructionProperties`](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties") for the instruction. By default, if properties is not set it is equivalent to passing `{None: None}`. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional name to use for identifying the instruction. If not specified the [`name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") attribute of `gate` will be used. All gates in the `Target` need unique names. Backends can differentiate between different parameterization of a single gate by providing a unique name for each (e.g. “rx30”, “rx60”, \`”rx90”\`\` similar to the example in the documentation for the [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target") class). + +**Raises** + +* [**AttributeError**](https://docs.python.org/3/library/exceptions.html#AttributeError "(in Python v3.12)") – If gate is already in map +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If an operation class is passed in for `instruction` and no name is specified or `properties` is set. + +### build\_coupling\_map + + + +`build_coupling_map(two_q_gate=None, filter_idle_qubits=False)` + +Get a [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") from this target. + +If there is a mix of two qubit operations that have a connectivity constraint and those that are globally defined this will also return `None` because the globally connectivity means there is no constraint on the target. If you wish to see the constraints of the two qubit operations that have constraints you should use the `two_q_gate` argument to limit the output to the gates which have a constraint. + +**Parameters** + +* **two\_q\_gate** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional gate name for a two qubit gate in the `Target` to generate the coupling map for. If specified the output coupling map will only have edges between qubits where this gate is present. +* **filter\_idle\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `True` the output [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") will remove any qubits that don’t have any operations defined in the target. Note that using this argument will result in an output [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object which has holes in its indices which might differ from the assumptions of the class. The typical use case of this argument is to be paired with [`CouplingMap.connected_components()`](qiskit.transpiler.CouplingMap#connected_components "qiskit.transpiler.CouplingMap.connected_components") which will handle the holes as expected. + +**Returns** + +**The [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object** + +for this target. If there are no connectivity constraints in the target this will return `None`. + +**Return type** + +[CouplingMap](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If a non-two qubit gate is passed in for `two_q_gate`. +* [**IndexError**](https://docs.python.org/3/library/exceptions.html#IndexError "(in Python v3.12)") – If an Instruction not in the `Target` is passed in for `two_q_gate`. + +### durations + + + +`durations()` + +Get an InstructionDurations object from the target + +**Returns** + +**The instruction duration represented in the** + +target + +**Return type** + +[InstructionDurations](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") + +### from\_configuration + + + +`classmethod from_configuration(basis_gates, num_qubits=None, coupling_map=None, inst_map=None, backend_properties=None, instruction_durations=None, concurrent_measurements=None, dt=None, timing_constraints=None, custom_name_mapping=None)` + +Create a target object from the individual global configuration + +Prior to the creation of the [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target") class, the constraints of a backend were represented by a collection of different objects which combined represent a subset of the information contained in the [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target"). This function provides a simple interface to convert those separate objects to a [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target"). + +This constructor will use the input from `basis_gates`, `num_qubits`, and `coupling_map` to build a base model of the backend and the `instruction_durations`, `backend_properties`, and `inst_map` inputs are then queried (in that order) based on that model to look up the properties of each instruction and qubit. If there is an inconsistency between the inputs any extra or conflicting information present in `instruction_durations`, `backend_properties`, or `inst_map` will be ignored. + +**Parameters** + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – The list of basis gate names for the backend. For the target to be created these names must either be in the output from `get_standard_gate_name_mapping()` or present in the specified `custom_name_mapping` argument. +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of qubits supported on the backend. +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") *| None*) – The coupling map representing connectivity constraints on the backend. If specified all gates from `basis_gates` will be supported on all qubits (or pairs of qubits). +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") *| None*) – The instruction schedule map representing the pulse [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") definitions for each instruction. If this is specified `coupling_map` must be specified. The `coupling_map` is used as the source of truth for connectivity and if `inst_map` is used the schedule is looked up based on the instructions from the pair of `basis_gates` and `coupling_map`. If you want to define a custom gate for a particular qubit or qubit pair, you can manually build [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target"). +* **backend\_properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") *| None*) – The [`BackendProperties`](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties") object which is used for instruction properties and qubit properties. If specified and instruction properties are intended to be used then the `coupling_map` argument must be specified. This is only used to lookup error rates and durations (unless `instruction_durations` is specified which would take precedence) for instructions specified via `coupling_map` and `basis_gates`. +* **instruction\_durations** ([*InstructionDurations*](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations") *| None*) – Optional instruction durations for instructions. If specified it will take priority for setting the `duration` field in the [`InstructionProperties`](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties") objects for the instructions in the target. +* **concurrent\_measurements** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of sets of qubits that must be measured together. This must be provided as a nested list like `[[0, 1], [2, 3, 4]]`. +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – The system time resolution of input signals in seconds +* **timing\_constraints** (*TimingConstraints | None*) – Optional timing constraints to include in the [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target") +* **custom\_name\_mapping** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*, Any] | None*) – An optional dictionary that maps custom gate/operation names in `basis_gates` to an [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") object representing that gate/operation. By default, most standard gates names are mapped to the standard gate object from [`qiskit.circuit.library`](circuit_library#module-qiskit.circuit.library "qiskit.circuit.library") this only needs to be specified if the input `basis_gates` defines gates in names outside that set. + +**Returns** + +the target built from the input configuration + +**Return type** + +[Target](#qiskit.transpiler.Target "qiskit.transpiler.Target") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the input basis gates contain > 2 qubits and `coupling_map` is +* **specified.** – +* [**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – If no mapping is available for a specified `basis_gate`. + +### get + + + +`get(k[, d]) → D[k] if k in D, else d.  d defaults to None.` + +### get\_calibration + + + +`get_calibration(operation_name, qargs, *args, **kwargs)` + +Get calibrated pulse schedule for the instruction. + +If calibration is templated with parameters, one can also provide those values to build a schedule with assigned parameters. + +**Parameters** + +* **operation\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the operation for the instruction. +* **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, ...]*) – The tuple of qubit indices for the instruction. +* **args** (*ParameterValueType*) – Parameter values to build schedule if any. +* **kwargs** (*ParameterValueType*) – Parameter values with name to build schedule if any. + +**Returns** + +Calibrated pulse schedule of corresponding instruction. + +**Return type** + +[Schedule](qiskit.pulse.Schedule "qiskit.pulse.Schedule") | [ScheduleBlock](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") + +### get\_non\_global\_operation\_names + + + +`get_non_global_operation_names(strict_direction=False)` + +Return the non-global operation names for the target + +The non-global operations are those in the target which don’t apply on all qubits (for single qubit operations) or all multi-qubit qargs (for multi-qubit operations). + +**Parameters** + +**strict\_direction** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `True` the multi-qubit operations considered as non-global respect the strict direction (or order of qubits in the qargs is significant). For example, if `cx` is defined on `(0, 1)` and `ecr` is defined over `(1, 0)` by default neither would be considered non-global, but if `strict_direction` is set `True` both `cx` and `ecr` would be returned. + +**Returns** + +A list of operation names for operations that aren’t global in this target + +**Return type** + +List\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### has\_calibration + + + +`has_calibration(operation_name, qargs)` + +Return whether the instruction (operation + qubits) defines a calibration. + +**Parameters** + +* **operation\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the operation for the instruction. +* **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*, ...]*) – The tuple of qubit indices for the instruction. + +**Returns** + +Returns `True` if the calibration is supported and `False` if it isn’t. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### instruction\_properties + + + +`instruction_properties(index)` + +Get the instruction properties for a specific instruction tuple + +This method is to be used in conjunction with the [`instructions`](#qiskit.transpiler.Target.instructions "qiskit.transpiler.Target.instructions") attribute of a [`Target`](#qiskit.transpiler.Target "qiskit.transpiler.Target") object. You can use this method to quickly get the instruction properties for an element of [`instructions`](#qiskit.transpiler.Target.instructions "qiskit.transpiler.Target.instructions") by using the index in that list. However, if you’re not working with [`instructions`](#qiskit.transpiler.Target.instructions "qiskit.transpiler.Target.instructions") directly it is likely more efficient to access the target directly via the name and qubits to get the instruction properties. For example, if [`instructions`](#qiskit.transpiler.Target.instructions "qiskit.transpiler.Target.instructions") returned: + +```python +[(XGate(), (0,)), (XGate(), (1,))] +``` + +you could get the properties of the `XGate` on qubit 1 with: + +```python +props = target.instruction_properties(1) +``` + +but just accessing it directly via the name would be more efficient: + +```python +props = target['x'][(1,)] +``` + +(assuming the `XGate`’s canonical name in the target is `'x'`) This is especially true for larger targets as this will scale worse with the number of instruction tuples in a target. + +**Parameters** + +**index** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The index of the instruction tuple from the [`instructions`](#qiskit.transpiler.Target.instructions "qiskit.transpiler.Target.instructions") attribute. For, example if you want the properties from the third element in [`instructions`](#qiskit.transpiler.Target.instructions "qiskit.transpiler.Target.instructions") you would set this to be `2`. + +**Returns** + +The instruction properties for the specified instruction tuple + +**Return type** + +[InstructionProperties](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties") + +### instruction\_schedule\_map + + + +`instruction_schedule_map()` + +Return an [`InstructionScheduleMap`](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") for the instructions in the target with a pulse schedule defined. + +**Returns** + +The instruction schedule map for the instructions in this target with a pulse schedule defined. + +**Return type** + +[InstructionScheduleMap](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap") + +### instruction\_supported + + + +`instruction_supported(operation_name=None, qargs=None, operation_class=None, parameters=None)` + +Return whether the instruction (operation + qubits) is supported by the target + +**Parameters** + +* **operation\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the operation for the instruction. Either this or `operation_class` must be specified, if both are specified `operation_class` will take priority and this argument will be ignored. + +* **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – The tuple of qubit indices for the instruction. If this is not specified then this method will return `True` if the specified operation is supported on any qubits. The typical application will always have this set (otherwise it’s the same as just checking if the target contains the operation). Normally you would not set this argument if you wanted to check more generally that the target supports an operation with the `parameters` on any qubits. + +* **operation\_class** ([*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")*\[*[*qiskit.circuit.Instruction*](qiskit.circuit.Instruction "qiskit.circuit.Instruction")*]*) – The operation class to check whether the target supports a particular operation by class rather than by name. This lookup is more expensive as it needs to iterate over all operations in the target instead of just a single lookup. If this is specified it will supersede the `operation_name` argument. The typical use case for this operation is to check whether a specific variant of an operation is supported on the backend. For example, if you wanted to check whether a [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") was supported on a specific qubit with a fixed angle. That fixed angle variant will typically have a name different from the object’s [`name`](qiskit.circuit.Instruction#name "qiskit.circuit.Instruction.name") attribute (`"rx"`) in the target. This can be used to check if any instances of the class are available in such a case. + +* **parameters** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – + + A list of parameters to check if the target supports them on the specified qubits. If the instruction supports the parameter values specified in the list on the operation and qargs specified this will return `True` but if the parameters are not supported on the specified instruction it will return `False`. If this argument is not specified this method will return `True` if the instruction is supported independent of the instruction parameters. If specified with any [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") objects in the list, that entry will be treated as supporting any value, however parameter names will not be checked (for example if an operation in the target is listed as parameterized with `"theta"` and `"phi"` is passed into this function that will return `True`). For example, if called with: + + ```python + parameters = [Parameter("theta")] + target.instruction_supported("rx", (0,), parameters=parameters) + ``` + + will return `True` if an [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate") is supported on qubit 0 that will accept any parameter. If you need to check for a fixed numeric value parameter this argument is typically paired with the `operation_class` argument. For example: + + ```python + target.instruction_supported("rx", (0,), RXGate, parameters=[pi / 4]) + ``` + + will return `True` if an RXGate(pi/4) exists on qubit 0. + +**Returns** + +Returns `True` if the instruction is supported and `False` if it isn’t. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### operation\_from\_name + + + +`operation_from_name(instruction)` + +Get the operation class object for a given name + +**Parameters** + +**instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The instruction name to get the [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instance for + +**Returns** + +The Instruction instance corresponding to the name. This also can also be the class for globally defined variable with operations. + +**Return type** + +[qiskit.circuit.Instruction](qiskit.circuit.Instruction "qiskit.circuit.Instruction") + +### operation\_names\_for\_qargs + + + +`operation_names_for_qargs(qargs)` + +Get the operation names for a specified qargs tuple + +**Parameters** + +**qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – A `qargs` tuple of the qubits to get the gates that apply to it. For example, `(0,)` will return the set of all instructions that apply to qubit 0. If set to `None` this will return the names for any globally defined operations in the target. + +**Returns** + +The set of operation names that apply to the specified `qargs`. + +**Return type** + +[set](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)") + +**Raises** + +[**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – If `qargs` is not in target + +### operations\_for\_qargs + + + +`operations_for_qargs(qargs)` + +Get the operation class object for a specified qargs tuple + +**Parameters** + +**qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – A qargs tuple of the qubits to get the gates that apply to it. For example, `(0,)` will return the set of all instructions that apply to qubit 0. If set to `None` this will return any globally defined operations in the target. + +**Returns** + +The list of [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") instances that apply to the specified qarg. This may also be a class if a variable width operation is globally defined. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – If qargs is not in target + +### qargs\_for\_operation\_name + + + +`qargs_for_operation_name(operation)` + +Get the qargs for a given operation name + +**Parameters** + +**operation** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The operation name to get qargs for + +**Returns** + +The set of qargs the gate instance applies to. + +**Return type** + +[set](https://docs.python.org/3/library/stdtypes.html#set "(in Python v3.12)") + +### timing\_constraints + + + +`timing_constraints()` + +Get an `TimingConstraints` object from the target + +**Returns** + +The timing constraints represented in the `Target` + +**Return type** + +TimingConstraints + +### update\_from\_instruction\_schedule\_map + + + +`update_from_instruction_schedule_map(inst_map, inst_name_map=None, error_dict=None)` + +Update the target from an instruction schedule map. + +If the input instruction schedule map contains new instructions not in the target they will be added. However, if it contains additional qargs for an existing instruction in the target it will error. + +**Parameters** + +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap")) – The instruction + +* **inst\_name\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – An optional dictionary that maps any instruction name in `inst_map` to an instruction object. If not provided, instruction is pulled from the standard Qiskit gates, and finally custom gate instance is created with schedule name. + +* **error\_dict** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + + A dictionary of errors of the form: + + ```python + {gate_name: {qarg: error}} + ``` + +* **example::** (*for*) – \{‘rx’: \{(0, ): 1.4e-4, (1, ): 1.2e-4}} + +* **defined** (*For each entry in the inst\_map if error\_dict is*) – + +* **from** (*a when updating the Target the error value will be pulled*) – + +* **then** (*this dictionary. If one is not found in error\_dict*) – + +* **used.** (*None will be*) – + +### update\_instruction\_properties + + + +`update_instruction_properties(instruction, qargs, properties)` + +Update the property object for an instruction qarg pair already in the Target + +**Parameters** + +* **instruction** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The instruction name to update +* **qargs** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – The qargs to update the properties of +* **properties** ([*InstructionProperties*](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties")) – The properties to set for this instruction + +**Raises** + +[**KeyError**](https://docs.python.org/3/library/exceptions.html#KeyError "(in Python v3.12)") – If `instruction` or `qarg` are not in the target + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.TransformationPass.md b/docs/api/qiskit/0.46/qiskit.transpiler.TransformationPass.md new file mode 100644 index 00000000000..82de6e3781b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.TransformationPass.md @@ -0,0 +1,109 @@ +--- +title: TransformationPass +description: API reference for qiskit.transpiler.TransformationPass +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.TransformationPass +--- + +# TransformationPass + + + +`qiskit.transpiler.TransformationPass(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/basepasses.py "view source code") + +Bases: `BasePass` + +A transformation pass: change DAG, not property set. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`abstract run(dag)` + +Run a pass on the DAGCircuit. This is implemented by the pass developer. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – the dag on which the pass is run. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – when this is left unimplemented for a pass. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.TranspileLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.TranspileLayout.md new file mode 100644 index 00000000000..0415799654a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.TranspileLayout.md @@ -0,0 +1,234 @@ +--- +title: TranspileLayout +description: API reference for qiskit.transpiler.TranspileLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.TranspileLayout +--- + +# TranspileLayout + + + +`qiskit.transpiler.TranspileLayout(initial_layout, input_qubit_mapping, final_layout=None, _input_qubit_count=None, _output_qubit_list=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/layout.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Layout attributes from output circuit from transpiler. + +The transpiler in general is unitary-perserving up to permutations caused by setting and applying initial layout during the [Layout Stage](transpiler#layout-stage) and [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") insertion during the [Routing Stage](transpiler#routing-stage). To provide an interface to reason about these permutations caused by the [`transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler"). In general the normal interface to access and reason about the layout transformations made by the transpiler is to use the helper methods defined on this class. + +For example, looking at the initial layout, the transpiler can potentially remap the order of the qubits in your circuit as it fits the circuit to the target backend. If the input circuit was: + +Then during the layout stage the transpiler reorders the qubits to be: + +then the output of the [`initial_virtual_layout()`](#qiskit.transpiler.TranspileLayout.initial_virtual_layout "qiskit.transpiler.TranspileLayout.initial_virtual_layout") would be equivalent to: + +```python +Layout({ + qr[0]: 2, + qr[1]: 1, + qr[2]: 0, +}) +``` + +(it is also this attribute in the [`QuantumCircuit.draw()`](qiskit.circuit.QuantumCircuit#draw "qiskit.circuit.QuantumCircuit.draw") and [`circuit_drawer()`](qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer") which is used to display the mapping of qubits to positions in circuit visualizations post-transpilation) + +Building on this above example for final layout, if the transpiler needed to insert swap gates during routing so the output circuit became: + +then the output of the [`routing_permutation()`](#qiskit.transpiler.TranspileLayout.routing_permutation "qiskit.transpiler.TranspileLayout.routing_permutation") method would be: + +```python +[1, 0, 2] +``` + +which maps the qubits at each position to their final position after any swap insertions caused by routing. + +There are three public attributes associated with the class, however these are mostly provided for backwards compatibility and represent the internal state from the transpiler. They are defined as: + +> * [`initial_layout`](#qiskit.transpiler.TranspileLayout.initial_layout "qiskit.transpiler.TranspileLayout.initial_layout") - This attribute is used to model the permutation caused by the [Layout Stage](transpiler#layout-stage) it contains a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object that maps the input [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")s [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects to the position in the output `QuantumCircuit.qubits` list. +> * [`input_qubit_mapping`](#qiskit.transpiler.TranspileLayout.input_qubit_mapping "qiskit.transpiler.TranspileLayout.input_qubit_mapping") - This attribute is used to retain input ordering of the original [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object. It maps the virtual [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit") object from the original circuit (and [`initial_layout`](#qiskit.transpiler.TranspileLayout.initial_layout "qiskit.transpiler.TranspileLayout.initial_layout")) to its corresponding position in [`QuantumCircuit.qubits`](qiskit.circuit.QuantumCircuit#qubits "qiskit.circuit.QuantumCircuit.qubits") in the original circuit. This is needed when computing the permutation of the `Operator` of the circuit (and used by [`Operator.from_circuit()`](qiskit.quantum_info.Operator#from_circuit "qiskit.quantum_info.Operator.from_circuit")). +> * [`final_layout`](#qiskit.transpiler.TranspileLayout.final_layout "qiskit.transpiler.TranspileLayout.final_layout") - This is a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object used to model the output permutation caused ny any [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate")s inserted into the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") during the [Routing Stage](transpiler#routing-stage). It maps the output circuit’s qubits from `QuantumCircuit.qubits` in the output circuit to the final position after routing. It is **not** a mapping from the original input circuit’s position to the final position at the end of the transpiled circuit. If you need this you can use the [`final_index_layout()`](#qiskit.transpiler.TranspileLayout.final_index_layout "qiskit.transpiler.TranspileLayout.final_index_layout") to generate this. If this is set to `None` this indicates that routing was not run and it can be considered equivalent to a trivial layout with the qubits from the output circuit’s [`qubits`](qiskit.circuit.QuantumCircuit#qubits "qiskit.circuit.QuantumCircuit.qubits") list. + +## Attributes + + + +### final\_layout + +`Layout | None` + +`= None` + + + +### initial\_layout + +`Layout` + + + +### input\_qubit\_mapping + +`dict[Qubit, int]` + +## Methods + +### final\_index\_layout + + + +`final_index_layout(filter_ancillas=True)` + +Generate the final layout as an array of integers + +This method will generate an array of final positions for each qubit in the output circuit. For example, if you had an input circuit like: + +```python +qc = QuantumCircuit(3) +qc.h(0) +qc.cx(0, 1) +qc.cx(0, 2) +``` + +and the output from the transpiler was: + +```python +tqc = QuantumCircuit(3) +qc.h(2) +qc.cx(2, 1) +qc.swap(0, 1) +qc.cx(2, 1) +``` + +then the return from this function would be a list of: + +```python +[2, 0, 1] +``` + +because qubit 0 in the original circuit’s final state is on qubit 3 in the output circuit, qubit 1 in the original circuit’s final state is on qubit 0, and qubit 2’s final state is on qubit. The output list length will be as wide as the input circuit’s number of qubits, as the output list from this method is for tracking the permutation of qubits in the original circuit caused by the transpiler. + +**Parameters** + +**filter\_ancillas** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `False` any ancillas allocated in the output circuit will be included in the layout. + +**Returns** + +A list of final positions for each input circuit qubit + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + +### final\_virtual\_layout + + + +`final_virtual_layout(filter_ancillas=True)` + +Generate the final layout as a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object + +This method will generate an array of final positions for each qubit in the output circuit. For example, if you had an input circuit like: + +```python +qc = QuantumCircuit(3) +qc.h(0) +qc.cx(0, 1) +qc.cx(0, 2) +``` + +and the output from the transpiler was: + +```python +tqc = QuantumCircuit(3) +qc.h(2) +qc.cx(2, 1) +qc.swap(0, 1) +qc.cx(2, 1) +``` + +then the return from this function would be a layout object: + +```python +Layout({ + qc.qubits[0]: 2, + qc.qubits[1]: 0, + qc.qubits[2]: 1, +}) +``` + +because qubit 0 in the original circuit’s final state is on qubit 3 in the output circuit, qubit 1 in the original circuit’s final state is on qubit 0, and qubit 2’s final state is on qubit. The output list length will be as wide as the input circuit’s number of qubits, as the output list from this method is for tracking the permutation of qubits in the original circuit caused by the transpiler. + +**Parameters** + +**filter\_ancillas** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `False` any ancillas allocated in the output circuit will be included in the layout. + +**Returns** + +A layout object mapping to the final positions for each qubit + +**Return type** + +[*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.layout.Layout") + +### initial\_index\_layout + + + +`initial_index_layout(filter_ancillas=False)` + +Generate an initial layout as an array of integers + +**Parameters** + +**filter\_ancillas** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `True` any ancilla qubits added to the transpiler will not be included in the output. + +**Returns** + +A layout array that maps a position in the array to its new position in the output circuit. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + +### initial\_virtual\_layout + + + +`initial_virtual_layout(filter_ancillas=False)` + +Return a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object for the initial layout. + +This returns a mapping of virtual [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects in the input circuit to the physical qubit selected during layout. This is analogous to the [`initial_layout`](#qiskit.transpiler.TranspileLayout.initial_layout "qiskit.transpiler.TranspileLayout.initial_layout") attribute. + +**Parameters** + +**filter\_ancillas** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `True` only qubits in the input circuit will be in the returned layout. Any ancilla qubits added to the output circuit will be filtered from the returned object. + +**Returns** + +A layout object mapping the input circuit’s [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit") objects to the selected physical qubits. + +**Return type** + +[*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.layout.Layout") + +### routing\_permutation + + + +`routing_permutation()` + +Generate a final layout as an array of integers + +If there is no [`final_layout`](#qiskit.transpiler.TranspileLayout.final_layout "qiskit.transpiler.TranspileLayout.final_layout") attribute present then that indicates there was no output permutation caused by routing or other transpiler transforms. In this case the function will return a list of `[0, 1, 2, .., n]` to indicate this + +**Returns** + +A layout array that maps a position in the array to its new position in the output circuit + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")] + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPSchedule.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPSchedule.md new file mode 100644 index 00000000000..dea752a400c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPSchedule.md @@ -0,0 +1,130 @@ +--- +title: ALAPSchedule +description: API reference for qiskit.transpiler.passes.ALAPSchedule +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ALAPSchedule +--- + +# ALAPSchedule + + + +`qiskit.transpiler.passes.ALAPSchedule(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/alap.py "view source code") + +Bases: `BaseSchedulerTransform` + +ALAP Scheduling pass, which schedules the **stop** time of instructions as late as possible. + +See `BaseSchedulerTransform` for the detailed behavior of the control flow operation, i.e. `c_if`. + + + The class `qiskit.transpiler.passes.scheduling.alap.ALAPSchedule` is pending deprecation as of qiskit 0.21.0. It will be marked deprecated in a future release, and then removed no earlier than 3 months after the release date. Instead, use [`ALAPScheduleAnalysis`](qiskit.transpiler.passes.ALAPScheduleAnalysis "qiskit.transpiler.passes.ALAPScheduleAnalysis"), which is an analysis pass that requires a padding pass to later modify the circuit. + + +## Attributes + + + +### CONDITIONAL\_SUPPORTED + +`= (, )` + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the ALAPSchedule pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A scheduled DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the circuit is not mapped on physical qubits. +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if conditional bit is added to non-supported instruction. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPScheduleAnalysis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPScheduleAnalysis.md new file mode 100644 index 00000000000..d743b2093d3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ALAPScheduleAnalysis.md @@ -0,0 +1,133 @@ +--- +title: ALAPScheduleAnalysis +description: API reference for qiskit.transpiler.passes.ALAPScheduleAnalysis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ALAPScheduleAnalysis +--- + +# ALAPScheduleAnalysis + + + +`qiskit.transpiler.passes.ALAPScheduleAnalysis(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/scheduling/alap.py "view source code") + +Bases: `BaseScheduler` + +ALAP Scheduling pass, which schedules the **stop** time of instructions as late as possible. + +See the [Scheduling Stage](transpiler#scheduling-stage) section in the [`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler") module documentation for the detailed behavior of the control flow operation, i.e. `c_if`. + +Scheduler initializer. + +**Parameters** + +* **durations** – Durations of instructions to be used in scheduling +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `durations` and this are specified then this argument will take precedence and `durations` will be ignored. + +## Attributes + + + +### CONDITIONAL\_SUPPORTED + +`= (, )` + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the ALAPSchedule pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A scheduled DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the circuit is not mapped on physical qubits. +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if conditional bit is added to non-supported instruction. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.AQCSynthesisPlugin.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.AQCSynthesisPlugin.md new file mode 100644 index 00000000000..f3e4b6e696a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.AQCSynthesisPlugin.md @@ -0,0 +1,181 @@ +--- +title: AQCSynthesisPlugin +description: API reference for qiskit.transpiler.passes.AQCSynthesisPlugin +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.AQCSynthesisPlugin +--- + +# AQCSynthesisPlugin + + + +`qiskit.transpiler.passes.AQCSynthesisPlugin`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/aqc_plugin.py "view source code") + +Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") + +An AQC-based Qiskit unitary synthesis plugin. + +This plugin is invoked by [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") when the `unitary_synthesis_method` parameter is set to `"aqc"`. + +This plugin supports customization and additional parameters can be passed to the plugin by passing a dictionary as the `unitary_synthesis_plugin_config` parameter of the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function. + +Supported parameters in the dictionary: + +**network\_layout (str)** + +Type of network geometry, one of \{`"sequ"`, `"spin"`, `"cart"`, `"cyclic_spin"`, `"cyclic_line"`}. Default value is `"spin"`. + +**connectivity\_type (str)** + +type of inter-qubit connectivity, \{`"full"`, `"line"`, `"star"`}. Default value is `"full"`. + +**depth (int)** + +depth of the CNOT-network, i.e. the number of layers, where each layer consists of a single CNOT-block. + +**optimizer ([`Optimizer`](qiskit.algorithms.optimizers.Optimizer "qiskit.algorithms.optimizers.Optimizer"))** + +An instance of optimizer to be used in the optimization process. + +**seed (int)** + +A random seed. + +**initial\_point ([`ndarray`](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)"))** + +Initial values of angles/parameters to start the optimization process from. + +## Attributes + + + +### max\_qubits + +Maximum number of supported qubits is `14`. + + + +### min\_qubits + +Minimum number of supported qubits is `3`. + + + +### supported\_bases + +The plugin does not support bases for synthesis. + + + +### supports\_basis\_gates + +The plugin does not support basis gates and by default it synthesizes a circuit using `["rx", "ry", "rz", "cx"]` gate basis. + + + +### supports\_coupling\_map + +The plugin does not support coupling maps. + + + +### supports\_gate\_errors + +The plugin does not support gate errors. + + + +### supports\_gate\_errors\_by\_qubit + +Return whether the plugin supports taking `gate_errors_by_qubit` + +This differs from `supports_gate_errors`/`gate_errors` by using a different view of the same data. Instead of being keyed by gate name this is keyed by qubit and uses [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to represent gates (instead of gate names). + +`gate_errors_by_qubit` will be a dictionary in the form of `{(qubits,): [Gate, error]}`. For example: + +```python +{ +(0,): [SXGate(): 0.0006149355812506126, RZGate(): 0.0], +(0, 1): [CXGate(): 0.012012477900732316] +} +``` + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate errors on every gate for each qubit. The gate error rates reported in `gate_errors` are provided by the target device `Backend` object and the exact meaning might be different depending on the backend. + +This defaults to False + + + +### supports\_gate\_lengths + +The plugin does not support gate lengths. + + + +### supports\_gate\_lengths\_by\_qubit + +Return whether the plugin supports taking `gate_lengths_by_qubit` + +This differs from `supports_gate_lengths`/`gate_lengths` by using a different view of the same data. Instead of being keyed by gate name this is keyed by qubit and uses [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to represent gates (instead of gate names) + +`gate_lengths_by_qubit` will be a dictionary in the form of `{(qubits,): [Gate, length]}`. For example: + +```python +{ +(0,): [SXGate(): 0.0006149355812506126, RZGate(): 0.0], +(0, 1): [CXGate(): 0.012012477900732316] +} +``` + +where the `length` value is in units of seconds. + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate lengths on every gate for each qubit. + +This defaults to False + + + +### supports\_natural\_direction + +The plugin does not support natural direction, it assumes bidirectional two qubit gates. + + + +### supports\_pulse\_optimize + +The plugin does not support optimization of pulses. + + + +### supports\_target + +Whether the plugin supports taking `target` as an option + +`target` will be a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the target device for the output of the synthesis pass. + +By default this will be `False` since the plugin interface predates the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") class. If a plugin returns `True` for this attribute, it is expected that the plugin will use the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") instead of the values passed if any of `supports_gate_lengths`, `supports_gate_errors`, `supports_coupling_map`, and `supports_basis_gates` are set (although ideally all those parameters should contain duplicate information). + +## Methods + +### run + + + +`run(unitary, **options)` + +Run synthesis for the given unitary matrix + +**Parameters** + +* **unitary** ([*numpy.ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – The unitary matrix to synthesize to a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object +* **options** – The optional kwargs that are passed based on the output the `support_*` methods on the class. Refer to the documentation for these methods on [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") to see what the keys and values are. + +**Returns** + +The dag circuit representation of the unitary. Alternatively, you can return a tuple of the form `(dag, wires)` where `dag` is the dag circuit representation of the circuit representation of the unitary and `wires` is the mapping wires to use for [`qiskit.dagcircuit.DAGCircuit.substitute_node_with_dag()`](qiskit.dagcircuit.DAGCircuit#substitute_node_with_dag "qiskit.dagcircuit.DAGCircuit.substitute_node_with_dag"). If you return a tuple and `wires` is `None` this will behave just as if only a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") was returned. Additionally if this returns `None` no substitution will be made. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPSchedule.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPSchedule.md new file mode 100644 index 00000000000..803befb9bba --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPSchedule.md @@ -0,0 +1,134 @@ +--- +title: ASAPSchedule +description: API reference for qiskit.transpiler.passes.ASAPSchedule +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ASAPSchedule +--- + +# ASAPSchedule + + + +`qiskit.transpiler.passes.ASAPSchedule(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/asap.py "view source code") + +Bases: `BaseSchedulerTransform` + +ASAP Scheduling pass, which schedules the start time of instructions as early as possible.. + +See `BaseSchedulerTransform` for the detailed behavior of the control flow operation, i.e. `c_if`. + + + This base class has been superseded by [`ASAPScheduleAnalysis`](qiskit.transpiler.passes.ASAPScheduleAnalysis "qiskit.transpiler.passes.ASAPScheduleAnalysis") and the new scheduling workflow. It will be deprecated and subsequently removed in a future release. + + + + The class `qiskit.transpiler.passes.scheduling.asap.ASAPSchedule` is pending deprecation as of qiskit 0.21.0. It will be marked deprecated in a future release, and then removed no earlier than 3 months after the release date. Instead, use [`ASAPScheduleAnalysis`](qiskit.transpiler.passes.ASAPScheduleAnalysis "qiskit.transpiler.passes.ASAPScheduleAnalysis"), which is an analysis pass that requires a padding pass to later modify the circuit. + + +## Attributes + + + +### CONDITIONAL\_SUPPORTED + +`= (, )` + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the ASAPSchedule pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A scheduled DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the circuit is not mapped on physical qubits. +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if conditional bit is added to non-supported instruction. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPScheduleAnalysis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPScheduleAnalysis.md new file mode 100644 index 00000000000..e18b8a604d8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ASAPScheduleAnalysis.md @@ -0,0 +1,133 @@ +--- +title: ASAPScheduleAnalysis +description: API reference for qiskit.transpiler.passes.ASAPScheduleAnalysis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ASAPScheduleAnalysis +--- + +# ASAPScheduleAnalysis + + + +`qiskit.transpiler.passes.ASAPScheduleAnalysis(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/scheduling/asap.py "view source code") + +Bases: `BaseScheduler` + +ASAP Scheduling pass, which schedules the start time of instructions as early as possible. + +See the [Scheduling Stage](transpiler#scheduling-stage) section in the [`qiskit.transpiler`](transpiler#module-qiskit.transpiler "qiskit.transpiler") module documentation for the detailed behavior of the control flow operation, i.e. `c_if`. + +Scheduler initializer. + +**Parameters** + +* **durations** – Durations of instructions to be used in scheduling +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `durations` and this are specified then this argument will take precedence and `durations` will be ignored. + +## Attributes + + + +### CONDITIONAL\_SUPPORTED + +`= (, )` + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the ASAPSchedule pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A scheduled DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the circuit is not mapped on physical qubits. +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if conditional bit is added to non-supported instruction. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.AlignMeasures.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.AlignMeasures.md new file mode 100644 index 00000000000..3087553a531 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.AlignMeasures.md @@ -0,0 +1,165 @@ +--- +title: AlignMeasures +description: API reference for qiskit.transpiler.passes.AlignMeasures +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.AlignMeasures +--- + +# AlignMeasures + + + +`qiskit.transpiler.passes.AlignMeasures(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/alignments/align_measures.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Measurement alignment. + +This is a control electronics aware optimization pass. + +In many quantum computing architectures gates (instructions) are implemented with shaped analog stimulus signals. These signals are digitally stored in the waveform memory of the control electronics and converted into analog voltage signals by electronic components called digital to analog converters (DAC). + +In a typical hardware implementation of superconducting quantum processors, a single qubit instruction is implemented by a microwave signal with the duration of around several tens of ns with a per-sample time resolution of \~0.1-10ns, as reported by `backend.configuration().dt`. In such systems requiring higher DAC bandwidth, control electronics often defines a pulse granularity, in other words a data chunk, to allow the DAC to perform the signal conversion in parallel to gain the bandwidth. + +Measurement alignment is required if a backend only allows triggering `measure` instructions at a certain multiple value of this pulse granularity. This value is usually provided by `backend.configuration().timing_constraints`. + +In Qiskit SDK, the duration of delay can take arbitrary value in units of `dt`, thus circuits involving delays may violate the above alignment constraint (i.e. misalignment). This pass shifts measurement instructions to a new time position to fix the misalignment, by inserting extra delay right before the measure instructions. The input of this pass should be scheduled [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit"), thus one should select one of the scheduling passes ([`ALAPSchedule`](qiskit.transpiler.passes.ALAPSchedule "qiskit.transpiler.passes.ALAPSchedule") or `ASAPSchedule`) before calling this. + +**Examples** + +We assume executing the following circuit on a backend with `alignment=16`. + +```python + ┌───┐┌────────────────┐┌─┐ +q_0: ┤ X ├┤ Delay(100[dt]) ├┤M├ + └───┘└────────────────┘└╥┘ +c: 1/════════════════════════╩═ + 0 +``` + +Note that delay of 100 dt induces a misalignment of 4 dt at the measurement. This pass appends an extra 12 dt time shift to the input circuit. + +```python + ┌───┐┌────────────────┐┌─┐ +q_0: ┤ X ├┤ Delay(112[dt]) ├┤M├ + └───┘└────────────────┘└╥┘ +c: 1/════════════════════════╩═ + 0 +``` + +This pass always inserts a positive delay before measurements rather than reducing other delays. + +**Notes** + +The Backend may allow users to execute circuits violating the alignment constraint. However, it may return meaningless measurement data mainly due to the phase error. + +Create new pass. + + + The class `qiskit.transpiler.passes.scheduling.alignments.align_measures.AlignMeasures` is pending deprecation as of qiskit 0.21.0. It will be marked deprecated in a future release, and then removed no earlier than 3 months after the release date. Instead, use [`ConstrainedReschedule`](qiskit.transpiler.passes.ConstrainedReschedule "qiskit.transpiler.passes.ConstrainedReschedule"), which performs the same function but also supports aligning to additional timing constraints. + + +**Parameters** + +**alignment** – Integer number representing the minimum time resolution to trigger measure instruction in units of `dt`. This value depends on the control electronics of your quantum processor. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the measurement alignment pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to be checked. + +**Returns** + +DAG with consistent timing and op nodes annotated with duration. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If circuit is not scheduled. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ApplyLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ApplyLayout.md new file mode 100644 index 00000000000..2b9c0b75e3e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ApplyLayout.md @@ -0,0 +1,121 @@ +--- +title: ApplyLayout +description: API reference for qiskit.transpiler.passes.ApplyLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ApplyLayout +--- + +# ApplyLayout + + + +`qiskit.transpiler.passes.ApplyLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/apply_layout.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Transform a circuit with virtual qubits into a circuit with physical qubits. + +Transforms a DAGCircuit with virtual qubits into a DAGCircuit with physical qubits by applying the Layout given in property\_set. Requires either of passes to set/select Layout, e.g. SetLayout, TrivialLayout. Assumes the Layout has full physical qubits. + +If a post layout pass is run and sets the `post_layout` property set field with a new layout to use after `ApplyLayout` has already run once this pass will compact the layouts so that we apply `original_virtual` -> `existing_layout` -> `new_layout` -> `new_physical` so that the output circuit and layout combination become: `original_virtual` -> `new_physical` + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the ApplyLayout pass on `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to map. + +**Returns** + +A mapped DAG (with physical qubits). + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if no layout is found in `property_set` or no full physical qubits. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.md new file mode 100644 index 00000000000..c9f0f84a8f6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.BarrierBeforeFinalMeasurements.md @@ -0,0 +1,103 @@ +--- +title: BarrierBeforeFinalMeasurements +description: API reference for qiskit.transpiler.passes.BarrierBeforeFinalMeasurements +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.BarrierBeforeFinalMeasurements +--- + +# BarrierBeforeFinalMeasurements + + + +`qiskit.transpiler.passes.BarrierBeforeFinalMeasurements(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/barrier_before_final_measurements.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Add a barrier before final measurements. + +This pass adds a barrier before the set of final measurements. Measurements are considered final if they are followed by no other operations (aside from other measurements or barriers.) + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the BarrierBeforeFinalMeasurements pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.BasicSwap.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.BasicSwap.md new file mode 100644 index 00000000000..52229033d68 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.BasicSwap.md @@ -0,0 +1,127 @@ +--- +title: BasicSwap +description: API reference for qiskit.transpiler.passes.BasicSwap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.BasicSwap +--- + +# BasicSwap + + + +`qiskit.transpiler.passes.BasicSwap(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/routing/basic_swap.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Map (with minimum effort) a DAGCircuit onto a `coupling_map` adding swap gates. + +The basic mapper is a minimum effort to insert swap gates to map the DAG onto a coupling map. When a cx is not in the coupling map possibilities, it inserts one or more swaps in front to make it compatible. + +BasicSwap initializer. + +**Parameters** + +* **coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – Directed graph represented a coupling map. +* **fake\_run** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if true, it will only pretend to do routing, i.e., no swap is effectively added. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the BasicSwap pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to map. + +**Returns** + +A mapped DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the coupling map or the layout are not +* **compatible with the DAG**\*\*, or \*\***if the coupling\_map=None.** – + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.BasisTranslator.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.BasisTranslator.md new file mode 100644 index 00000000000..6177675f1f6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.BasisTranslator.md @@ -0,0 +1,172 @@ +--- +title: BasisTranslator +description: API reference for qiskit.transpiler.passes.BasisTranslator +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.BasisTranslator +--- + +# BasisTranslator + + + +`qiskit.transpiler.passes.BasisTranslator(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/basis/basis_translator.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Translates gates to a target basis by searching for a set of translations from a given EquivalenceLibrary. + +This pass operates in several steps: + +* Determine the source basis from the input circuit. +* Perform a Dijkstra search over basis sets, starting from the device’s target\_basis new gates are being generated using the rules from the provided EquivalenceLibrary and the search stops if all gates in the source basis have been generated. +* The found path, as a set of rules from the EquivalenceLibrary, is composed into a set of gate replacement rules. +* The composed replacement rules are applied in-place to each op node which is not already in the target\_basis. + +If the target keyword argument is specified and that [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") objects contains operations which are non-global (i.e. they are defined only for a subset of qubits), as calculated by [`get_non_global_operation_names()`](qiskit.transpiler.Target#get_non_global_operation_names "qiskit.transpiler.Target.get_non_global_operation_names"), this pass will attempt to match the output translation to those constraints. For 1 qubit operations this is straightforward, the pass will perform a search using the union of the set of global operations with the set of operations defined solely on that qubit. For multi-qubit gates this is a bit more involved, while the behavior is initially similar to the single qubit case, just using all the qubits the operation is run on (where order is not significant) isn’t sufficient. We also need to consider any potential local qubits defined on subsets of the quantum arguments for the multi-qubit operation. This means the target used for the search of a non-global multi-qubit gate is the union of global operations, non-global multi-qubit gates sharing the same qubits, and any non-global gates defined on any subset of the qubits used. + + + In the case of non-global operations it is possible for a single execution of this pass to output an incomplete translation if any non-global gates are defined on qubits that are a subset of a larger multi-qubit gate. For example, if you have a `u` gate only defined on qubit 0 and an `x` gate only on qubit 1 it is possible when translating a 2 qubit operation on qubit 0 and 1 that the output might have `u` on qubit 1 and `x` on qubit 0. Typically running this pass a second time will correct these issues. + + + + +## Translation Errors + +This pass will error if there is no path to translate an input gate to the specified basis. However, during a typical/default preset passmanager this pass gets run multiple times at different stages of the compilation pipeline. This means that potentially the input gates that are getting translated were not in the input circuit to [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") as they were generated by an intermediate transform in the circuit. + +When this error occurs it typically means that either the target basis is not universal or there are additional equivalence rules needed in the :clas:\~.EquivalenceLibrary\` instance being used by the :class:\~.BasisTranslator\` pass. You can refer to [Custom Basis Gates](providers#custom-basis-gates) for details on adding custom equivalence rules. + +Initialize a BasisTranslator instance. + +**param equivalence\_library** + +The equivalence library which will be used by the BasisTranslator pass. (Instructions in this library will not be unrolled by this pass.) + +**type equivalence\_library** + +EquivalenceLibrary + +**param target\_basis** + +Target basis names to unroll to, e.g. \[‘u3’, ‘cx’]. + +**type target\_basis** + +list\[str] + +**param target** + +The backend compilation target + +**type target** + +Target + +**param min\_qubits** + +The minimum number of qubits for operations in the input dag to translate. + +**type min\_qubits** + +int + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Translate an input DAGCircuit to the target basis. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – input dag + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the target basis cannot be reached + +**Returns** + +translated circuit. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CSPLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CSPLayout.md new file mode 100644 index 00000000000..1d90d862ef5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CSPLayout.md @@ -0,0 +1,118 @@ +--- +title: CSPLayout +description: API reference for qiskit.transpiler.passes.CSPLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CSPLayout +--- + +# CSPLayout + + + +`qiskit.transpiler.passes.CSPLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/csp_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +If possible, chooses a Layout as a CSP, using backtracking. + +If possible, chooses a Layout as a CSP, using backtracking. + +If not possible, does not set the layout property. In all the cases, the property CSPLayout\_stop\_reason will be added with one of the following values: + +* solution found: If a perfect layout was found. +* nonexistent solution: If no perfect layout was found and every combination was checked. +* call limit reached: If no perfect layout was found and the call limit was reached. +* time limit reached: If no perfect layout was found and the time limit was reached. + +**Parameters** + +* **coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – Directed graph representing a coupling map. +* **strict\_direction** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, considers the direction of the coupling map. Default is False. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Sets the seed of the PRNG. +* **call\_limit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Amount of times that `constraint.RecursiveBacktrackingSolver.recursiveBacktracking` will be called. None means no call limit. Default: 1000. +* **time\_limit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Amount of seconds that the pass will try to find a solution. None means no time limit. Default: 10 seconds. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +run the layout method + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CXCancellation.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CXCancellation.md new file mode 100644 index 00000000000..4e20f47fe1e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CXCancellation.md @@ -0,0 +1,113 @@ +--- +title: CXCancellation +description: API reference for qiskit.transpiler.passes.CXCancellation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CXCancellation +--- + +# CXCancellation + + + +`qiskit.transpiler.passes.CXCancellation(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/cx_cancellation.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Cancel back-to-back `cx` gates in dag. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CXCancellation pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the directed acyclic graph to run on. + +**Returns** + +Transformed DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckGateDirection.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckGateDirection.md new file mode 100644 index 00000000000..725054bb616 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckGateDirection.md @@ -0,0 +1,114 @@ +--- +title: CheckGateDirection +description: API reference for qiskit.transpiler.passes.CheckGateDirection +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CheckGateDirection +--- + +# CheckGateDirection + + + +`qiskit.transpiler.passes.CheckGateDirection(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/check_gate_direction.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Check if the two-qubit gates follow the right direction with respect to the coupling map. + +CheckGateDirection initializer. + +**Parameters** + +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – Directed graph representing a coupling map. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The backend target to use for this pass. If this is specified it will be used instead of the coupling map + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CheckGateDirection pass on dag. + +If dag is mapped and the direction is correct the property is\_direction\_mapped is set to True (or to False otherwise). + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to check. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckMap.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckMap.md new file mode 100644 index 00000000000..a119b90de02 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CheckMap.md @@ -0,0 +1,116 @@ +--- +title: CheckMap +description: API reference for qiskit.transpiler.passes.CheckMap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CheckMap +--- + +# CheckMap + + + +`qiskit.transpiler.passes.CheckMap(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/check_map.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Check if a DAG circuit is already mapped to a coupling map. + +Check if a DAGCircuit is mapped to `coupling_map` by checking that all 2-qubit interactions are laid out to be on adjacent qubits in the global coupling map of the device, setting the property set field (either specified with `property_set_field` or the default `is_swap_mapped`) to `True` or `False` accordingly. Note this does not validate directionality of the connectivity between qubits. If you need to check gates are implemented in a native direction for a target use the [`CheckGateDirection`](qiskit.transpiler.passes.CheckGateDirection "qiskit.transpiler.passes.CheckGateDirection") pass instead. + +CheckMap initializer. + +**Parameters** + +* **coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – Directed graph representing a coupling map. +* **property\_set\_field** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – An optional string to specify the property set field to store the result of the check. If not default the result is stored in `"is_swap_mapped"`. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CheckMap pass on dag. + +If dag is mapped to coupling\_map, the property is\_swap\_mapped is set to True (or to False otherwise). + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to map. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect1qRuns.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect1qRuns.md new file mode 100644 index 00000000000..6d0e5dda78b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect1qRuns.md @@ -0,0 +1,105 @@ +--- +title: Collect1qRuns +description: API reference for qiskit.transpiler.passes.Collect1qRuns +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Collect1qRuns +--- + +# Collect1qRuns + + + +`qiskit.transpiler.passes.Collect1qRuns(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/collect_1q_runs.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Collect one-qubit subcircuits. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Collect1qBlocks pass on dag. + +The blocks contain “op” nodes in topological order such that all gates in a block act on the same qubits and are adjacent in the circuit. + +After the execution, `property_set['run_list']` is set to a list of tuples of “op” node. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect2qBlocks.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect2qBlocks.md new file mode 100644 index 00000000000..8f4f6f698b9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Collect2qBlocks.md @@ -0,0 +1,105 @@ +--- +title: Collect2qBlocks +description: API reference for qiskit.transpiler.passes.Collect2qBlocks +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Collect2qBlocks +--- + +# Collect2qBlocks + + + +`qiskit.transpiler.passes.Collect2qBlocks(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/collect_2q_blocks.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Collect two-qubit subcircuits. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Collect2qBlocks pass on dag. + +The blocks contain “op” nodes in topological order such that all gates in a block act on the same qubits and are adjacent in the circuit. + +After the execution, `property_set['block_list']` is set to a list of tuples of “op” node. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectCliffords.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectCliffords.md new file mode 100644 index 00000000000..776560a4f0e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectCliffords.md @@ -0,0 +1,119 @@ +--- +title: CollectCliffords +description: API reference for qiskit.transpiler.passes.CollectCliffords +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CollectCliffords +--- + +# CollectCliffords + + + +`qiskit.transpiler.passes.CollectCliffords(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/collect_cliffords.py "view source code") + +Bases: `CollectAndCollapse` + +Collects blocks of Clifford gates and replaces them by a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") object. + +CollectCliffords initializer. + +**Parameters** + +* **do\_commutative\_analysis** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, exploits commutativity relations between nodes. +* **split\_blocks** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, splits collected blocks into sub-blocks over disjoint qubit subsets. +* **min\_block\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – specifies the minimum number of gates in the block for the block to be collected. +* **split\_layers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, splits collected blocks into sub-blocks over disjoint qubit subsets. +* **collect\_from\_back** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – specifies if blocks should be collected started from the end of the circuit. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CollectLinearFunctions pass on dag. :param dag: the DAG to be optimized. :type dag: DAGCircuit + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectLinearFunctions.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectLinearFunctions.md new file mode 100644 index 00000000000..e1cd3282961 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectLinearFunctions.md @@ -0,0 +1,119 @@ +--- +title: CollectLinearFunctions +description: API reference for qiskit.transpiler.passes.CollectLinearFunctions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CollectLinearFunctions +--- + +# CollectLinearFunctions + + + +`qiskit.transpiler.passes.CollectLinearFunctions(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/collect_linear_functions.py "view source code") + +Bases: `CollectAndCollapse` + +Collect blocks of linear gates ([`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") and [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") gates) and replaces them by linear functions ([`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction")). + +CollectLinearFunctions initializer. + +**Parameters** + +* **do\_commutative\_analysis** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, exploits commutativity relations between nodes. +* **split\_blocks** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, splits collected blocks into sub-blocks over disjoint qubit subsets. +* **min\_block\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – specifies the minimum number of gates in the block for the block to be collected. +* **split\_layers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, splits collected blocks into sub-blocks over disjoint qubit subsets. +* **collect\_from\_back** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – specifies if blocks should be collected started from the end of the circuit. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CollectLinearFunctions pass on dag. :param dag: the DAG to be optimized. :type dag: DAGCircuit + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectMultiQBlocks.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectMultiQBlocks.md new file mode 100644 index 00000000000..19d1ff2c242 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CollectMultiQBlocks.md @@ -0,0 +1,133 @@ +--- +title: CollectMultiQBlocks +description: API reference for qiskit.transpiler.passes.CollectMultiQBlocks +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CollectMultiQBlocks +--- + +# CollectMultiQBlocks + + + +`qiskit.transpiler.passes.CollectMultiQBlocks(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/collect_multiqubit_blocks.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Collect sequences of uninterrupted gates acting on groups of qubits. `max_block_size` specifies the maximum number of qubits that can be acted upon by any single group of gates + +Traverse the DAG and find blocks of gates that act consecutively on groups of qubits. Write the blocks to `property_set` as a list of blocks of the form: + +```python +[[g0, g1, g2], [g4, g5]] +``` + +Blocks are reported in a valid topological order. Further, the gates within each block are also reported in topological order Some gates may not be present in any block (e.g. if the number of operands is greater than `max_block_size`) + +A Disjoint Set Union data structure (DSU) is used to maintain blocks as gates are processed. This data structure points each qubit to a set at all times and the sets correspond to current blocks. These change over time and the data structure allows these changes to be done quickly. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### find\_set + + + +`find_set(index)` + +DSU function for finding root of set of items If my parent is myself, I am the root. Otherwise we recursively find the root for my parent. After that, we assign my parent to be my root, saving recursion in the future. + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CollectMultiQBlocks pass on dag. + +The blocks contain “op” nodes in topological sort order such that all gates in a block act on the same set of qubits and are adjacent in the circuit. + +The blocks are built by examining predecessors and successors of “cx” gates in the circuit. u1, u2, u3, cx, id gates will be included. + +After the execution, `property_set['block_list']` is set to a list of tuples of `DAGNode` objects + +### union\_set + + + +`union_set(set1, set2)` + +DSU function for unioning two sets together Find the roots of each set. Then assign one to have the other as its parent, thus liking the sets. Merges smaller set into larger set in order to have better runtime + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutationAnalysis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutationAnalysis.md new file mode 100644 index 00000000000..9eec3185624 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutationAnalysis.md @@ -0,0 +1,105 @@ +--- +title: CommutationAnalysis +description: API reference for qiskit.transpiler.passes.CommutationAnalysis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CommutationAnalysis +--- + +# CommutationAnalysis + + + +`qiskit.transpiler.passes.CommutationAnalysis(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/commutation_analysis.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Analysis pass to find commutation relations between DAG nodes. + +`property_set['commutation_set']` is a dictionary that describes the commutation relations on a given wire, all the gates on a wire are grouped into a set of gates that commute. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CommutationAnalysis pass on dag. + +Run the pass on the DAG, and write the discovered commutation relations into the `property_set`. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeCancellation.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeCancellation.md new file mode 100644 index 00000000000..c1fec588a1e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeCancellation.md @@ -0,0 +1,130 @@ +--- +title: CommutativeCancellation +description: API reference for qiskit.transpiler.passes.CommutativeCancellation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CommutativeCancellation +--- + +# CommutativeCancellation + + + +`qiskit.transpiler.passes.CommutativeCancellation(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/commutative_cancellation.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Cancel the redundant (self-adjoint) gates through commutation relations. + +Pass for cancelling self-inverse gates/rotations. The cancellation utilizes the commutation relations in the circuit. Gates considered include: + +```python +H, X, Y, Z, CX, CY, CZ +``` + +CommutativeCancellation initializer. + +**Parameters** + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Basis gates to consider, e.g. `['u3', 'cx']`. For the effects of this pass, the basis is the set intersection between the `basis_gates` parameter and the gates in the dag. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `basis_gates` and `target` are specified then this argument will take precedence and `basis_gates` will be ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CommutativeCancellation pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – when the 1-qubit rotation gates are not found + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeInverseCancellation.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeInverseCancellation.md new file mode 100644 index 00000000000..5531da9815b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CommutativeInverseCancellation.md @@ -0,0 +1,113 @@ +--- +title: CommutativeInverseCancellation +description: API reference for qiskit.transpiler.passes.CommutativeInverseCancellation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CommutativeInverseCancellation +--- + +# CommutativeInverseCancellation + + + +`qiskit.transpiler.passes.CommutativeInverseCancellation(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/commutative_inverse_cancellation.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Cancel pairs of inverse gates exploiting commutation relations. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CommutativeInverseCancellation pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – the directed acyclic graph to run on. + +**Returns** + +Transformed DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Commuting2qGateRouter.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Commuting2qGateRouter.md new file mode 100644 index 00000000000..f8ae6d582e5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Commuting2qGateRouter.md @@ -0,0 +1,206 @@ +--- +title: Commuting2qGateRouter +description: API reference for qiskit.transpiler.passes.Commuting2qGateRouter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Commuting2qGateRouter +--- + +# Commuting2qGateRouter + + + +`qiskit.transpiler.passes.Commuting2qGateRouter(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/routing/commuting_2q_gate_routing/commuting_2q_gate_router.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +A class to swap route one or more commuting gates to the coupling map. + +This pass routes blocks of commuting two-qubit gates encapsulated as `Commuting2qBlock` instructions. This pass will not apply to other instructions. The mapping to the coupling map is done using swap strategies, see `SwapStrategy`. The swap strategy should suit the problem and the coupling map. This transpiler pass should ideally be executed before the quantum circuit is enlarged with any idle ancilla qubits. Otherwise, we may swap qubits outside the portion of the chip we want to use. Therefore, the swap strategy and its associated coupling map do not represent physical qubits. Instead, they represent an intermediate mapping that corresponds to the physical qubits once the initial layout is applied. The example below shows how to map a four qubit [`PauliEvolutionGate`](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate") to qubits 0, 1, 3, and 4 of the five qubit device with the coupling map + +```python +0 -- 1 -- 2 + | + 3 + | + 4 +``` + +To do this we use a line swap strategy for qubits 0, 1, 3, and 4 defined it in terms of virtual qubits 0, 1, 2, and 3. + +```python +from qiskit import QuantumCircuit +from qiskit.opflow import PauliSumOp +from qiskit.circuit.library import PauliEvolutionGate +from qiskit.transpiler import Layout, CouplingMap, PassManager +from qiskit.transpiler.passes import FullAncillaAllocation +from qiskit.transpiler.passes import EnlargeWithAncilla +from qiskit.transpiler.passes import ApplyLayout +from qiskit.transpiler.passes import SetLayout + +from qiskit.transpiler.passes.routing.commuting_2q_gate_routing import ( + SwapStrategy, + FindCommutingPauliEvolutions, + Commuting2qGateRouter, +) + +# Define the circuit on virtual qubits +op = PauliSumOp.from_list([("IZZI", 1), ("ZIIZ", 2), ("ZIZI", 3)]) +circ = QuantumCircuit(4) +circ.append(PauliEvolutionGate(op, 1), range(4)) + +# Define the swap strategy on qubits before the initial_layout is applied. +swap_strat = SwapStrategy.from_line([0, 1, 2, 3]) + +# Chose qubits 0, 1, 3, and 4 from the backend coupling map shown above. +backend_cmap = CouplingMap(couplinglist=[(0, 1), (1, 2), (1, 3), (3, 4)]) +initial_layout = Layout.from_intlist([0, 1, 3, 4], *circ.qregs) + +pm_pre = PassManager( + [ + FindCommutingPauliEvolutions(), + Commuting2qGateRouter(swap_strat), + SetLayout(initial_layout), + FullAncillaAllocation(backend_cmap), + EnlargeWithAncilla(), + ApplyLayout(), + ] +) + +# Insert swap gates, map to initial_layout and finally enlarge with ancilla. +pm_pre.run(circ).draw("mpl") +``` + +This pass manager relies on the `current_layout` which corresponds to the qubit layout as swap gates are applied. The pass will traverse all nodes in the dag. If a node should be routed using a swap strategy then it will be decomposed into sub-instructions with swap layers in between and the `current_layout` will be modified. Nodes that should not be routed using swap strategies will be added back to the dag taking the `current_layout` into account. + +**Parameters** + +* **swap\_strategy** – An instance of a `SwapStrategy` that holds the swap layers that are used, and the order in which to apply them, to map the instruction to the hardware. If this field is not given, it should be contained in the property set of the pass. This allows other passes to determine the most appropriate swap strategy at run-time. +* **edge\_coloring** – An optional edge coloring of the coupling map (I.e. no two edges that share a node have the same color). If the edge coloring is given then the commuting gates that can be simultaneously applied given the current qubit permutation are grouped according to the edge coloring and applied according to this edge coloring. Here, a color is an int which is used as the index to define and access the groups of commuting gates that can be applied simultaneously. If the edge coloring is not given then the sets will be built-up using a greedy algorithm. The edge coloring is useful to position gates such as `RZZGate`s next to swap gates to exploit CX cancellations. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the pass by decomposing the nodes it applies on. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – The dag to which we will add swaps. + +**Returns** + +A dag where swaps have been added for the intended gate type. + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the swap strategy was not given at init time and there is no swap strategy in the property set. +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the quantum circuit contains more than one qubit register. +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If there are qubits that are not contained in the quantum register. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### swap\_decompose + + + +`swap_decompose(dag, node, current_layout, swap_strategy)` + +Take an instance of `Commuting2qBlock` and map it to the coupling map. + +The mapping is done with the swap strategy. + +**Parameters** + +* **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – The dag which contains the `Commuting2qBlock` we route. +* **node** ([*DAGOpNode*](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.dagnode.DAGOpNode")) – A node whose operation is a `Commuting2qBlock`. +* **current\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.layout.Layout")) – The layout before the swaps are applied. This function will modify the layout so that subsequent gates can be properly composed on the dag. +* **swap\_strategy** (*SwapStrategy*) – The swap strategy used to decompose the node. + +**Returns** + +A dag that is compatible with the coupling map where swap gates have been added to map the gates in the `Commuting2qBlock` to the hardware. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConsolidateBlocks.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConsolidateBlocks.md new file mode 100644 index 00000000000..39886219d29 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConsolidateBlocks.md @@ -0,0 +1,121 @@ +--- +title: ConsolidateBlocks +description: API reference for qiskit.transpiler.passes.ConsolidateBlocks +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ConsolidateBlocks +--- + +# ConsolidateBlocks + + + +`qiskit.transpiler.passes.ConsolidateBlocks(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/consolidate_blocks.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Replace each block of consecutive gates by a single Unitary node. + +Pass to consolidate sequences of uninterrupted gates acting on the same qubits into a Unitary node, to be resynthesized later, to a potentially more optimal subcircuit. + +**Notes** + +This pass assumes that the ‘blocks\_list’ property that it reads is given such that blocks are in topological order. The blocks are collected by a previous pass, such as Collect2qBlocks. + +ConsolidateBlocks initializer. + +If `kak_basis_gate` is not `None` it will be used as the basis gate for KAK decomposition. Otherwise, if `basis_gates` is not `None` a basis gate will be chosen from this list. Otherwise, the basis gate will be [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate"). + +**Parameters** + +* **kak\_basis\_gate** ([*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")) – Basis gate for KAK decomposition. +* **force\_consolidate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Force block consolidation. +* **basis\_gates** (*List(*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*)*) – Basis gates from which to choose a KAK gate. +* **approximation\_degree** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – a float between $[0.0, 1.0]$. Lower approximates more. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The target object for the compilation target backend. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the ConsolidateBlocks pass on dag. + +Iterate over each block and replace it with an equivalent Unitary on the same wires. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConstrainedReschedule.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConstrainedReschedule.md new file mode 100644 index 00000000000..5e6a0cf3181 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConstrainedReschedule.md @@ -0,0 +1,175 @@ +--- +title: ConstrainedReschedule +description: API reference for qiskit.transpiler.passes.ConstrainedReschedule +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ConstrainedReschedule +--- + +# ConstrainedReschedule + + + +`qiskit.transpiler.passes.ConstrainedReschedule(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/alignments/reschedule.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Rescheduler pass that updates node start times to conform to the hardware alignments. + +This pass shifts DAG node start times previously scheduled with one of the scheduling passes, e.g. [`ASAPScheduleAnalysis`](qiskit.transpiler.passes.ASAPScheduleAnalysis "qiskit.transpiler.passes.ASAPScheduleAnalysis") or [`ALAPScheduleAnalysis`](qiskit.transpiler.passes.ALAPScheduleAnalysis "qiskit.transpiler.passes.ALAPScheduleAnalysis"), so that every instruction start time satisfies alignment constraints. + +**Examples** + +We assume executing the following circuit on a backend with 16 dt of acquire alignment. + +```python + ┌───┐┌────────────────┐┌─┐ +q_0: ┤ X ├┤ Delay(100[dt]) ├┤M├ + └───┘└────────────────┘└╥┘ +c: 1/════════════════════════╩═ + 0 +``` + +Note that delay of 100 dt induces a misalignment of 4 dt at the measurement. This pass appends an extra 12 dt time shift to the input circuit. + +```python + ┌───┐┌────────────────┐┌─┐ +q_0: ┤ X ├┤ Delay(112[dt]) ├┤M├ + └───┘└────────────────┘└╥┘ +c: 1/════════════════════════╩═ + 0 +``` + +**Notes** + +Your backend may execute circuits violating these alignment constraints. However, you may obtain erroneous measurement result because of the untracked phase originating in the instruction misalignment. + +Create new rescheduler pass. + +The alignment values depend on the control electronics of your quantum processor. + +**Parameters** + +* **acquire\_alignment** – Integer number representing the minimum time resolution to trigger acquisition instruction in units of `dt`. +* **pulse\_alignment** – Integer number representing the minimum time resolution to trigger gate instruction in units of `dt`. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run rescheduler. + +This pass should perform rescheduling to satisfy: + +> * All DAGOpNode nodes (except for compiler directives) are placed at start time satisfying hardware alignment constraints. +> * The end time of a node does not overlap with the start time of successor nodes. + +Assumptions: + +> * Topological order and absolute time order of DAGOpNode are consistent. +> * All bits in either qargs or cargs associated with node synchronously start. +> * Start time of qargs and cargs may different due to I/O latency. + +Based on the configurations above, the rescheduler pass takes the following strategy: + +1. **The nodes are processed in the topological order, from the beginning of** + + the circuit (i.e. from left to right). For every node (including compiler directives), the function `_push_node_back` performs steps 2 and 3. + +2. **If the start time of the node violates the alignment constraint,** + + the start time is increased to satisfy the constraint. + +3. **Each immediate successor whose start\_time overlaps the node’s end\_time is** + + pushed backwards (towards the end of the wire). Note that at this point the shifted successor does not need to satisfy the constraints, but this will be taken care of when that successor node itself is processed. + +4. **After every node is processed, all misalignment constraints will be resolved,** + + and there will be no overlap between the nodes. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG circuit to be rescheduled with constraints. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If circuit is not scheduled. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ContainsInstruction.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ContainsInstruction.md new file mode 100644 index 00000000000..c5a830ac52b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ContainsInstruction.md @@ -0,0 +1,110 @@ +--- +title: ContainsInstruction +description: API reference for qiskit.transpiler.passes.ContainsInstruction +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ContainsInstruction +--- + +# ContainsInstruction + + + +`qiskit.transpiler.passes.ContainsInstruction(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/contains_instruction.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +An analysis pass to detect if the DAG contains a specific instruction. + +This pass takes in a single instruction name for example `'delay'` and will set the property set `contains_delay` to `True` if the DAG contains that instruction and `False` if it does not. + +ContainsInstruction initializer. + +**Parameters** + +* **instruction\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| Iterable\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – The instruction or instructions to check are in the DAG. The output in the property set is set to `contains_` prefixed on each value for this parameter. +* **recurse** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if `True` (default), then recurse into control-flow operations. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the ContainsInstruction pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConvertConditionsToIfOps.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConvertConditionsToIfOps.md new file mode 100644 index 00000000000..4ba3d869898 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ConvertConditionsToIfOps.md @@ -0,0 +1,111 @@ +--- +title: ConvertConditionsToIfOps +description: API reference for qiskit.transpiler.passes.ConvertConditionsToIfOps +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ConvertConditionsToIfOps +--- + +# ConvertConditionsToIfOps + + + +`qiskit.transpiler.passes.ConvertConditionsToIfOps(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/convert_conditions_to_if_ops.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Convert instructions whose `condition` attribute is set to a non-`None` value into the equivalent single-statement `IfElseBlock`. + +This is a simple pass aimed at easing the conversion from the old style of using [`InstructionSet.c_if()`](qiskit.circuit.InstructionSet#c_if "qiskit.circuit.InstructionSet.c_if") into the new style of using more complex conditional logic. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run a pass on the DAGCircuit. This is implemented by the pass developer. + +**Parameters** + +**dag** – the dag on which the pass is run. + +**Raises** + +[**NotImplementedError**](https://docs.python.org/3/library/exceptions.html#NotImplementedError "(in Python v3.12)") – when this is left unimplemented for a pass. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOps.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOps.md new file mode 100644 index 00000000000..54e27a4304a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOps.md @@ -0,0 +1,103 @@ +--- +title: CountOps +description: API reference for qiskit.transpiler.passes.CountOps +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CountOps +--- + +# CountOps + + + +`qiskit.transpiler.passes.CountOps(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/analysis/count_ops.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Count the operations in a DAG circuit. + +The result is saved in `property_set['count_ops']` as an integer. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CountOps pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOpsLongestPath.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOpsLongestPath.md new file mode 100644 index 00000000000..b304a4a53bb --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CountOpsLongestPath.md @@ -0,0 +1,103 @@ +--- +title: CountOpsLongestPath +description: API reference for qiskit.transpiler.passes.CountOpsLongestPath +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CountOpsLongestPath +--- + +# CountOpsLongestPath + + + +`qiskit.transpiler.passes.CountOpsLongestPath(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/analysis/count_ops_longest_path.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Count the operations on the longest path in a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit"). + +The result is saved in `property_set['count_ops_longest_path']` as an integer. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the CountOpsLongestPath pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.CrosstalkAdaptiveSchedule.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CrosstalkAdaptiveSchedule.md new file mode 100644 index 00000000000..cfa0a9505d4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.CrosstalkAdaptiveSchedule.md @@ -0,0 +1,343 @@ +--- +title: CrosstalkAdaptiveSchedule +description: API reference for qiskit.transpiler.passes.CrosstalkAdaptiveSchedule +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.CrosstalkAdaptiveSchedule +--- + +# CrosstalkAdaptiveSchedule + + + +`qiskit.transpiler.passes.CrosstalkAdaptiveSchedule(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/crosstalk_adaptive_schedule.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Crosstalk mitigation through adaptive instruction scheduling. + +CrosstalkAdaptiveSchedule initializer. + + + The class `qiskit.transpiler.passes.optimization.crosstalk_adaptive_schedule.CrosstalkAdaptiveSchedule` is deprecated as of qiskit 0.46. It will be removed in the 1.0.0 release. + + +**Parameters** + +* **backend\_prop** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – backend properties object + +* **crosstalk\_prop** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – + + crosstalk properties object crosstalk\_prop\[g1]\[g2] specifies the conditional error rate of g1 when g1 and g2 are executed simultaneously. g1 should be a two-qubit tuple of the form (x,y) where x and y are physical qubit ids. g2 can be either two-qubit tuple (x,y) or single-qubit tuple (x). We currently ignore crosstalk between pairs of single-qubit gates. Gate pairs which are not specified are assumed to be crosstalk free. + + Example: + + ```python + crosstalk_prop = {(0, 1) : {(2, 3) : 0.2, (2) : 0.15}, + (4, 5) : {(2, 3) : 0.1}, + (2, 3) : {(0, 1) : 0.05, (4, 5): 0.05}} + ``` + + The keys of the crosstalk\_prop are tuples for ordered tuples for CX gates e.g., (0, 1) corresponding to CX 0, 1 in the hardware. Each key has an associated value dict which specifies the conditional error rates with nearby gates e.g., `(0, 1) : {(2, 3) : 0.2, (2) : 0.15}` means that CNOT 0, 1 has an error rate of 0.2 when it is executed in parallel with CNOT 2,3 and an error rate of 0.15 when it is executed in parallel with a single qubit gate on qubit 2. + +* **weight\_factor** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – weight of gate error/crosstalk terms in the objective $weight_factor*fidelities + (1-weight_factor)*decoherence errors$. Weight can be varied from 0 to 1, with 0 meaning that only decoherence errors are optimized and 1 meaning that only crosstalk errors are optimized. weight\_factor should be tuned per application to get the best results. + +* **measured\_qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a list of qubits that will be measured in a particular circuit. This arg need not be specified for circuits which already include measure gates. The arg is useful when a subsequent module such as state\_tomography\_circuits inserts the measure gates. If CrosstalkAdaptiveSchedule is made aware of those measurements, it is included in the optimization. + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – A target representing the target backend, if both `backend_prop` and `target` are specified then this argument will take precedence and `coupling_map` will be ignored. + +**Raises** + +[**ImportError**](https://docs.python.org/3/library/exceptions.html#ImportError "(in Python v3.12)") – if unable to import z3 solver + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### assign\_gate\_id + + + +`assign_gate_id(dag)` + +ID for each gate + +### basic\_bounds + + + +`basic_bounds()` + +Basic variable bounds for optimization + +### check\_dag\_dependency + + + +`check_dag_dependency(gate1, gate2)` + +gate2 is a DAG dependent of gate1 if it is a descendant of gate1 + +### check\_xtalk\_dependency + + + +`check_xtalk_dependency(t_1, t_2)` + +Check if two gates have a crosstalk dependency. We do not consider crosstalk between pairs of single qubit gates. + +### coherence\_constraints + + + +`coherence_constraints()` + +Set decoherence errors based on qubit lifetimes + +### create\_updated\_dag + + + +`create_updated_dag(layers, barriers)` + +Given a set of layers and barriers, construct a new dag + +### create\_z3\_vars + + + +`create_z3_vars()` + +Setup the variables required for Z3 optimization + +### cx\_tuple + + + +`cx_tuple(gate)` + +Representation for two-qubit gate Note: current implementation assumes that the CX error rates and crosstalk behavior are independent of gate direction + +### enforce\_schedule\_on\_dag + + + +`enforce_schedule_on_dag(input_gate_times)` + +Z3 outputs start times for each gate. Some gates need to be serialized to implement the Z3 schedule. This function inserts barriers to implement those serializations + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### extract\_crosstalk\_relevant\_sets + + + +`extract_crosstalk_relevant_sets()` + +Extract the set of program gates which potentially have crosstalk noise + +### extract\_dag\_overlap\_sets + + + +`extract_dag_overlap_sets(dag)` + +Gate A, B are overlapping if A is neither a descendant nor an ancestor of B. Currently overlaps (A,B) are considered when A is a 2q gate and B is either 2q or 1q gate. + +### extract\_solution + + + +`extract_solution()` + +Extract gate start and finish times from Z3 solution + +### fidelity\_constraints + + + +`fidelity_constraints()` + +Set gate fidelity based on gate overlap conditions + +### filter\_candidates + + + +`filter_candidates(candidates, layer, layer_id, triplet)` + +For a gate G and layer L, L is a candidate layer for G if no gate in L has a DAG dependency with G, and if Z3 allows gates in L and G to overlap. + +### find\_layer + + + +`find_layer(layers, triplet)` + +Find the appropriate layer for a gate + +### gate\_tuple + + + +`gate_tuple(gate)` + +Representation for gate + +### generate\_barriers + + + +`generate_barriers(layers)` + +For each gate g, see if a barrier is required to serialize it with some previously processed gate + +### is\_significant\_xtalk + + + +`is_significant_xtalk(gate1, gate2)` + +Given two conditional gate error rates check if there is high crosstalk by comparing with independent error rates. + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### objective\_function + + + +`objective_function()` + +Objective function is a weighted combination of gate errors and decoherence errors + +### parse\_backend\_properties + + + +`parse_backend_properties()` + +This function assumes that gate durations and coherence times are in seconds in backend.properties() This function converts gate durations and coherence times to nanoseconds. + +### powerset + + + +`powerset(iterable)` + +Finds the set of all subsets of the given iterable This function is used to generate constraints for the Z3 optimization + +### r2f + + + +`r2f(val)` + +Convert Z3 Real to Python float + +### reset + + + +`reset()` + +Reset variables + +### run + + + +`run(dag)` + +Main scheduling function + +### scheduling\_constraints + + + +`scheduling_constraints()` + +DAG scheduling constraints optimization Sets overlap indicator variables + +### singleq\_tuple + + + +`singleq_tuple(gate)` + +Representation for single-qubit gate + +### solve\_optimization + + + +`solve_optimization()` + +Setup and solve a Z3 optimization for finding the best schedule + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGFixedPoint.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGFixedPoint.md new file mode 100644 index 00000000000..12c18cf9320 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGFixedPoint.md @@ -0,0 +1,103 @@ +--- +title: DAGFixedPoint +description: API reference for qiskit.transpiler.passes.DAGFixedPoint +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.DAGFixedPoint +--- + +# DAGFixedPoint + + + +`qiskit.transpiler.passes.DAGFixedPoint(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/dag_fixed_point.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Check if the DAG has reached a fixed point. + +A dummy analysis pass that checks if the DAG a fixed point (the DAG is not modified anymore). The result is saved in `property_set['dag_fixed_point']` as a boolean. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the DAGFixedPoint pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGLongestPath.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGLongestPath.md new file mode 100644 index 00000000000..1328258ffe0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DAGLongestPath.md @@ -0,0 +1,101 @@ +--- +title: DAGLongestPath +description: API reference for qiskit.transpiler.passes.DAGLongestPath +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.DAGLongestPath +--- + +# DAGLongestPath + + + +`qiskit.transpiler.passes.DAGLongestPath(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/analysis/dag_longest_path.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Return the longest path in a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") as a list of [`DAGOpNode`](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")s, [`DAGInNode`](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")s, and [`DAGOutNode`](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")s. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the DAGLongestPath pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Decompose.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Decompose.md new file mode 100644 index 00000000000..30426cc1e85 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Decompose.md @@ -0,0 +1,119 @@ +--- +title: Decompose +description: API reference for qiskit.transpiler.passes.Decompose +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Decompose +--- + +# Decompose + + + +`qiskit.transpiler.passes.Decompose(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/basis/decompose.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Expand a gate in a circuit using its decomposition rules. + +Decompose initializer. + +**Parameters** + +**gates\_to\_decompose** – optional subset of gates to be decomposed, identified by gate label, name or type. Defaults to all gates. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Decompose pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – input dag. + +**Returns** + +output dag where `gate` was expanded. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.DenseLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DenseLayout.md new file mode 100644 index 00000000000..14e6b58238f --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DenseLayout.md @@ -0,0 +1,125 @@ +--- +title: DenseLayout +description: API reference for qiskit.transpiler.passes.DenseLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.DenseLayout +--- + +# DenseLayout + + + +`qiskit.transpiler.passes.DenseLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/dense_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Choose a Layout by finding the most connected subset of qubits. + +This pass associates a physical qubit (int) to each virtual qubit of the circuit (Qubit). + + + Even though a `'layout'` is not strictly a property of the DAG, in the transpiler architecture it is best passed around between passes by being set in `property_set`. + + +DenseLayout initializer. + +**Parameters** + +* **coupling\_map** (*Coupling*) – directed graph representing a coupling map. +* **backend\_prop** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – backend properties object +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – A target representing the target backend. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the DenseLayout pass on dag. + +Pick a convenient layout depending on the best matching qubit connectivity, and set the property layout. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to find layout for. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if dag wider than self.coupling\_map + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Depth.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Depth.md new file mode 100644 index 00000000000..70fd1d5d825 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Depth.md @@ -0,0 +1,105 @@ +--- +title: Depth +description: API reference for qiskit.transpiler.passes.Depth +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Depth +--- + +# Depth + + + +`qiskit.transpiler.passes.Depth(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/analysis/depth.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Calculate the depth of a DAG circuit. + +**Parameters** + +**recurse** – whether to allow recursion into control flow. If this is `False` (default), the pass will throw an error when control flow is present, to avoid returning a number with little meaning. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Depth pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.DynamicalDecoupling.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DynamicalDecoupling.md new file mode 100644 index 00000000000..2b3be281520 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.DynamicalDecoupling.md @@ -0,0 +1,202 @@ +--- +title: DynamicalDecoupling +description: API reference for qiskit.transpiler.passes.DynamicalDecoupling +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.DynamicalDecoupling +--- + +# DynamicalDecoupling + + + +`qiskit.transpiler.passes.DynamicalDecoupling(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/dynamical_decoupling.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Dynamical decoupling insertion pass. + +This pass works on a scheduled, physical circuit. It scans the circuit for idle periods of time (i.e. those containing delay instructions) and inserts a DD sequence of gates in those spots. These gates amount to the identity, so do not alter the logical action of the circuit, but have the effect of mitigating decoherence in those idle periods. + +As a special case, the pass allows a length-1 sequence (e.g. \[XGate()]). In this case the DD insertion happens only when the gate inverse can be absorbed into a neighboring gate in the circuit (so we would still be replacing Delay with something that is equivalent to the identity). This can be used, for instance, as a Hahn echo. + +This pass ensures that the inserted sequence preserves the circuit exactly (including global phase). + +```python +import numpy as np +from qiskit.circuit import QuantumCircuit +from qiskit.circuit.library import XGate +from qiskit.transpiler import PassManager, InstructionDurations +from qiskit.transpiler.passes import ALAPSchedule, DynamicalDecoupling +from qiskit.visualization import timeline_drawer + +# Because the legacy passes do not propagate the scheduling information correctly, it is +# necessary to run a no-op "re-schedule" before the output circuits can be drawn. +def draw(circuit): + from qiskit import transpile + + scheduled = transpile( + circuit, + optimization_level=0, + instruction_durations=InstructionDurations(), + scheduling_method="alap", + ) + return timeline_drawer(scheduled) + +circ = QuantumCircuit(4) +circ.h(0) +circ.cx(0, 1) +circ.cx(1, 2) +circ.cx(2, 3) +circ.measure_all() +durations = InstructionDurations( + [("h", 0, 50), ("cx", [0, 1], 700), ("reset", None, 10), + ("cx", [1, 2], 200), ("cx", [2, 3], 300), + ("x", None, 50), ("measure", None, 1000)] +) +# balanced X-X sequence on all qubits +dd_sequence = [XGate(), XGate()] +pm = PassManager([ALAPSchedule(durations), + DynamicalDecoupling(durations, dd_sequence)]) +circ_dd = pm.run(circ) +draw(circ_dd) + +# Uhrig sequence on qubit 0 +n = 8 +dd_sequence = [XGate()] * n +def uhrig_pulse_location(k): + return np.sin(np.pi * (k + 1) / (2 * n + 2)) ** 2 +spacing = [] +for k in range(n): + spacing.append(uhrig_pulse_location(k) - sum(spacing)) +spacing.append(1 - sum(spacing)) +pm = PassManager( + [ + ALAPSchedule(durations), + DynamicalDecoupling(durations, dd_sequence, qubits=[0], spacing=spacing), + ] +) +circ_dd = pm.run(circ) +draw(circ_dd) +``` + +![../\_images/qiskit-transpiler-passes-DynamicalDecoupling-1\_00.png](/images/api/qiskit/0.46/qiskit-transpiler-passes-DynamicalDecoupling-1_00.png) + +![../\_images/qiskit-transpiler-passes-DynamicalDecoupling-1\_01.png](/images/api/qiskit/0.46/qiskit-transpiler-passes-DynamicalDecoupling-1_01.png) + +Dynamical decoupling initializer. + + + The class `qiskit.transpiler.passes.scheduling.dynamical_decoupling.DynamicalDecoupling` is pending deprecation as of qiskit 0.21.0. It will be marked deprecated in a future release, and then removed no earlier than 3 months after the release date. Instead, use [`PadDynamicalDecoupling`](qiskit.transpiler.passes.PadDynamicalDecoupling "qiskit.transpiler.passes.PadDynamicalDecoupling"), which performs the same function but requires scheduling and alignment analysis passes to run prior to it. + + +**Parameters** + +* **durations** ([*InstructionDurations*](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations")) – Durations of instructions to be used in scheduling. +* **dd\_sequence** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")*]*) – sequence of gates to apply in idle spots. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – physical qubits on which to apply DD. If None, all qubits will undergo DD (when possible). +* **spacing** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – a list of spacings between the DD gates. The available slack will be divided according to this. The list length must be one more than the length of dd\_sequence, and the elements must sum to 1. If None, a balanced spacing will be used \[d/2, d, d, …, d, d, d/2]. +* **skip\_reset\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if True, does not insert DD on idle periods that immediately follow initialized/reset qubits (as qubits in the ground state are less susceptile to decoherence). +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `durations` and this are specified then this argument will take precedence and `durations` will be ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the DynamicalDecoupling pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – a scheduled DAG. + +**Returns** + +**equivalent circuit with delays interrupted by DD,** + +where possible. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the circuit is not mapped on physical qubits. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.EchoRZXWeylDecomposition.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.EchoRZXWeylDecomposition.md new file mode 100644 index 00000000000..c6b75b9e147 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.EchoRZXWeylDecomposition.md @@ -0,0 +1,128 @@ +--- +title: EchoRZXWeylDecomposition +description: API reference for qiskit.transpiler.passes.EchoRZXWeylDecomposition +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.EchoRZXWeylDecomposition +--- + +# EchoRZXWeylDecomposition + + + +`qiskit.transpiler.passes.EchoRZXWeylDecomposition(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/echo_rzx_weyl_decomposition.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Rewrite two-qubit gates using the Weyl decomposition. + +This transpiler pass rewrites two-qubit gates in terms of echoed cross-resonance gates according to the Weyl decomposition. A two-qubit gate will be replaced with at most six non-echoed RZXGates. Each pair of RZXGates forms an echoed RZXGate. + +EchoRZXWeylDecomposition pass. + +**Parameters** + +* **instruction\_schedule\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap")) – the mapping from circuit [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") names and arguments to [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule")s. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `instruction_schedule_map` and `target` are specified then this argument will take precedence and `instruction_schedule_map` will be ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the EchoRZXWeylDecomposition pass on dag. + +Rewrites two-qubit gates in an arbitrary circuit in terms of echoed cross-resonance gates by computing the Weyl decomposition of the corresponding unitary. Modifies the input dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to rewrite. + +**Returns** + +The modified dag. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the circuit cannot be rewritten. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.EnlargeWithAncilla.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.EnlargeWithAncilla.md new file mode 100644 index 00000000000..45ee5cfc614 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.EnlargeWithAncilla.md @@ -0,0 +1,119 @@ +--- +title: EnlargeWithAncilla +description: API reference for qiskit.transpiler.passes.EnlargeWithAncilla +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.EnlargeWithAncilla +--- + +# EnlargeWithAncilla + + + +`qiskit.transpiler.passes.EnlargeWithAncilla(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/enlarge_with_ancilla.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Extend the dag with virtual qubits that are in layout but not in the circuit yet. + +Extend the DAG circuit with new virtual qubits (ancilla) that are specified in the layout, but not present in the circuit. Which qubits to add are previously allocated in the `layout` property, by a previous pass. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the EnlargeWithAncilla pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to extend. + +**Returns** + +An extended DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If there is no layout in the property set or not set at init time. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.FixedPoint.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.FixedPoint.md new file mode 100644 index 00000000000..782f1854b39 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.FixedPoint.md @@ -0,0 +1,109 @@ +--- +title: FixedPoint +description: API reference for qiskit.transpiler.passes.FixedPoint +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.FixedPoint +--- + +# FixedPoint + + + +`qiskit.transpiler.passes.FixedPoint(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/fixed_point.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Check if a property reached a fixed point. + +A dummy analysis pass that checks if a property reached a fixed point. The result is saved in `property_set['_fixed_point']` as a boolean. + +FixedPoint initializer. + +**Parameters** + +**property\_to\_check** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The property to check if a fixed point was reached. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the FixedPoint pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.FullAncillaAllocation.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.FullAncillaAllocation.md new file mode 100644 index 00000000000..03ad511ef7a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.FullAncillaAllocation.md @@ -0,0 +1,141 @@ +--- +title: FullAncillaAllocation +description: API reference for qiskit.transpiler.passes.FullAncillaAllocation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.FullAncillaAllocation +--- + +# FullAncillaAllocation + + + +`qiskit.transpiler.passes.FullAncillaAllocation(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/full_ancilla_allocation.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Allocate all idle nodes from the coupling map or target as ancilla on the layout. + +A pass for allocating all idle physical qubits (those that exist in coupling map or target but not the dag circuit) as ancilla. It will also choose new virtual qubits to correspond to those physical ancilla. + + + This is an analysis pass, and only responsible for choosing physical ancilla locations and their corresponding virtual qubits. A separate transformation pass must add those virtual qubits to the circuit. + + +FullAncillaAllocation initializer. + +**Parameters** + +**coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – directed graph representing a coupling map. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the FullAncillaAllocation pass on dag. + +Extend the layout with new (physical qubit, virtual qubit) pairs. The dag signals which virtual qubits are already in the circuit. This pass will allocate new virtual qubits such that no collision occurs (i.e. Layout bijectivity is preserved) + +The coupling\_map and layout together determine which physical qubits are free. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – circuit to analyze + +**Returns** + +returns the same dag circuit, unmodified + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If there is not layout in the property set or not set at init time. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + +### validate\_layout + + + +`static validate_layout(layout_qubits, dag_qubits)` + +Checks if all the qregs in `layout_qregs` already exist in `dag_qregs`. Otherwise, raise. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.GateDirection.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.GateDirection.md new file mode 100644 index 00000000000..429eb001421 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.GateDirection.md @@ -0,0 +1,153 @@ +--- +title: GateDirection +description: API reference for qiskit.transpiler.passes.GateDirection +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.GateDirection +--- + +# GateDirection + + + +`qiskit.transpiler.passes.GateDirection(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/gate_direction.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Modify asymmetric gates to match the hardware coupling direction. + +This pass makes use of the following identities: + +```python + ┌───┐┌───┐┌───┐ +q_0: ──■── q_0: ┤ H ├┤ X ├┤ H ├ + ┌─┴─┐ = ├───┤└─┬─┘├───┤ +q_1: ┤ X ├ q_1: ┤ H ├──■──┤ H ├ + └───┘ └───┘ └───┘ + + + global phase: 3π/2 + ┌──────┐ ┌───┐ ┌────┐┌─────┐┌──────┐┌───┐ +q_0: ┤0 ├ q_0: ─┤ S ├─┤ √X ├┤ Sdg ├┤1 ├┤ H ├ + │ ECR │ = ┌┴───┴┐├────┤└┬───┬┘│ Ecr │├───┤ +q_1: ┤1 ├ q_1: ┤ Sdg ├┤ √X ├─┤ S ├─┤0 ├┤ H ├ + └──────┘ └─────┘└────┘ └───┘ └──────┘└───┘ + + + ┌──────┐ ┌───┐┌──────┐┌───┐ +q_0: ┤0 ├ q_0: ┤ H ├┤1 ├┤ H ├ + │ RZX │ = ├───┤│ RZX │├───┤ +q_1: ┤1 ├ q_1: ┤ H ├┤0 ├┤ H ├ + └──────┘ └───┘└──────┘└───┘ +``` + +This pass assumes that the positions of the qubits in the `DAGCircuit.qubits` attribute are the physical qubit indicies. For example if `dag.qubits[0]` is qubit 0 in the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") or [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"). + +GateDirection pass. + +**Parameters** + +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – Directed graph represented a coupling map. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The backend target to use for this pass. If this is specified it will be used instead of the coupling map + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the GateDirection pass on dag. + +Flips the cx nodes to match the directed coupling map. Modifies the input dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to map. + +**Returns** + +The rearranged dag for the coupling map + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the circuit cannot be mapped just by flipping the cx nodes. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.GatesInBasis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.GatesInBasis.md new file mode 100644 index 00000000000..7010627786c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.GatesInBasis.md @@ -0,0 +1,108 @@ +--- +title: GatesInBasis +description: API reference for qiskit.transpiler.passes.GatesInBasis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.GatesInBasis +--- + +# GatesInBasis + + + +`qiskit.transpiler.passes.GatesInBasis(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/gates_basis.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Check if all gates in a DAG are in a given set of gates + +Initialize the GatesInBasis pass. + +**Parameters** + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The list of strings representing the set of basis gates. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The target representing the backend. If specified this will be used instead of the `basis_gates` parameter + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the GatesInBasis pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.HighLevelSynthesis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.HighLevelSynthesis.md new file mode 100644 index 00000000000..7fa71572ee4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.HighLevelSynthesis.md @@ -0,0 +1,152 @@ +--- +title: HighLevelSynthesis +description: API reference for qiskit.transpiler.passes.HighLevelSynthesis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.HighLevelSynthesis +--- + +# HighLevelSynthesis + + + +`qiskit.transpiler.passes.HighLevelSynthesis(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/high_level_synthesis.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Synthesize higher-level objects and unroll custom definitions. + +The input to this pass is a DAG that may contain higher-level objects, including abstract mathematical objects (e.g., objects of type [`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction")), annotated operations (objects of type [`AnnotatedOperation`](qiskit.circuit.AnnotatedOperation "qiskit.circuit.AnnotatedOperation")), and custom gates. + +In the most common use-case when either `basis_gates` or `target` is specified, all higher-level objects are synthesized, so the output is a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") without such objects. More precisely, every gate in the output DAG is either directly supported by the target, or is in `equivalence_library`. + +The abstract mathematical objects are synthesized using synthesis plugins, applying synthesis methods specified in the high-level-synthesis config (refer to the documentation for `HLSConfig`). + +As an example, let us assume that `op_a` and `op_b` are names of two higher-level objects, that `op_a`-objects have two synthesis methods `default` which does require any additional parameters and `other` with two optional integer parameters `option_1` and `option_2`, that `op_b`-objects have a single synthesis method `default`, and `qc` is a quantum circuit containing `op_a` and `op_b` objects. The following code snippet: + +```python +hls_config = HLSConfig(op_b=[("other", {"option_1": 7, "option_2": 4})]) +pm = PassManager([HighLevelSynthesis(hls_config=hls_config)]) +transpiled_qc = pm.run(qc) +``` + +shows how to run the alternative synthesis method `other` for `op_b`-objects, while using the `default` methods for all other high-level objects, including `op_a`-objects. + +The annotated operations (consisting of a base operation and a list of inverse, control and power modifiers) are synthesizing recursively, first synthesizing the base operation, and then applying synthesis methods for creating inverted, controlled, or powered versions of that). + +The custom gates are synthesized by recursively unrolling their definitions, until every gate is either supported by the target or is in the equivalence library. + +When neither `basis_gates` nor `target` is specified, the pass synthesizes only the top-level abstract mathematical objects and annotated operations, without descending into the gate `definitions`. This is consistent with the older behavior of the pass, allowing to synthesize some higher-level objects using plugins and leaving the other gates untouched. + +HighLevelSynthesis initializer. + +**Parameters** + +* **hls\_config** – Optional, the high-level-synthesis config that specifies synthesis methods and parameters for various high-level-objects in the circuit. If it is not specified, the default synthesis methods and parameters will be used. +* **coupling\_map** – Optional, directed graph represented as a coupling map. +* **target** – Optional, the backend target to use for this pass. If it is specified, it will be used instead of the coupling map. +* **use\_qubit\_indices** – a flag indicating whether this synthesis pass is running before or after the layout is set, that is, whether the qubit indices of higher-level-objects correspond to qubit indices on the target backend. +* **equivalence\_library** – The equivalence library used (instructions in this library will not be unrolled by this pass). +* **basis\_gates** – Optional, target basis names to unroll to, e.g. \[‘u3’, ‘cx’]. Ignored if `target` is also specified. +* **min\_qubits** – The minimum number of qubits for operations in the input dag to translate. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the HighLevelSynthesis pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – input dag. + +**Returns** + +Output dag with higher-level operations synthesized. + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – when the transpiler is unable to synthesize the given DAG +* **(****for instance****, ****when the specified synthesis method is not available****)\*\*\*\*.** – + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.HoareOptimizer.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.HoareOptimizer.md new file mode 100644 index 00000000000..82995d4f8ac --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.HoareOptimizer.md @@ -0,0 +1,119 @@ +--- +title: HoareOptimizer +description: API reference for qiskit.transpiler.passes.HoareOptimizer +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.HoareOptimizer +--- + +# HoareOptimizer + + + +`qiskit.transpiler.passes.HoareOptimizer(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/hoare_opt.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +This is a transpiler pass using Hoare logic circuit optimization. The inner workings of this are detailed in: [https://arxiv.org/abs/1810.00375](https://arxiv.org/abs/1810.00375) + +**Parameters** + +**size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – size of gate cache, in number of gates + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – if unable to import z3 solver + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the directed acyclic graph to run on. + +**Returns** + +Transformed DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.InstructionDurationCheck.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.InstructionDurationCheck.md new file mode 100644 index 00000000000..3c2e3f6023d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.InstructionDurationCheck.md @@ -0,0 +1,118 @@ +--- +title: InstructionDurationCheck +description: API reference for qiskit.transpiler.passes.InstructionDurationCheck +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.InstructionDurationCheck +--- + +# InstructionDurationCheck + + + +`qiskit.transpiler.passes.InstructionDurationCheck(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/alignments/check_durations.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Duration validation pass for reschedule. + +This pass investigates the input quantum circuit and checks if the circuit requires rescheduling for execution. Note that this pass can be triggered without scheduling. This pass only checks the duration of delay instructions and user defined pulse gates, which report duration values without pre-scheduling. + +This pass assumes backend supported instructions, i.e. basis gates, have no violation of the hardware alignment constraints, which is true in general. + +Create new duration validation pass. + +The alignment values depend on the control electronics of your quantum processor. + +**Parameters** + +* **acquire\_alignment** – Integer number representing the minimum time resolution to trigger acquisition instruction in units of `dt`. +* **pulse\_alignment** – Integer number representing the minimum time resolution to trigger gate instruction in units of `dt`. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run duration validation passes. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG circuit to check instruction durations. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.InverseCancellation.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.InverseCancellation.md new file mode 100644 index 00000000000..d0cbeb09d2d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.InverseCancellation.md @@ -0,0 +1,123 @@ +--- +title: InverseCancellation +description: API reference for qiskit.transpiler.passes.InverseCancellation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.InverseCancellation +--- + +# InverseCancellation + + + +`qiskit.transpiler.passes.InverseCancellation(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/inverse_cancellation.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Cancel specific Gates which are inverses of each other when they occur back-to- back. + +Initialize InverseCancellation pass. + +**Parameters** + +**gates\_to\_cancel** – List describing the gates to cancel. Each element of the list is either a single gate or a pair of gates. If a single gate, then it should be self-inverse. If a pair of gates, then the gates in the pair should be inverses of each other. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – Input is not a self-inverse gate or a pair of inverse gates. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the InverseCancellation pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – the directed acyclic graph to run on. + +**Returns** + +Transformed DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Layout2qDistance.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Layout2qDistance.md new file mode 100644 index 00000000000..5880eb4f043 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Layout2qDistance.md @@ -0,0 +1,110 @@ +--- +title: Layout2qDistance +description: API reference for qiskit.transpiler.passes.Layout2qDistance +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Layout2qDistance +--- + +# Layout2qDistance + + + +`qiskit.transpiler.passes.Layout2qDistance(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/layout_2q_distance.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Evaluate how good the layout selection was. + +Saves in `property_set['layout_score']` (or the property name in property\_name) the sum of distances for each circuit CX. The lower the number, the better the selection. Therefore, 0 is a perfect layout selection. No CX direction is considered. + +Layout2qDistance initializer. + +**Parameters** + +* **coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – Directed graph represented a coupling map. +* **property\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The property name to save the score. Default: layout\_score + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Layout2qDistance pass on dag. :param dag: DAG to evaluate. :type dag: DAGCircuit + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsSynthesis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsSynthesis.md new file mode 100644 index 00000000000..6d2fe0f55ab --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsSynthesis.md @@ -0,0 +1,124 @@ +--- +title: LinearFunctionsSynthesis +description: API reference for qiskit.transpiler.passes.LinearFunctionsSynthesis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.LinearFunctionsSynthesis +--- + +# LinearFunctionsSynthesis + + + +`qiskit.transpiler.passes.LinearFunctionsSynthesis(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py "view source code") + +Bases: [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis") + +DEPRECATED: Synthesize linear functions. + +Under the hood, this runs the default high-level synthesis plugin for linear functions. + + + The class `qiskit.transpiler.passes.synthesis.linear_functions_synthesis.LinearFunctionsSynthesis` is deprecated as of qiskit-terra 0.23.0. It will be removed in the Qiskit 1.0 release. Instead, use [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis"). + + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the HighLevelSynthesis pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – input dag. + +**Returns** + +Output dag with higher-level operations synthesized. + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – when the transpiler is unable to synthesize the given DAG +* **(****for instance****, ****when the specified synthesis method is not available****)\*\*\*\*.** – + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsToPermutations.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsToPermutations.md new file mode 100644 index 00000000000..70d12e8ae93 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.LinearFunctionsToPermutations.md @@ -0,0 +1,109 @@ +--- +title: LinearFunctionsToPermutations +description: API reference for qiskit.transpiler.passes.LinearFunctionsToPermutations +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.LinearFunctionsToPermutations +--- + +# LinearFunctionsToPermutations + + + +`qiskit.transpiler.passes.LinearFunctionsToPermutations(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/linear_functions_synthesis.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Promotes linear functions to permutations when possible. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the LinearFunctionsToPermutations pass on dag. :param dag: input dag. + +**Returns** + +Output dag with LinearFunctions synthesized. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.LookaheadSwap.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.LookaheadSwap.md new file mode 100644 index 00000000000..609a0ef0a70 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.LookaheadSwap.md @@ -0,0 +1,145 @@ +--- +title: LookaheadSwap +description: API reference for qiskit.transpiler.passes.LookaheadSwap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.LookaheadSwap +--- + +# LookaheadSwap + + + +`qiskit.transpiler.passes.LookaheadSwap(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/routing/lookahead_swap.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Map input circuit onto a backend topology via insertion of SWAPs. + +Implementation of Sven Jandura’s swap mapper submission for the 2018 Qiskit Developer Challenge, adapted to integrate into the transpiler architecture. + +The role of the swapper pass is to modify the starting circuit to be compatible with the target device’s topology (the set of two-qubit gates available on the hardware.) To do this, the pass will insert SWAP gates to relocate the virtual qubits for each upcoming gate onto a set of coupled physical qubits. However, as SWAP gates are particularly lossy, the goal is to accomplish this remapping while introducing the fewest possible additional SWAPs. + +This algorithm searches through the available combinations of SWAP gates by means of a narrowed best first/beam search, described as follows: + +* Start with a layout of virtual qubits onto physical qubits. +* Find any gates in the input circuit which can be performed with the current layout and mark them as mapped. +* For all possible SWAP gates, calculate the layout that would result from their application and rank them according to the distance of the resulting layout over upcoming gates (see \_calc\_layout\_distance.) +* For the four (search\_width) highest-ranking SWAPs, repeat the above process on the layout that would be generated if they were applied. +* Repeat this process down to a depth of four (search\_depth) SWAPs away from the initial layout, for a total of 256 (search\_width^search\_depth) prospective layouts. +* Choose the layout which maximizes the number of two-qubit which could be performed. Add its mapped gates, including the SWAPs generated, to the output circuit. +* Repeat the above until all gates from the initial circuit are mapped. + +For more details on the algorithm, see Sven’s blog post: [https://medium.com/qiskit/improving-a-quantum-compiler-48410d7a7084](https://medium.com/qiskit/improving-a-quantum-compiler-48410d7a7084) + +LookaheadSwap initializer. + +**Parameters** + +* **coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – CouplingMap of the target backend. +* **search\_depth** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – lookahead tree depth when ranking best SWAP options. +* **search\_width** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – lookahead tree width when ranking best SWAP options. +* **fake\_run** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if true, it will only pretend to do routing, i.e., no swap is effectively added. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the LookaheadSwap pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the directed acyclic graph to be mapped + +**Returns** + +**A dag mapped to be compatible with the coupling\_map in** + +the property\_set. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the coupling map or the layout are not +* **compatible with the DAG**\*\*, or \*\***if the coupling\_map=None** – + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.MergeAdjacentBarriers.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.MergeAdjacentBarriers.md new file mode 100644 index 00000000000..c48fac3fce6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.MergeAdjacentBarriers.md @@ -0,0 +1,138 @@ +--- +title: MergeAdjacentBarriers +description: API reference for qiskit.transpiler.passes.MergeAdjacentBarriers +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.MergeAdjacentBarriers +--- + +# MergeAdjacentBarriers + + + +`qiskit.transpiler.passes.MergeAdjacentBarriers(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/merge_adjacent_barriers.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Return a circuit with any adjacent barriers merged together. + +Only barriers which can be merged without affecting the barrier structure of the DAG will be merged. + +Not all redundant barriers will necessarily be merged, only adjacent barriers are merged. + +For example, the circuit: + +```python +qr = QuantumRegister(3, 'q') +circuit = QuantumCircuit(qr) +circuit.barrier(qr[0]) +circuit.barrier(qr[1]) +circuit.barrier(qr) +``` + +Will be transformed into a circuit corresponding to: + +```python +circuit.barrier(qr[0]) +circuit.barrier(qr) +``` + +i.e, + +```python + ░ ░ ░ ░ +q_0: ─░──░─ q_0: ─░──░─ + ░ ░ ░ ░ +q_1: ─░──░─ => q_1: ────░─ + ░ ░ ░ +q_2: ────░─ q_2: ────░─ + ░ +``` + +after one iteration of the pass. These two barriers were not merged by the first pass as they are not adjacent in the initial circuit. + +The pass then can be reapplied to merge the newly adjacent barriers. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the MergeAdjacentBarriers pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.MinimumPoint.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.MinimumPoint.md new file mode 100644 index 00000000000..d7ca0f3f6fc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.MinimumPoint.md @@ -0,0 +1,121 @@ +--- +title: MinimumPoint +description: API reference for qiskit.transpiler.passes.MinimumPoint +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.MinimumPoint +--- + +# MinimumPoint + + + +`qiskit.transpiler.passes.MinimumPoint(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/minimum_point.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Check if the DAG has reached a relative semi-stable point over previous runs + +This pass is similar to the [`FixedPoint`](qiskit.transpiler.passes.FixedPoint "qiskit.transpiler.passes.FixedPoint") transpiler pass and is intended primarily to be used to set a loop break condition in the property set. However, unlike the [`FixedPoint`](qiskit.transpiler.passes.FixedPoint "qiskit.transpiler.passes.FixedPoint") class which only sets the condition if 2 consecutive runs have the same value property set value this pass is designed to find a local minimum and use that instead. This pass is designed for an optimization loop where a fixed point may never get reached (for example if synthesis is used and there are multiple equivalent outputs for some cases). + +This pass will track the state of fields in the property set over its past executions and set a boolean field when either a fixed point is reached over the backtracking depth or selecting the minimum value found if the backtracking depth is reached. To do this it stores a deep copy of the current minimum DAG in the property set and when `backtrack_depth` number of executions is reached since the last minimum the output dag is set to that copy of the earlier minimum. + +Fields used by this pass in the property set are (all relative to the `prefix` argument): + +* `{prefix}_minimum_point_state` - Used to track the state of the minimum point search + +* **`{prefix}_minimum_point` - This value gets set to `True` when either a fixed point** + + is reached over the `backtrack_depth` executions, or `backtrack_depth` was exceeded and an earlier minimum is restored. + +Initialize an instance of this pass + +**Parameters** + +* **property\_set\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of property set keys that will be used to evaluate the local minimum. The values of these property set keys will be used as a tuple for comparison +* **prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The prefix to use for the property set key that is used for tracking previous evaluations +* **backtrack\_depth** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of entries to store. If this number is reached and the next iteration doesn’t have a decrease in the number of values the minimum of the previous n will be set as the output dag and `minimum_point` will be set to `True` in the property set + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the MinimumPoint pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.NoiseAdaptiveLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.NoiseAdaptiveLayout.md new file mode 100644 index 00000000000..5fcde96fdca --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.NoiseAdaptiveLayout.md @@ -0,0 +1,156 @@ +--- +title: NoiseAdaptiveLayout +description: API reference for qiskit.transpiler.passes.NoiseAdaptiveLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.NoiseAdaptiveLayout +--- + +# NoiseAdaptiveLayout + + + +`qiskit.transpiler.passes.NoiseAdaptiveLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/noise_adaptive_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Choose a noise-adaptive Layout based on current calibration data for the backend. + +> This pass associates a physical qubit (int) to each virtual qubit of the circuit (Qubit), using calibration data. +> +> The pass implements the qubit mapping method from: Noise-Adaptive Compiler Mappings for Noisy Intermediate-Scale Quantum Computers Prakash Murali, Jonathan M. Baker, Ali Javadi-Abhari, Frederic T. Chong, Margaret R. Martonosi ASPLOS 2019 (arXiv:1901.11054). + +`Ordering of edges` + +`Map qubits edge-by-edge in the order of decreasing frequency of occurrence in the program dag.` + +### Initialization + + + +`Initialization()` + +`If an edge exists with both endpoints unmapped,` + +`pick the best available hardware cx to execute this edge.` + +`Iterative step` + +`When an edge exists with one endpoint unmapped,` + +`map that endpoint to a location which allows` + +`maximum reliability for CNOTs with previously mapped qubits.` + +`In the end if there are unmapped qubits (which don't` + +`participate in any CNOT), map them to any available` + +`hardware qubit.` + +### Notes + + + +`Notes()` + +even though a layout is not strictly a property of the DAG, in the transpiler architecture it is best passed around between passes by being set in property\_set. + +NoiseAdaptiveLayout initializer. + + + The class `qiskit.transpiler.passes.layout.noise_adaptive_layout.NoiseAdaptiveLayout` is deprecated as of qiskit 0.46. It will be removed in the 1.0.0 release. + + +**Parameters** + +* **backend\_prop** (*Union\[*[*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – backend properties object +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – Optional. To filter the backend\_prop qubits/gates. This parameter is ignored if [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") is provided in `backend_prop`. That method is preferred. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if invalid options + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the NoiseAdaptiveLayout pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.NormalizeRXAngle.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.NormalizeRXAngle.md new file mode 100644 index 00000000000..e895cfae9d2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.NormalizeRXAngle.md @@ -0,0 +1,156 @@ +--- +title: NormalizeRXAngle +description: API reference for qiskit.transpiler.passes.NormalizeRXAngle +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.NormalizeRXAngle +--- + +# NormalizeRXAngle + + + +`qiskit.transpiler.passes.NormalizeRXAngle(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/normalize_rx_angle.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Normalize theta parameter of RXGate instruction. + +The parameter normalization is performed with following steps. + +1\) Wrap RX Gate theta into \[0, pi]. When theta is negative value, the gate is decomposed into the following sequence. + +```python + ┌───────┐┌─────────┐┌────────┐ +q: ┤ Rz(π) ├┤ Rx(|θ|) ├┤ Rz(-π) ├ + └───────┘└─────────┘└────────┘ +``` + +2. If the operation is supported by target, convert RX(pi/2) to SX, and RX(pi) to X. +3. Quantize theta value according to the user-specified resolution. + +This will help reduce the size of calibration data sent over the wire, and allow us to exploit the more accurate, hardware-calibrated pulses. Note that pulse calibration might be attached per each rotation angle. + +NormalizeRXAngle initializer. + +**Parameters** + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend. If the target contains SX and X calibrations, this pass will replace the corresponding RX gates with SX and X gates. +* **resolution\_in\_radian** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Resolution for RX rotation angle quantization. If set to zero, this pass won’t modify the rotation angles in the given DAG. (=Provides arbitrary-angle RX) + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### quantize\_angles + + + +`quantize_angles(qubit, original_angle)` + +Quantize the RX rotation angles by assigning the same value for the angles that differ within a resolution provided by the user. + +**Parameters** + +* **qubit** ([*Qubit*](qiskit.circuit.Qubit "qiskit.circuit.Qubit")) – This will be the dict key to access the list of quantized rotation angles. +* **original\_angle** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Original rotation angle, before quantization. + +**Returns** + +Quantized angle. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the NormalizeRXAngle pass on `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – The DAG to be optimized. + +**Returns** + +A DAG with RX gate calibration. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.NumTensorFactors.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.NumTensorFactors.md new file mode 100644 index 00000000000..ea2d6c817a0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.NumTensorFactors.md @@ -0,0 +1,103 @@ +--- +title: NumTensorFactors +description: API reference for qiskit.transpiler.passes.NumTensorFactors +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.NumTensorFactors +--- + +# NumTensorFactors + + + +`qiskit.transpiler.passes.NumTensorFactors(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/analysis/num_tensor_factors.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Calculate the number of tensor factors of a DAG circuit. + +The result is saved in `property_set['num_tensor_factors']` as an integer. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the NumTensorFactors pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGates.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGates.md new file mode 100644 index 00000000000..b961c97c5d1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGates.md @@ -0,0 +1,158 @@ +--- +title: Optimize1qGates +description: API reference for qiskit.transpiler.passes.Optimize1qGates +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Optimize1qGates +--- + +# Optimize1qGates + + + +`qiskit.transpiler.passes.Optimize1qGates(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/optimize_1q_gates.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Optimize chains of single-qubit u1, u2, u3 gates by combining them into a single gate. + +Optimize1qGates initializer. + +**Parameters** + +* **basis** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Basis gates to consider, e.g. \[‘u3’, ‘cx’]. For the effects of this pass, the basis is the set intersection between the basis parameter and the set \{‘u1’,’u2’,’u3’, ‘u’, ‘p’}. +* **eps** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – EPS to check against +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `basis` and `target` are specified then this argument will take precedence and `basis` will be ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### compose\_u3 + + + +`static compose_u3(theta1, phi1, lambda1, theta2, phi2, lambda2)` + +Return a triple theta, phi, lambda for the product. + +**u3(theta, phi, lambda)** + +\= u3(theta1, phi1, lambda1).u3(theta2, phi2, lambda2) = Rz(phi1).Ry(theta1).Rz(lambda1+phi2).Ry(theta2).Rz(lambda2) = Rz(phi1).Rz(phi’).Ry(theta’).Rz(lambda’).Rz(lambda2) = u3(theta’, phi1 + phi’, lambda2 + lambda’) + +Return theta, phi, lambda. + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Optimize1qGates pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if `YZY` and `ZYZ` angles do not give same rotation matrix. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + +### yzy\_to\_zyz + + + +`static yzy_to_zyz(xi, theta1, theta2, eps=1e-09)` + +Express a Y.Z.Y single qubit gate as a Z.Y.Z gate. + +Solve the equation + +$$ +$$ + +Ry(theta1).Rz(xi).Ry(theta2) = Rz(phi).Ry(theta).Rz(lambda) + +for theta, phi, and lambda. + +Return a solution theta, phi, and lambda. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesDecomposition.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesDecomposition.md new file mode 100644 index 00000000000..82534b0eef4 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesDecomposition.md @@ -0,0 +1,129 @@ +--- +title: Optimize1qGatesDecomposition +description: API reference for qiskit.transpiler.passes.Optimize1qGatesDecomposition +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Optimize1qGatesDecomposition +--- + +# Optimize1qGatesDecomposition + + + +`qiskit.transpiler.passes.Optimize1qGatesDecomposition(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/optimize_1q_decomposition.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Optimize chains of single-qubit gates by combining them into a single gate. + +**The decision to replace the original chain with a new re-synthesis depends on:** + +* whether the original chain was out of basis: replace +* whether the original chain was in basis but re-synthesis is lower error: replace +* whether the original chain contains a pulse gate: do not replace +* whether the original chain amounts to identity: replace with null + +Error is computed as a multiplication of the errors of individual gates on that qubit. + +Optimize1qGatesDecomposition initializer. + +**Parameters** + +* **basis** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – Basis gates to consider, e.g. \[‘u3’, ‘cx’]. For the effects of this pass, the basis is the set intersection between the basis parameter and the Euler basis. Ignored if `target` is also specified. +* **target** (*Optional\[*[*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object corresponding to the compilation target. When specified, any argument specified for `basis_gates` is ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Optimize1qGatesDecomposition pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.md new file mode 100644 index 00000000000..90dd55fbec6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation.md @@ -0,0 +1,123 @@ +--- +title: Optimize1qGatesSimpleCommutation +description: API reference for qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation +--- + +# Optimize1qGatesSimpleCommutation + + + +`qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/optimize_1q_commutation.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Optimizes 1Q gate strings interrupted by 2Q gates by commuting the components and resynthesizing the results. The commutation rules are stored in `commutation_table`. + +**NOTE: In addition to those mentioned in `commutation_table`, this pass has some limitations:** + +* Does not handle multiple commutations in a row without intermediate progress. +* Can only commute into positions where there are pre-existing runs. +* Does not exhaustively test all the different ways commuting gates can be assigned to either side of a barrier to try to find low-depth configurations. (This is particularly evident if all the gates in a run commute with both the predecessor and the successor barriers.) + +**Parameters** + +* **basis** (*List\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – See also Optimize1qGatesDecomposition. +* **run\_to\_completion** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, this pass retries until it is unable to do any more work. If False, it finds and performs one optimization, and for full optimization the user is obligated to re-call the pass until the output stabilizes. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `basis` and this are specified then this argument will take precedence and `basis` will be ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.OptimizeCliffords.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.OptimizeCliffords.md new file mode 100644 index 00000000000..5adada50bae --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.OptimizeCliffords.md @@ -0,0 +1,113 @@ +--- +title: OptimizeCliffords +description: API reference for qiskit.transpiler.passes.OptimizeCliffords +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.OptimizeCliffords +--- + +# OptimizeCliffords + + + +`qiskit.transpiler.passes.OptimizeCliffords(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/optimize_cliffords.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Combine consecutive Cliffords over the same qubits. This serves as an example of extra capabilities enabled by storing Cliffords natively on the circuit. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the OptimizeCliffords pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDelay.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDelay.md new file mode 100644 index 00000000000..8367f23d71a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDelay.md @@ -0,0 +1,149 @@ +--- +title: PadDelay +description: API reference for qiskit.transpiler.passes.PadDelay +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.PadDelay +--- + +# PadDelay + + + +`qiskit.transpiler.passes.PadDelay(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/padding/pad_delay.py "view source code") + +Bases: `BasePadding` + +Padding idle time with Delay instructions. + +Consecutive delays will be merged in the output of this pass. + +```python +durations = InstructionDurations([("x", None, 160), ("cx", None, 800)]) + +qc = QuantumCircuit(2) +qc.delay(100, 0) +qc.x(1) +qc.cx(0, 1) +``` + +The ASAP-scheduled circuit output may become + +```python + ┌────────────────┐ +q_0: ┤ Delay(160[dt]) ├──■── + └─────┬───┬──────┘┌─┴─┐ +q_1: ──────┤ X ├───────┤ X ├ + └───┘ └───┘ +``` + +Note that the additional idle time of 60dt on the `q_0` wire coming from the duration difference between `Delay` of 100dt (`q_0`) and `XGate` of 160 dt (`q_1`) is absorbed in the delay instruction on the `q_0` wire, i.e. in total 160 dt. + +See `BasePadding` pass for details. + +Create new padding delay pass. + +**Parameters** + +* **fill\_very\_end** – Set `True` to fill the end of circuit with delay. +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend. If it is supplied and does not support delay instruction on a qubit, padding passes do not pad any idle time of the qubit. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the padding pass on `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG to be checked. + +**Returns** + +DAG with idle time filled with instructions. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – When a particular node is not scheduled, likely some transform pass is inserted before this node is called. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDynamicalDecoupling.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDynamicalDecoupling.md new file mode 100644 index 00000000000..43f549986c8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.PadDynamicalDecoupling.md @@ -0,0 +1,207 @@ +--- +title: PadDynamicalDecoupling +description: API reference for qiskit.transpiler.passes.PadDynamicalDecoupling +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.PadDynamicalDecoupling +--- + +# PadDynamicalDecoupling + + + +`qiskit.transpiler.passes.PadDynamicalDecoupling(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/padding/dynamical_decoupling.py "view source code") + +Bases: `BasePadding` + +Dynamical decoupling insertion pass. + +This pass works on a scheduled, physical circuit. It scans the circuit for idle periods of time (i.e. those containing delay instructions) and inserts a DD sequence of gates in those spots. These gates amount to the identity, so do not alter the logical action of the circuit, but have the effect of mitigating decoherence in those idle periods. + +As a special case, the pass allows a length-1 sequence (e.g. `[XGate()]`). In this case the DD insertion happens only when the gate inverse can be absorbed into a neighboring gate in the circuit (so we would still be replacing Delay with something that is equivalent to the identity). This can be used, for instance, as a Hahn echo. + +This pass ensures that the inserted sequence preserves the circuit exactly (including global phase). + +```python +import numpy as np +from qiskit.circuit import QuantumCircuit +from qiskit.circuit.library import XGate +from qiskit.transpiler import PassManager, InstructionDurations +from qiskit.transpiler.passes import ALAPScheduleAnalysis, PadDynamicalDecoupling +from qiskit.visualization import timeline_drawer +circ = QuantumCircuit(4) +circ.h(0) +circ.cx(0, 1) +circ.cx(1, 2) +circ.cx(2, 3) +circ.measure_all() +durations = InstructionDurations( + [("h", 0, 50), ("cx", [0, 1], 700), ("reset", None, 10), + ("cx", [1, 2], 200), ("cx", [2, 3], 300), + ("x", None, 50), ("measure", None, 1000)] +) + +# balanced X-X sequence on all qubits +dd_sequence = [XGate(), XGate()] +pm = PassManager([ALAPScheduleAnalysis(durations), + PadDynamicalDecoupling(durations, dd_sequence)]) +circ_dd = pm.run(circ) +timeline_drawer(circ_dd) + +# Uhrig sequence on qubit 0 +n = 8 +dd_sequence = [XGate()] * n +def uhrig_pulse_location(k): + return np.sin(np.pi * (k + 1) / (2 * n + 2)) ** 2 +spacing = [] +for k in range(n): + spacing.append(uhrig_pulse_location(k) - sum(spacing)) +spacing.append(1 - sum(spacing)) +pm = PassManager( + [ + ALAPScheduleAnalysis(durations), + PadDynamicalDecoupling(durations, dd_sequence, qubits=[0], spacing=spacing), + ] +) +circ_dd = pm.run(circ) +timeline_drawer(circ_dd) +``` + +![../\_images/qiskit-transpiler-passes-PadDynamicalDecoupling-1\_00.png](/images/api/qiskit/0.46/qiskit-transpiler-passes-PadDynamicalDecoupling-1_00.png) + +![../\_images/qiskit-transpiler-passes-PadDynamicalDecoupling-1\_01.png](/images/api/qiskit/0.46/qiskit-transpiler-passes-PadDynamicalDecoupling-1_01.png) + + + You may need to call alignment pass before running dynamical decoupling to guarantee your circuit satisfies acquisition alignment constraints. + + +Dynamical decoupling initializer. + +**Parameters** + +* **durations** – Durations of instructions to be used in scheduling. + +* **dd\_sequence** – Sequence of gates to apply in idle spots. + +* **qubits** – Physical qubits on which to apply DD. If None, all qubits will undergo DD (when possible). + +* **spacing** – A list of spacings between the DD gates. The available slack will be divided according to this. The list length must be one more than the length of dd\_sequence, and the elements must sum to 1. If None, a balanced spacing will be used \[d/2, d, d, …, d, d, d/2]. + +* **skip\_reset\_qubits** – If True, does not insert DD on idle periods that immediately follow initialized/reset qubits (as qubits in the ground state are less susceptile to decoherence). + +* **pulse\_alignment** – The hardware constraints for gate timing allocation. This is usually provided from `backend.configuration().timing_constraints`. If provided, the delay length, i.e. `spacing`, is implicitly adjusted to satisfy this constraint. + +* **extra\_slack\_distribution** – + + The option to control the behavior of DD sequence generation. The duration of the DD sequence should be identical to an idle time in the scheduled quantum circuit, however, the delay in between gates comprising the sequence should be integer number in units of dt, and it might be further truncated when `pulse_alignment` is specified. This sometimes results in the duration of the created sequence being shorter than the idle time that you want to fill with the sequence, i.e. extra slack. This option takes following values. + + > * ”middle”: Put the extra slack to the interval at the middle of the sequence. + > * ”edges”: Divide the extra slack as evenly as possible into intervals at beginning and end of the sequence. + +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `durations` and this are specified then this argument will take precedence and `durations` will be ignored. + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – When invalid DD sequence is specified. +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – When pulse gate with the duration which is non-multiple of the alignment constraint value is found. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If `dd_sequence` is not specified + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the padding pass on `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG to be checked. + +**Returns** + +DAG with idle time filled with instructions. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – When a particular node is not scheduled, likely some transform pass is inserted before this node is called. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.PulseGates.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.PulseGates.md new file mode 100644 index 00000000000..4ca7833a085 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.PulseGates.md @@ -0,0 +1,178 @@ +--- +title: PulseGates +description: API reference for qiskit.transpiler.passes.PulseGates +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.PulseGates +--- + +# PulseGates + + + +`qiskit.transpiler.passes.PulseGates(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/calibration/pulse_gate.py "view source code") + +Bases: `CalibrationBuilder` + +Pulse gate adding pass. + +This pass adds gate calibrations from the supplied `InstructionScheduleMap` to a quantum circuit. + +This pass checks each DAG circuit node and acquires a corresponding schedule from the instruction schedule map object that may be provided by the target backend. Because this map is a mutable object, the end-user can provide a configured backend to execute the circuit with customized gate implementations. + +This mapping object returns a schedule with “publisher” metadata which is an integer Enum value representing who created the gate schedule. If the gate schedule is provided by end-users, this pass attaches the schedule to the DAG circuit as a calibration. + +This pass allows users to easily override quantum circuit with custom gate definitions without directly dealing with those schedules. + +**References** + +* \[1] OpenQASM 3: A broader and deeper quantum assembly language [https://arxiv.org/abs/2104.14722](https://arxiv.org/abs/2104.14722) + +Create new pass. + +**Parameters** + +* **inst\_map** – Instruction schedule map that user may override. +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `inst_map` and `target` are specified then it updates instructions in the `target` with `inst_map`. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### get\_calibration + + + +`get_calibration(node_op, qubits)` + +Gets the calibrated schedule for the given instruction and qubits. + +**Parameters** + +* **node\_op** ([*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – Target instruction object. +* **qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")) – Integer qubit indices to check. + +**Returns** + +Return Schedule of target gate instruction. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – When node is parameterized and calibration is raw schedule object. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") | [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the calibration adder pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A DAG with calibrations added to it. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### supported + + + +`supported(node_op, qubits)` + +Determine if a given node supports the calibration. + +**Parameters** + +* **node\_op** ([*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – Target instruction object. +* **qubits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")) – Integer qubit indices to check. + +**Returns** + +Return `True` is calibration can be provided. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.RXCalibrationBuilder.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RXCalibrationBuilder.md new file mode 100644 index 00000000000..6f724095bd2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RXCalibrationBuilder.md @@ -0,0 +1,187 @@ +--- +title: RXCalibrationBuilder +description: API reference for qiskit.transpiler.passes.RXCalibrationBuilder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RXCalibrationBuilder +--- + +# RXCalibrationBuilder + + + +`qiskit.transpiler.passes.RXCalibrationBuilder(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/calibration/rx_builder.py "view source code") + +Bases: `CalibrationBuilder` + +Add single-pulse RX calibrations that are bootstrapped from the SX calibration. + + + Requirement: NormalizeRXAngles pass (one of the optimization passes). + + +It is recommended to place this pass in the post-optimization stage of a passmanager. A simple demo: + +```python +from qiskit.providers.fake_provider import FakeBelemV2 +from qiskit.transpiler import PassManager, PassManagerConfig +from qiskit.transpiler.preset_passmanagers import level_1_pass_manager +from qiskit.circuit import Parameter +from qiskit.circuit.library import QuantumVolume +from qiskit.circuit.library.standard_gates import RXGate + +from calibration.rx_builder import RXCalibrationBuilder + +qv = QuantumVolume(4, 4, seed=1004) + +# Transpiling with single pulse RX gates enabled +backend_with_single_pulse_rx = FakeBelemV2() +rx_inst_props = {} +for i in range(backend_with_single_pulse_rx.num_qubits): + rx_inst_props[(i,)] = None +backend_with_single_pulse_rx.target.add_instruction(RXGate(Parameter("theta")), rx_inst_props) +config_with_rx = PassManagerConfig.from_backend(backend=backend_with_single_pulse_rx) +pm_with_rx = level_1_pass_manager(pass_manager_config=config_with_rx) +rx_builder = RXCalibrationBuilder(target=backend_with_single_pulse_rx.target) +pm_with_rx.post_optimization = PassManager([rx_builder]) +transpiled_circ_with_single_pulse_rx = pm_with_rx.run(qv) +transpiled_circ_with_single_pulse_rx.count_ops() + +# Conventional transpilation: each RX gate is decomposed into a sequence with two SX gates +original_backend = FakeBelemV2() +original_config = PassManagerConfig.from_backend(backend=original_backend) +original_pm = level_1_pass_manager(pass_manager_config=original_config) +original_transpiled_circ = original_pm.run(qv) +original_transpiled_circ.count_ops() +``` + +**References** + +* \[1]: Gokhale et al. (2020), Optimized Quantum Compilation for Near-Term Algorithms with OpenPulse. arXiv:2004.11205 \<[https://arxiv.org/abs/2004.11205](https://arxiv.org/abs/2004.11205)> + +Bootstrap single-pulse RX gate calibrations from the (hardware-calibrated) SX gate calibration. + +**Parameters** + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – Should contain a SX calibration that will be +* **calibrations.** (*used for bootstrapping RX*) – + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### get\_calibration + + + +`get_calibration(node_op, qubits)` + +Generate RX calibration for the rotation angle specified in node\_op. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") | [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the calibration adder pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A DAG with calibrations added to it. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### supported + + + +`supported(node_op, qubits)` + +Check if the calibration for SX gate exists and it’s a single DRAG pulse. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilder.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilder.md new file mode 100644 index 00000000000..6077af8f5fc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilder.md @@ -0,0 +1,199 @@ +--- +title: RZXCalibrationBuilder +description: API reference for qiskit.transpiler.passes.RZXCalibrationBuilder +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilder +--- + +# RZXCalibrationBuilder + + + +`qiskit.transpiler.passes.RZXCalibrationBuilder(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/calibration/rzx_builder.py "view source code") + +Bases: `CalibrationBuilder` + +Creates calibrations for RZXGate(theta) by stretching and compressing Gaussian square pulses in the CX gate. This is done by retrieving (for a given pair of qubits) the CX schedule in the instruction schedule map of the backend defaults. The CX schedule must be an echoed cross-resonance gate optionally with rotary tones. The cross-resonance drive tones and rotary pulses must be Gaussian square pulses. The width of the Gaussian square pulse is adjusted so as to match the desired rotation angle. If the rotation angle is small such that the width disappears then the amplitude of the zero width Gaussian square pulse (i.e. a Gaussian) is reduced to reach the target rotation angle. Additional details can be found in [https://arxiv.org/abs/2012.11660](https://arxiv.org/abs/2012.11660). + +Initializes a RZXGate calibration builder. + +**Parameters** + +* **instruction\_schedule\_map** – The `InstructionScheduleMap` object representing the default pulse calibrations for the target backend +* **verbose** – Set True to raise a user warning when RZX schedule cannot be built. +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `instruction_schedule_map` and this are specified then this argument will take precedence and `instruction_schedule_map` will be ignored. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – Instruction schedule map is not provided. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### get\_calibration + + + +`get_calibration(node_op, qubits)` + +Builds the calibration schedule for the RZXGate(theta) with echos. + +**Parameters** + +* **node\_op** (*CircuitInst*) – Instruction of the RZXGate(theta). I.e. params\[0] is theta. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of qubits for which to get the schedules. The first qubit is the control and the second is the target. + +**Returns** + +The calibration schedule for the RZXGate(theta). + +**Return type** + +schedule + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if rotation angle is not assigned. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the control and target qubits cannot be identified. +* **CalibrationNotAvailable** – RZX schedule cannot be built for input node. + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### rescale\_cr\_inst + + + +`static rescale_cr_inst(instruction, theta, sample_mult=16)` + +A builder macro to play stretched pulse. + +**Parameters** + +* **instruction** ([*Play*](qiskit.pulse.instructions.Play "qiskit.pulse.instructions.play.Play")) – The instruction from which to create a new shortened or lengthened pulse. +* **theta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – desired angle, pi/2 is assumed to be the angle that the pulse in the given play instruction implements. +* **sample\_mult** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – All pulses must be a multiple of sample\_mult. + +**Returns** + +Duration of stretched pulse. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if rotation angle is not assigned. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the calibration adder pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A DAG with calibrations added to it. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### supported + + + +`supported(node_op, qubits)` + +Determine if a given node supports the calibration. + +**Parameters** + +* **node\_op** ([*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – Target instruction object. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Integer qubit indices to check. + +**Returns** + +Return `True` is calibration can be provided. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.md new file mode 100644 index 00000000000..fe8213e1c4e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho.md @@ -0,0 +1,201 @@ +--- +title: RZXCalibrationBuilderNoEcho +description: API reference for qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho +--- + +# RZXCalibrationBuilderNoEcho + + + +`qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/calibration/rzx_builder.py "view source code") + +Bases: [`RZXCalibrationBuilder`](qiskit.transpiler.passes.RZXCalibrationBuilder "qiskit.transpiler.passes.calibration.rzx_builder.RZXCalibrationBuilder") + +Creates calibrations for RZXGate(theta) by stretching and compressing Gaussian square pulses in the CX gate. + +The `RZXCalibrationBuilderNoEcho` is a variation of the [`RZXCalibrationBuilder`](qiskit.transpiler.passes.RZXCalibrationBuilder "qiskit.transpiler.passes.RZXCalibrationBuilder") pass that creates calibrations for the cross-resonance pulses without inserting the echo pulses in the pulse schedule. This enables exposing the echo in the cross-resonance sequence as gates so that the transpiler can simplify them. The `RZXCalibrationBuilderNoEcho` only supports the hardware-native direction of the CX gate. + +Initializes a RZXGate calibration builder. + +**Parameters** + +* **instruction\_schedule\_map** – The `InstructionScheduleMap` object representing the default pulse calibrations for the target backend +* **verbose** – Set True to raise a user warning when RZX schedule cannot be built. +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `instruction_schedule_map` and this are specified then this argument will take precedence and `instruction_schedule_map` will be ignored. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – Instruction schedule map is not provided. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### get\_calibration + + + +`get_calibration(node_op, qubits)` + +Builds the calibration schedule for the RZXGate(theta) without echos. + +**Parameters** + +* **node\_op** (*CircuitInst*) – Instruction of the RZXGate(theta). I.e. params\[0] is theta. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of qubits for which to get the schedules. The first qubit is the control and the second is the target. + +**Returns** + +The calibration schedule for the RZXGate(theta). + +**Return type** + +schedule + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if rotation angle is not assigned. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the control and target qubits cannot be identified, or the backend does not natively support the specified direction of the cx. +* **CalibrationNotAvailable** – RZX schedule cannot be built for input node. + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### rescale\_cr\_inst + + + +`static rescale_cr_inst(instruction, theta, sample_mult=16)` + +A builder macro to play stretched pulse. + +**Parameters** + +* **instruction** ([*Play*](qiskit.pulse.instructions.Play "qiskit.pulse.instructions.play.Play")) – The instruction from which to create a new shortened or lengthened pulse. +* **theta** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – desired angle, pi/2 is assumed to be the angle that the pulse in the given play instruction implements. +* **sample\_mult** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – All pulses must be a multiple of sample\_mult. + +**Returns** + +Duration of stretched pulse. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if rotation angle is not assigned. + +**Return type** + +[int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the calibration adder pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG to schedule. + +**Returns** + +A DAG with calibrations added to it. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### supported + + + +`supported(node_op, qubits)` + +Determine if a given node supports the calibration. + +**Parameters** + +* **node\_op** ([*Instruction*](qiskit.circuit.Instruction "qiskit.circuit.instruction.Instruction")) – Target instruction object. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Integer qubit indices to check. + +**Returns** + +Return `True` is calibration can be provided. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveBarriers.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveBarriers.md new file mode 100644 index 00000000000..a4249a78175 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveBarriers.md @@ -0,0 +1,124 @@ +--- +title: RemoveBarriers +description: API reference for qiskit.transpiler.passes.RemoveBarriers +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RemoveBarriers +--- + +# RemoveBarriers + + + +`qiskit.transpiler.passes.RemoveBarriers(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/remove_barriers.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Return a circuit with any barrier removed. + +This transformation is not semantics preserving. + +**Example** + +```python +from qiskit import QuantumCircuit +from qiskit.transpiler.passes import RemoveBarriers + +circuit = QuantumCircuit(1) +circuit.x(0) +circuit.barrier() +circuit.h(0) + +circuit = RemoveBarriers()(circuit) +circuit.draw('mpl') +``` + +![../\_images/qiskit-transpiler-passes-RemoveBarriers-1.png](/images/api/qiskit/0.46/qiskit-transpiler-passes-RemoveBarriers-1.png) + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the RemoveBarriers pass on dag. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.md new file mode 100644 index 00000000000..dbff6dac4d6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure.md @@ -0,0 +1,115 @@ +--- +title: RemoveDiagonalGatesBeforeMeasure +description: API reference for qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure +--- + +# RemoveDiagonalGatesBeforeMeasure + + + +`qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/remove_diagonal_gates_before_measure.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Remove diagonal gates (including diagonal 2Q gates) before a measurement. + +Transpiler pass to remove diagonal gates (like RZ, T, Z, etc) before a measurement. Including diagonal 2Q gates. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the RemoveDiagonalGatesBeforeMeasure pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveFinalMeasurements.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveFinalMeasurements.md new file mode 100644 index 00000000000..1290c6effa1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveFinalMeasurements.md @@ -0,0 +1,117 @@ +--- +title: RemoveFinalMeasurements +description: API reference for qiskit.transpiler.passes.RemoveFinalMeasurements +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RemoveFinalMeasurements +--- + +# RemoveFinalMeasurements + + + +`qiskit.transpiler.passes.RemoveFinalMeasurements(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/remove_final_measurements.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Remove final measurements and barriers at the end of a circuit. + +This pass removes final barriers and final measurements, as well as all unused classical registers and bits they are connected to. Measurements and barriers are considered final if they are followed by no other operations (aside from other measurements or barriers.) + +Classical registers are removed iff they reference at least one bit that has become unused by the circuit as a result of the operation, and all of their other bits are also unused. Separately, classical bits are removed iff they have become unused by the circuit as a result of the operation, or they appear in a removed classical register, but do not appear in a classical register that will remain. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the RemoveFinalMeasurements pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveResetInZeroState.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveResetInZeroState.md new file mode 100644 index 00000000000..bc6e9e5e98d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.RemoveResetInZeroState.md @@ -0,0 +1,113 @@ +--- +title: RemoveResetInZeroState +description: API reference for qiskit.transpiler.passes.RemoveResetInZeroState +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.RemoveResetInZeroState +--- + +# RemoveResetInZeroState + + + +`qiskit.transpiler.passes.RemoveResetInZeroState(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/remove_reset_in_zero_state.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Remove reset gate when the qubit is in zero state. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the RemoveResetInZeroState pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the DAG to be optimized. + +**Returns** + +the optimized DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ResetAfterMeasureSimplification.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ResetAfterMeasureSimplification.md new file mode 100644 index 00000000000..97c2ebc6fe9 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ResetAfterMeasureSimplification.md @@ -0,0 +1,103 @@ +--- +title: ResetAfterMeasureSimplification +description: API reference for qiskit.transpiler.passes.ResetAfterMeasureSimplification +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ResetAfterMeasureSimplification +--- + +# ResetAfterMeasureSimplification + + + +`qiskit.transpiler.passes.ResetAfterMeasureSimplification(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/reset_after_measure_simplification.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +This pass replaces reset after measure with a conditional X gate. + +This optimization is suitable for use on IBM Quantum systems where the reset operation is performed by a measurement followed by a conditional x-gate. It might not be desirable on other backends if reset is implemented differently. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the pass on a dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreLayout.md new file mode 100644 index 00000000000..eae67a11425 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreLayout.md @@ -0,0 +1,213 @@ +--- +title: SabreLayout +description: API reference for qiskit.transpiler.passes.SabreLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.SabreLayout +--- + +# SabreLayout + + + +`qiskit.transpiler.passes.SabreLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/sabre_layout.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Choose a Layout via iterative bidirectional routing of the input circuit. + +Starting with a random initial Layout, the algorithm does a full routing of the circuit (via the routing\_pass method) to end up with a final\_layout. This final\_layout is then used as the initial\_layout for routing the reverse circuit. The algorithm iterates a number of times until it finds an initial\_layout that reduces full routing cost. + +This method exploits the reversibility of quantum circuits, and tries to include global circuit information in the choice of initial\_layout. + +By default, this pass will run both layout and routing and will transform the circuit so that the layout is applied to the input dag (meaning that the output circuit will have ancilla qubits allocated for unused qubits on the coupling map and the qubits will be reordered to match the mapped physical qubits) and then routing will be applied (inserting `AnalysisPass` objects and just find an initial layout and set that on the property set. This is done because by default the pass will run parallel seed trials with different random seeds for selecting the random initial layout and then selecting the routed output which results in the least number of swap gates needed. + +You can use the `routing_pass` argument to have this pass operate as a typical layout pass. When specified this will use the specified routing pass to select an initial layout only and will not run multiple seed trials. + +In addition to starting with a random initial Layout the pass can also take in an additional list of starting layouts which will be used for additional trials. If the `sabre_starting_layouts` is present in the property set when this pass is run, that will be used for additional trials. There will still be `layout_trials` of full random starting layouts run and the contents of `sabre_starting_layouts` will be run in addition to those. The output which results in the lowest amount of swap gates (whether from the random trials or the property set starting point) will be used. The value for this property set field should be a list of [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") objects representing the starting layouts to use. If a virtual qubit is missing from an [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object in the list a random qubit will be selected. + +## Property Set Fields Read + +**`sabre_starting_layouts` (`list[Layout]`)** + +An optional list of [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") objects to use for additional layout trials. This is in addition to the full random trials specified with the `layout_trials` argument. + +## Property Set Values Written + +**`layout` ([`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout"))** + +The chosen initial mapping of virtual to physical qubits, including the ancilla allocation. + +**`final_layout` ([`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout"))** + +A permutation of how swaps have been applied to the input qubits at the end of the circuit. + +**References:** + +\[1] Li, Gushu, Yufei Ding, and Yuan Xie. “Tackling the qubit mapping problem for NISQ-era quantum devices.” ASPLOS 2019. [arXiv:1809.02573](https://arxiv.org/pdf/1809.02573.pdf) + +SabreLayout initializer. + +**param coupling\_map** + +directed graph representing a coupling map. + +**type coupling\_map** + +Union\[CouplingMap, Target] + +**param routing\_pass** + +the routing pass to use while iterating. If specified this pass operates as an [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.AnalysisPass") and will only populate the `layout` field in the property set and the input dag is returned unmodified. This argument is mutually exclusive with the `swap_trials` and the `layout_trials` arguments and if this is specified at the same time as either argument an error will be raised. + +**type routing\_pass** + +BasePass + +**param seed** + +seed for setting a random first trial layout. + +**type seed** + +int + +**param max\_iterations** + +number of forward-backward iterations. + +**type max\_iterations** + +int + +**param swap\_trials** + +The number of trials to run of [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap") for each iteration. This is equivalent to the `trials` argument on [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap"). If this is not specified (and `routing_pass` isn’t set) by default the number of physical CPUs on your local system will be used. For reproducibility between environments it is best to set this to an explicit number because the output will potentially depend on the number of trials run. This option is mutually exclusive with the `routing_pass` argument and an error will be raised if both are used. + +**type swap\_trials** + +int + +**param layout\_trials** + +The number of random seed trials to run layout with. When > 1 the trial that resuls in the output with the fewest swap gates will be selected. If this is not specified (and `routing_pass` is not set) then the number of local physical CPUs will be used as the default value. This option is mutually exclusive with the `routing_pass` argument and an error will be raised if both are used. + +**type layout\_trials** + +int + +**param skip\_routing** + +If this is set `True` and `routing_pass` is not used then routing will not be applied to the output circuit. Only the layout will be set in the property set. This is a tradeoff to run custom routing with multiple layout trials, as using this option will cause SabreLayout to run the routing stage internally but not use that result. + +**type skip\_routing** + +bool + +**raises TranspilerError** + +If both `routing_pass` and `swap_trials` or + +**raises both `routing_pass` and `layout_trials` are specified** + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the SabreLayout pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to find layout for. + +**Returns** + +**The output dag if swap mapping was run** + +(otherwise the input dag is returned unmodified). + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if dag wider than self.coupling\_map + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabrePreLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabrePreLayout.md new file mode 100644 index 00000000000..9bd5a6555b6 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabrePreLayout.md @@ -0,0 +1,171 @@ +--- +title: SabrePreLayout +description: API reference for qiskit.transpiler.passes.SabrePreLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.SabrePreLayout +--- + +# SabrePreLayout + + + +`qiskit.transpiler.passes.SabrePreLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/sabre_pre_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Choose a starting layout to use for additional Sabre layout trials. + +## Property Set Values Written + +**`sabre_starting_layouts` (`list[Layout]`)** + +An optional list of [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") objects to use for additional Sabre layout trials. + +SabrePreLayout initializer. + +The pass works by augmenting the coupling map with more and more “extra” edges until VF2 succeeds to find a perfect graph isomorphism. More precisely, the augmented coupling map contains edges between nodes that are within a given distance `d` in the original coupling map, and the value of `d` is increased until an isomorphism is found. + +Intuitively, a better layout involves fewer extra edges. The pass also optionally minimizes the number of extra edges involved in the layout until a local minimum is found. This involves removing extra edges and running VF2 to see if an isomorphism still exists. + +**param coupling\_map** + +directed graph representing the original coupling map or a target modelling the backend (including its connectivity). + +**type coupling\_map** + +Union\[CouplingMap, Target] + +**param max\_distance** + +the maximum distance to consider for augmented coupling maps. + +**type max\_distance** + +int + +**param error\_rate** + +the error rate to assign to the “extra” edges. A non-zero error rate prioritizes VF2 to choose original edges over extra edges. + +**type error\_rate** + +float + +**param max\_trials\_vf2** + +specifies the maximum number of VF2 trials. A larger number allows VF2 to explore more layouts, eventually choosing the one with the smallest error rate. + +**type max\_trials\_vf2** + +int + +**param call\_limit\_vf2** + +limits each call to VF2 by bounding the number of VF2 state visits. + +**type call\_limit\_vf2** + +int + +**param improve\_layout** + +whether to improve the layout by minimizing the number of extra edges involved. This might be time-consuming as this requires additional VF2 calls. + +**type improve\_layout** + +bool + +**raises TranspilerError** + +At runtime, if neither `coupling_map` or `target` are provided. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the SabrePreLayout pass on dag. + +The discovered starting layout is written to the property set value `sabre_starting_layouts`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to create starting layout for. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreSwap.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreSwap.md new file mode 100644 index 00000000000..5ae0a1a749d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SabreSwap.md @@ -0,0 +1,178 @@ +--- +title: SabreSwap +description: API reference for qiskit.transpiler.passes.SabreSwap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.SabreSwap +--- + +# SabreSwap + + + +`qiskit.transpiler.passes.SabreSwap(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/routing/sabre_swap.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Map input circuit onto a backend topology via insertion of SWAPs. + +Implementation of the SWAP-based heuristic search from the SABRE qubit mapping paper \[1] (Algorithm 1). The heuristic aims to minimize the number of lossy SWAPs inserted and the depth of the circuit. + +This algorithm starts from an initial layout of virtual qubits onto physical qubits, and iterates over the circuit DAG until all gates are exhausted, inserting SWAPs along the way. It only considers 2-qubit gates as only those are germane for the mapping problem (it is assumed that 3+ qubit gates are already decomposed). + +In each iteration, it will first check if there are any gates in the `front_layer` that can be directly applied. If so, it will apply them and remove them from `front_layer`, and replenish that layer with new gates if possible. Otherwise, it will try to search for SWAPs, insert the SWAPs, and update the mapping. + +The search for SWAPs is restricted, in the sense that we only consider physical qubits in the neighborhood of those qubits involved in `front_layer`. These give rise to a `swap_candidate_list` which is scored according to some heuristic cost function. The best SWAP is implemented and `current_layout` updated. + +This transpiler pass adds onto the SABRE algorithm in that it will run multiple trials of the algorithm with different seeds. The best output, determined by the trial with the least amount of SWAPed inserted, will be selected from the random trials. + +**References:** + +\[1] Li, Gushu, Yufei Ding, and Yuan Xie. “Tackling the qubit mapping problem for NISQ-era quantum devices.” ASPLOS 2019. [arXiv:1809.02573](https://arxiv.org/pdf/1809.02573.pdf) + +SabreSwap initializer. + +**Parameters** + +* **coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – CouplingMap of the target backend. +* **heuristic** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The type of heuristic to use when deciding best swap strategy (‘basic’ or ‘lookahead’ or ‘decay’). +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – random seed used to tie-break among candidate swaps. +* **fake\_run** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if true, it only pretend to do routing, i.e., no swap is effectively added. +* **trials** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of seed trials to run sabre with. These will be run in parallel (unless the PassManager is already running in parallel). If not specified this defaults to the number of physical CPUs on the local system. For reproducible results it is recommended that you set this explicitly, as the output will be deterministic for a fixed number of trials. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the specified heuristic is not valid. + +Additional Information: + +> The search space of possible SWAPs on physical qubits is explored by assigning a score to the layout that would result from each SWAP. The goodness of a layout is evaluated based on how viable it makes the remaining virtual gates that must be applied. A few heuristic cost functions are supported +> +> * ‘basic’: +> +> The sum of distances for corresponding physical qubits of interacting virtual qubits in the front\_layer. +> +> $$ +> H_{basic} = \sum_{gate \in F} D[\pi(gate.q_1)][\pi(gate.q2)] +> $$ +> +> * ‘lookahead’: +> +> This is the sum of two costs: first is the same as the basic cost. Second is the basic cost but now evaluated for the extended set as well (i.e. $|E|$ number of upcoming successors to gates in front\_layer F). This is weighted by some amount EXTENDED\_SET\_WEIGHT (W) to signify that upcoming gates are less important that the front\_layer. +> +> $$ +> H_{decay}=\frac{1}{\left|{F}\right|}\sum_{gate \in F} D[\pi(gate.q_1)][\pi(gate.q2)] +> + W*\frac{1}{\left|{E}\right|} \sum_{gate \in E} D[\pi(gate.q_1)][\pi(gate.q2)] +> $$ +> +> * ‘decay’: +> +> This is the same as ‘lookahead’, but the whole cost is multiplied by a decay factor. This increases the cost if the SWAP that generated the trial layout was recently used (i.e. it penalizes increase in depth). +> +> $$ +> H_{decay} = max(decay(SWAP.q_1), decay(SWAP.q_2)) { +> \frac{1}{\left|{F}\right|} \sum_{gate \in F} D[\pi(gate.q_1)][\pi(gate.q2)]\\ +> + W *\frac{1}{\left|{E}\right|} \sum_{gate \in E} D[\pi(gate.q_1)][\pi(gate.q2)] +> } +> $$ + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the SabreSwap pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the directed acyclic graph to be mapped. + +**Returns** + +A dag mapped to be compatible with the coupling\_map. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the coupling map or the layout are not +* **compatible with the DAG**\*\*, or \*\***if the coupling\_map=None** – + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.SetIOLatency.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SetIOLatency.md new file mode 100644 index 00000000000..e72663345e8 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SetIOLatency.md @@ -0,0 +1,116 @@ +--- +title: SetIOLatency +description: API reference for qiskit.transpiler.passes.SetIOLatency +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.SetIOLatency +--- + +# SetIOLatency + + + +`qiskit.transpiler.passes.SetIOLatency(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/scheduling/set_io_latency.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Set IOLatency information to the input circuit. + +The `clbit_write_latency` and `conditional_latency` are added to the property set of pass manager. This information can be shared among the passes that perform scheduling on instructions acting on classical registers. + +Once these latencies are added to the property set, this information is also copied to the output circuit object as protected attributes, so that it can be utilized outside the transpilation, for example, the timeline visualization can use latency to accurately show time occupation by instructions on the classical registers. + +Create pass with latency information. + +**Parameters** + +* **clbit\_write\_latency** – A control flow constraints. Because standard superconducting quantum processor implement dispersive QND readout, the actual data transfer to the clbit happens after the round-trip stimulus signal is buffered and discriminated into quantum state. The interval `[t0, t0 + clbit_write_latency]` is regarded as idle time for clbits associated with the measure instruction. This defaults to 0 dt which is identical to Qiskit Pulse scheduler. +* **conditional\_latency** – A control flow constraints. This value represents a latency of reading a classical register for the conditional operation. The gate operation occurs after this latency. This appears as a delay in front of the DAGOpNode of the gate. This defaults to 0 dt. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Add IO latency information. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – Input DAG circuit. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.SetLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SetLayout.md new file mode 100644 index 00000000000..424bc58d081 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SetLayout.md @@ -0,0 +1,126 @@ +--- +title: SetLayout +description: API reference for qiskit.transpiler.passes.SetLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.SetLayout +--- + +# SetLayout + + + +`qiskit.transpiler.passes.SetLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/set_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Set the `layout` property to the given layout. + +This pass associates a physical qubit (int) to each virtual qubit of the circuit (Qubit) in increasing order. + +SetLayout initializer. + +**Parameters** + +**layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout") *or List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – + +the layout to set. It can be: + +* a `Layout` instance: sets that layout. +* a list of integers: takes the index in the list as the physical position in which the virtual qubit is going to be mapped. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the SetLayout pass on `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to map. + +**Returns** + +the original DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Size.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Size.md new file mode 100644 index 00000000000..7af39522547 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Size.md @@ -0,0 +1,107 @@ +--- +title: Size +description: API reference for qiskit.transpiler.passes.Size +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Size +--- + +# Size + + + +`qiskit.transpiler.passes.Size(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/analysis/size.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Calculate the size of a DAG circuit. + +The result is saved in `property_set['size']` as an integer. + +**Parameters** + +**recurse** – whether to allow recursion into control flow. If this is `False` (default), the pass will throw an error when control flow is present, to avoid returning a number with little meaning. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Size pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaev.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaev.md new file mode 100644 index 00000000000..41956f4a5a2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaev.md @@ -0,0 +1,206 @@ +--- +title: SolovayKitaev +description: API reference for qiskit.transpiler.passes.SolovayKitaev +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.SolovayKitaev +--- + +# SolovayKitaev + + + +`qiskit.transpiler.passes.SolovayKitaev(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Approximately decompose 1q gates to a discrete basis using the Solovay-Kitaev algorithm. + +The Solovay-Kitaev theorem \[1] states that any single qubit gate can be approximated to arbitrary precision by a set of fixed single-qubit gates, if the set generates a dense subset in $SU(2)$. This is an important result, since it means that any single-qubit gate can be expressed in terms of a discrete, universal gate set that we know how to implement fault-tolerantly. Therefore, the Solovay-Kitaev algorithm allows us to take any non-fault tolerant circuit and rephrase it in a fault-tolerant manner. + +This implementation of the Solovay-Kitaev algorithm is based on \[2]. + +For example, the following circuit + +```python + ┌─────────┐ +q_0: ┤ RX(0.8) ├ + └─────────┘ +``` + +can be decomposed into + +```python +global phase: 7π/8 + ┌───┐┌───┐┌───┐ +q_0: ┤ H ├┤ T ├┤ H ├ + └───┘└───┘└───┘ +``` + +with an L2-error of approximately 0.01. + +**Examples** + +Per default, the basis gate set is `["t", "tdg", "h"]`: + +```python +import numpy as np +from qiskit.circuit import QuantumCircuit +from qiskit.transpiler.passes.synthesis import SolovayKitaev +from qiskit.quantum_info import Operator + +circuit = QuantumCircuit(1) +circuit.rx(0.8, 0) + +print("Original circuit:") +print(circuit.draw()) + +skd = SolovayKitaev(recursion_degree=2) + +discretized = skd(circuit) + +print("Discretized circuit:") +print(discretized.draw()) + +print("Error:", np.linalg.norm(Operator(circuit).data - Operator(discretized).data)) +``` + +```python +Original circuit: + ┌─────────┐ +q: ┤ Rx(0.8) ├ + └─────────┘ +Discretized circuit: +global phase: 7π/8 + ┌───┐┌───┐┌───┐ +q: ┤ H ├┤ T ├┤ H ├ + └───┘└───┘└───┘ +Error: 2.828408279166474 +``` + +For individual basis gate sets, the `generate_basic_approximations` function can be used: + +```python +from qiskit.synthesis import generate_basic_approximations +from qiskit.transpiler.passes import SolovayKitaev + +basis = ["s", "sdg", "t", "tdg", "z", "h"] +approx = generate_basic_approximations(basis, depth=3) + +skd = SolovayKitaev(recursion_degree=2, basic_approximations=approx) +``` + +**References** + +**\[1]: Kitaev, A Yu (1997). Quantum computations: algorithms and error correction.** + +Russian Mathematical Surveys. 52 (6): 1191–1249. [Online](https://iopscience.iop.org/article/10.1070/RM1997v052n06ABEH002155). + +**\[2]: Dawson, Christopher M.; Nielsen, Michael A. (2005) The Solovay-Kitaev Algorithm.** + +[arXiv:quant-ph/0505030](https://arxiv.org/abs/quant-ph/0505030). + +**Parameters** + +* **recursion\_degree** – The recursion depth for the Solovay-Kitaev algorithm. A larger recursion depth increases the accuracy and length of the decomposition. +* **basic\_approximations** – The basic approximations for the finding the best discrete decomposition at the root of the recursion. If a string, it specifies the `.npy` file to load the approximations from. If a dictionary, it contains `{label: SO(3)-matrix}` pairs. If None, a default based on the H, T and Tdg gates up to combinations of depth 10 is generated. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the `SolovayKitaev` pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – The input dag. + +**Returns** + +Output dag with 1q gates synthesized in the discrete target basis. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if a gates does not have to\_matrix + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaevSynthesis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaevSynthesis.md new file mode 100644 index 00000000000..662da059c88 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.SolovayKitaevSynthesis.md @@ -0,0 +1,173 @@ +--- +title: SolovayKitaevSynthesis +description: API reference for qiskit.transpiler.passes.SolovayKitaevSynthesis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.SolovayKitaevSynthesis +--- + +# SolovayKitaevSynthesis + + + +`qiskit.transpiler.passes.SolovayKitaevSynthesis`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/solovay_kitaev_synthesis.py "view source code") + +Bases: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") + +A Solovay-Kitaev Qiskit unitary synthesis plugin. + +This plugin is invoked by [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") when the `unitary_synthesis_method` parameter is set to `"sk"`. + +This plugin supports customization and additional parameters can be passed to the plugin by passing a dictionary as the `unitary_synthesis_plugin_config` parameter of the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function. + +Supported parameters in the dictionary: + +**basis\_approximations (str | dict):** + +The basic approximations for the finding the best discrete decomposition at the root of the recursion. If a string, it specifies the `.npy` file to load the approximations from. If a dictionary, it contains `{label: SO(3)-matrix}` pairs. If None, a default based on the specified `basis_gates` and `depth` is generated. + +**basis\_gates (list):** + +A list of strings specifying the discrete basis gates to decompose to. If None, defaults to `["h", "t", "tdg"]`. + +**depth (int):** + +The gate-depth of the basic approximations. All possible, unique combinations of the basis gates up to length `depth` are considered. If None, defaults to 10. + +**recursion\_degree (int):** + +The number of times the decomposition is recursively improved. If None, defaults to 3. + +## Attributes + + + +### max\_qubits + +Maximum number of supported qubits is `1`. + + + +### min\_qubits + +Minimum number of supported qubits is `1`. + + + +### supported\_bases + +The plugin does not support bases for synthesis. + + + +### supports\_basis\_gates + +The plugin does not support basis gates. By default it synthesis to the `["h", "t", "tdg"]` gate basis. + + + +### supports\_coupling\_map + +The plugin does not support coupling maps. + + + +### supports\_gate\_errors + +The plugin does not support gate errors. + + + +### supports\_gate\_errors\_by\_qubit + +Return whether the plugin supports taking `gate_errors_by_qubit` + +This differs from `supports_gate_errors`/`gate_errors` by using a different view of the same data. Instead of being keyed by gate name this is keyed by qubit and uses [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to represent gates (instead of gate names). + +`gate_errors_by_qubit` will be a dictionary in the form of `{(qubits,): [Gate, error]}`. For example: + +```python +{ +(0,): [SXGate(): 0.0006149355812506126, RZGate(): 0.0], +(0, 1): [CXGate(): 0.012012477900732316] +} +``` + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate errors on every gate for each qubit. The gate error rates reported in `gate_errors` are provided by the target device `Backend` object and the exact meaning might be different depending on the backend. + +This defaults to False + + + +### supports\_gate\_lengths + +The plugin does not support gate lengths. + + + +### supports\_gate\_lengths\_by\_qubit + +Return whether the plugin supports taking `gate_lengths_by_qubit` + +This differs from `supports_gate_lengths`/`gate_lengths` by using a different view of the same data. Instead of being keyed by gate name this is keyed by qubit and uses [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to represent gates (instead of gate names) + +`gate_lengths_by_qubit` will be a dictionary in the form of `{(qubits,): [Gate, length]}`. For example: + +```python +{ +(0,): [SXGate(): 0.0006149355812506126, RZGate(): 0.0], +(0, 1): [CXGate(): 0.012012477900732316] +} +``` + +where the `length` value is in units of seconds. + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate lengths on every gate for each qubit. + +This defaults to False + + + +### supports\_natural\_direction + +The plugin does not support natural direction, it does not assume bidirectional two qubit gates. + + + +### supports\_pulse\_optimize + +The plugin does not support optimization of pulses. + + + +### supports\_target + +Whether the plugin supports taking `target` as an option + +`target` will be a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the target device for the output of the synthesis pass. + +By default this will be `False` since the plugin interface predates the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") class. If a plugin returns `True` for this attribute, it is expected that the plugin will use the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") instead of the values passed if any of `supports_gate_lengths`, `supports_gate_errors`, `supports_coupling_map`, and `supports_basis_gates` are set (although ideally all those parameters should contain duplicate information). + +## Methods + +### run + + + +`run(unitary, **options)` + +Run synthesis for the given unitary matrix + +**Parameters** + +* **unitary** ([*numpy.ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – The unitary matrix to synthesize to a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object +* **options** – The optional kwargs that are passed based on the output the `support_*` methods on the class. Refer to the documentation for these methods on [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") to see what the keys and values are. + +**Returns** + +The dag circuit representation of the unitary. Alternatively, you can return a tuple of the form `(dag, wires)` where `dag` is the dag circuit representation of the circuit representation of the unitary and `wires` is the mapping wires to use for [`qiskit.dagcircuit.DAGCircuit.substitute_node_with_dag()`](qiskit.dagcircuit.DAGCircuit#substitute_node_with_dag "qiskit.dagcircuit.DAGCircuit.substitute_node_with_dag"). If you return a tuple and `wires` is `None` this will behave just as if only a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") was returned. Additionally if this returns `None` no substitution will be made. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.StochasticSwap.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.StochasticSwap.md new file mode 100644 index 00000000000..ae71492710b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.StochasticSwap.md @@ -0,0 +1,139 @@ +--- +title: StochasticSwap +description: API reference for qiskit.transpiler.passes.StochasticSwap +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.StochasticSwap +--- + +# StochasticSwap + + + +`qiskit.transpiler.passes.StochasticSwap(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/routing/stochastic_swap.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Map a DAGCircuit onto a coupling\_map adding swap gates. + +Uses a randomized algorithm. + +**Notes** + +1. Measurements may occur and be followed by swaps that result in repeated measurement of the same qubit. Near-term experiments cannot implement these circuits, so some care is required when using this mapper with experimental backend targets. +2. We do not use the fact that the input state is zero to simplify the circuit. + +StochasticSwap initializer. + +The coupling map is a connected graph + +If these are not satisfied, the behavior is undefined. + +**Parameters** + +* **coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – Directed graph representing a coupling map. +* **trials** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – maximum number of iterations to attempt +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – seed for random number generator +* **fake\_run** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – if true, it will only pretend to do routing, i.e., no swap is effectively added. +* **initial\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout")) – starting layout at beginning of pass. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the StochasticSwap pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to map. + +**Returns** + +A mapped DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +* [**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the coupling map or the layout are not +* **compatible with the DAG**\*\*, or \*\***if the coupling\_map=None** – + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.TemplateOptimization.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TemplateOptimization.md new file mode 100644 index 00000000000..df83c02c1b3 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TemplateOptimization.md @@ -0,0 +1,122 @@ +--- +title: TemplateOptimization +description: API reference for qiskit.transpiler.passes.TemplateOptimization +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.TemplateOptimization +--- + +# TemplateOptimization + + + +`qiskit.transpiler.passes.TemplateOptimization(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/optimization/template_optimization.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Class for the template optimization pass. + +**Parameters** + +* **template\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*()]*) – list of the different template circuit to apply. +* **heuristics\_backward\_param** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – \[length, survivor] Those are the parameters for applying heuristics on the backward part of the algorithm. This part of the algorithm creates a tree of matching scenario. This tree grows exponentially. The heuristics evaluate which scenarios have the longest match and keep only those. The length is the interval in the tree for cutting it and survivor is the number of scenarios that are kept. We advise to use l=3 and s=1 to have serious time advantage. We remind that the heuristics implies losing a part of the maximal matches. Check reference for more details. +* **heuristics\_qubits\_param** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – \[length] The heuristics for the qubit choice make guesses from the dag dependency of the circuit in order to limit the number of qubit configurations to explore. The length is the number of successors or not predecessors that will be explored in the dag dependency of the circuit, each qubits of the nodes are added to the set of authorized qubits. We advise to use length=1. Check reference for more details. +* **user\_cost\_dict** (*Dict\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – quantum cost dictionary passed to TemplateSubstitution to configure its behavior. This will override any default values if None is not given. The key is the name of the gate and the value its quantum cost. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG circuit. + +**Returns** + +optimized DAG circuit. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the template has not the right form or if the output circuit acts differently as the input circuit. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.TimeUnitConversion.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TimeUnitConversion.md new file mode 100644 index 00000000000..c8fb808f87e --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TimeUnitConversion.md @@ -0,0 +1,132 @@ +--- +title: TimeUnitConversion +description: API reference for qiskit.transpiler.passes.TimeUnitConversion +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.TimeUnitConversion +--- + +# TimeUnitConversion + + + +`qiskit.transpiler.passes.TimeUnitConversion(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/time_unit_conversion.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Choose a time unit to be used in the following time-aware passes, and make all circuit time units consistent with that. + +This pass will add a [`Instruction.duration`](qiskit.circuit.Instruction#duration "qiskit.circuit.Instruction.duration") metadata to each op whose duration is known which will be used by subsequent scheduling passes for scheduling. + +If `dt` (in seconds) is known to transpiler, the unit `'dt'` is chosen. Otherwise, the unit to be selected depends on what units are used in delays and instruction durations: + +* `'s'`: if they are all in SI units. +* `'dt'`: if they are all in the unit `'dt'`. +* raise error: if they are a mix of SI units and `'dt'`. + +TimeUnitAnalysis initializer. + +**Parameters** + +* **inst\_durations** ([*InstructionDurations*](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations")) – A dictionary of durations of instructions. +* **target** – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `inst_durations` and `target` are specified then this argument will take precedence and `inst_durations` will be ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the TimeUnitAnalysis pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to be checked. + +**Returns** + +DAG with consistent timing and op nodes annotated with duration. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the units are not unifiable + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.TranslateParameterizedGates.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TranslateParameterizedGates.md new file mode 100644 index 00000000000..222de73e818 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TranslateParameterizedGates.md @@ -0,0 +1,174 @@ +--- +title: TranslateParameterizedGates +description: API reference for qiskit.transpiler.passes.TranslateParameterizedGates +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.TranslateParameterizedGates +--- + +# TranslateParameterizedGates + + + +`qiskit.transpiler.passes.TranslateParameterizedGates(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/basis/translate_parameterized.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Translate parameterized gates to a supported basis set. + +Once a parameterized instruction is found that is not in the `supported_gates` list, the instruction is decomposed one level and the parameterized sub-blocks are recursively decomposed. The recursion is stopped once all parameterized gates are in `supported_gates`, or if a gate has no definition and a translation to the basis is attempted (this might happen e.g. for the `UGate` if it’s not in the specified gate list). + +**Example** + +The following, multiply nested circuit: + +```python +from qiskit.circuit import QuantumCircuit, ParameterVector +from qiskit.transpiler.passes import TranslateParameterizedGates + +x = ParameterVector("x", 4) +block1 = QuantumCircuit(1) +block1.rx(x[0], 0) + +sub_block = QuantumCircuit(2) +sub_block.cx(0, 1) +sub_block.rz(x[2], 0) + +block2 = QuantumCircuit(2) +block2.ry(x[1], 0) +block2.append(sub_block.to_gate(), [0, 1]) + +block3 = QuantumCircuit(3) +block3.ccx(0, 1, 2) + +circuit = QuantumCircuit(3) +circuit.append(block1.to_gate(), [1]) +circuit.append(block2.to_gate(), [0, 1]) +circuit.append(block3.to_gate(), [0, 1, 2]) +circuit.cry(x[3], 0, 2) + +supported_gates = ["rx", "ry", "rz", "cp", "crx", "cry", "crz"] +unrolled = TranslateParameterizedGates(supported_gates)(circuit) +``` + +is decomposed to: + +```python + ┌──────────┐ ┌──────────┐┌─────────────┐ +q_0: ┤ Ry(x[1]) ├──■──┤ Rz(x[2]) ├┤0 ├─────■────── + ├──────────┤┌─┴─┐└──────────┘│ │ │ +q_1: ┤ Rx(x[0]) ├┤ X ├────────────┤1 circuit-92 ├─────┼────── + └──────────┘└───┘ │ │┌────┴─────┐ +q_2: ─────────────────────────────┤2 ├┤ Ry(x[3]) ├ + └─────────────┘└──────────┘ +``` + +**Parameters** + +* **supported\_gates** – A list of suppported basis gates specified as string. If `None`, a `target` must be provided. +* **equivalence\_library** – The equivalence library to translate the gates. Defaults to the equivalence library of all Qiskit standard gates. +* **target** – A [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") containing the supported operations. If `None`, `supported_gates` must be set. Note that this argument takes precedence over `supported_gates`, if both are set. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If neither of `supported_gates` and `target` are passed. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the transpiler pass. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – The DAG circuit in which the parameterized gates should be unrolled. + +**Returns** + +A DAG where the parameterized gates have been unrolled. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the circuit cannot be unrolled. + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.TrivialLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TrivialLayout.md new file mode 100644 index 00000000000..c6410fbf812 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.TrivialLayout.md @@ -0,0 +1,125 @@ +--- +title: TrivialLayout +description: API reference for qiskit.transpiler.passes.TrivialLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.TrivialLayout +--- + +# TrivialLayout + + + +`qiskit.transpiler.passes.TrivialLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/trivial_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Choose a Layout by assigning `n` circuit qubits to device qubits `0, .., n-1`. + +A pass for choosing a Layout of a circuit onto a Coupling graph, using a simple round-robin order. + +This pass associates a physical qubit (int) to each virtual qubit of the circuit (Qubit) in increasing order. + +Does not assume any ancilla. + +TrivialLayout initializer. + +**Parameters** + +**coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – directed graph representing a coupling map. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if invalid options + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the TrivialLayout pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – DAG to find layout for. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if dag wider than the target backend + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnitarySynthesis.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnitarySynthesis.md new file mode 100644 index 00000000000..22a53c908bc --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnitarySynthesis.md @@ -0,0 +1,135 @@ +--- +title: UnitarySynthesis +description: API reference for qiskit.transpiler.passes.UnitarySynthesis +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.UnitarySynthesis +--- + +# UnitarySynthesis + + + +`qiskit.transpiler.passes.UnitarySynthesis(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/unitary_synthesis.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Synthesize gates according to their basis gates. + +Synthesize unitaries over some basis gates. + +This pass can approximate 2-qubit unitaries given some gate fidelities (either via `backend_props` or `target`). More approximation can be forced by setting a heuristic dial `approximation_degree`. + +**Parameters** + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – List of gate names to target. If this is not specified the `target` argument must be used. If both this and the `target` are specified the value of `target` will be used and this will be ignored. +* **approximation\_degree** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – heuristic dial used for circuit approximation (1.0=no approximation, 0.0=maximal approximation). Approximation can make the synthesized circuit cheaper at the cost of straying from the original unitary. If None, approximation is done based on gate fidelities. +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – the coupling map of the backend in case synthesis is done on a physical circuit. The directionality of the coupling\_map will be taken into account if `pulse_optimize` is `True`/`None` and `natural_direction` is `True`/`None`. +* **backend\_props** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – Properties of a backend to synthesize for (e.g. gate fidelities). +* **pulse\_optimize** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to optimize pulses during synthesis. A value of `None` will attempt it but fall back if it does not succeed. A value of `True` will raise an error if pulse-optimized synthesis does not succeed. +* **natural\_direction** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether to apply synthesis considering directionality of 2-qubit gates. Only applies when `pulse_optimize` is `True` or `None`. The natural direction is determined by first checking to see whether the coupling map is unidirectional. If there is no coupling map or the coupling map is bidirectional, the gate direction with the shorter duration from the backend properties will be used. If set to True, and a natural direction can not be determined, raises [`TranspilerError`](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError"). If set to None, no exception will be raised if a natural direction can not be determined. +* **synth\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – List of gates to synthesize. If None and `pulse_optimize` is False or None, default to `['unitary']`. If `None` and `pulse_optimize == True`, default to `['unitary', 'swap']` +* **method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unitary synthesis method plugin to use. +* **min\_qubits** – The minimum number of qubits in the unitary to synthesize. If this is set and the unitary is less than the specified number of qubits it will not be synthesized. +* **plugin\_config** – Optional extra configuration arguments (as a `dict`) which are passed directly to the specified unitary synthesis plugin. By default, this will have no effect as the default plugin has no extra arguments. Refer to the documentation of your unitary synthesis plugin on how to use this. +* **target** – The optional [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") for the target device the pass is compiling for. If specified this will supersede the values set for `basis_gates`, `coupling_map`, and `backend_props`. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the UnitarySynthesis pass on `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – input dag. + +**Returns** + +Output dag with UnitaryGates synthesized to target basis. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if `method` was specified for the class and is not found in the installed plugins list. The list of installed plugins can be queried with [`unitary_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names") + +**Return type** + +[*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroll3qOrMore.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroll3qOrMore.md new file mode 100644 index 00000000000..fe75b978b50 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroll3qOrMore.md @@ -0,0 +1,124 @@ +--- +title: Unroll3qOrMore +description: API reference for qiskit.transpiler.passes.Unroll3qOrMore +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Unroll3qOrMore +--- + +# Unroll3qOrMore + + + +`qiskit.transpiler.passes.Unroll3qOrMore(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/basis/unroll_3q_or_more.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Recursively expands 3q+ gates until the circuit only contains 2q or 1q gates. + +Initialize the Unroll3qOrMore pass + +**Parameters** + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The target object representing the compilation target. If specified any multi-qubit instructions in the circuit when the pass is run that are supported by the target device will be left in place. If both this and `basis_gates` are specified only the target will be checked. +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of basis gate names that the target device supports. If specified any gate names in the circuit which are present in this list will not be unrolled. If both this and `target` are specified only the target will be used for checking which gates are supported. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Unroll3qOrMore pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – input dag + +**Returns** + +output dag with maximum node degrees of 2 + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if a 3q+ gate is not decomposable + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollCustomDefinitions.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollCustomDefinitions.md new file mode 100644 index 00000000000..9f47bb9716d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollCustomDefinitions.md @@ -0,0 +1,136 @@ +--- +title: UnrollCustomDefinitions +description: API reference for qiskit.transpiler.passes.UnrollCustomDefinitions +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.UnrollCustomDefinitions +--- + +# UnrollCustomDefinitions + + + +`qiskit.transpiler.passes.UnrollCustomDefinitions(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/basis/unroll_custom_definitions.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Unrolls instructions with custom definitions. + +Unrolls instructions with custom definitions. + +**Parameters** + +* **equivalence\_library** ([*EquivalenceLibrary*](qiskit.circuit.EquivalenceLibrary "qiskit.circuit.EquivalenceLibrary")) – The equivalence library which will be used by the BasisTranslator pass. (Instructions in this library will not be unrolled by this pass.) + +* **basis\_gates** (*Optional\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]]*) – Target basis names to unroll to, e.g. `['u3', 'cx']`. Ignored if `target` is also specified. + +* **target** (*Optional\[*[*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")*]*) – + + **The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object corresponding to the compilation** + + target. When specified, any argument specified for `basis_gates` is ignored. + + **min\_qubits (int): The minimum number of qubits for operations in the input** + + dag to translate. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the UnrollCustomDefinitions pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – input dag + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if unable to unroll given the basis due to undefined +* **decomposition rules**\*\* (****such as a bad basis****) or \*\***excessive recursion.** – + +**Returns** + +output unrolled dag + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollForLoops.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollForLoops.md new file mode 100644 index 00000000000..ac595f65867 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.UnrollForLoops.md @@ -0,0 +1,123 @@ +--- +title: UnrollForLoops +description: API reference for qiskit.transpiler.passes.UnrollForLoops +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.UnrollForLoops +--- + +# UnrollForLoops + + + +`qiskit.transpiler.passes.UnrollForLoops(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/utils/unroll_forloops.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +`UnrollForLoops` transpilation pass unrolls for-loops when possible. + +Things like `for x in {0, 3, 4} {rx(x) qr[1];}` will turn into `rx(0) qr[1]; rx(3) qr[1]; rx(4) qr[1];`. + + + The `UnrollForLoops` unrolls only one level of block depth. No inner loop will be considered by `max_target_depth`. + + +**Parameters** + +**max\_target\_depth** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. Checks if the unrolled block is over a particular subcircuit depth. To disable the check, use `-1` (Default). + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the UnrollForLoops pass on `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – the directed acyclic graph to run on. + +**Returns** + +Transformed DAG. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroller.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroller.md new file mode 100644 index 00000000000..dd930f08405 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Unroller.md @@ -0,0 +1,131 @@ +--- +title: Unroller +description: API reference for qiskit.transpiler.passes.Unroller +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Unroller +--- + +# Unroller + + + +`qiskit.transpiler.passes.Unroller(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/basis/unroller.py "view source code") + +Bases: [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.basepasses.TransformationPass") + +Unroll a circuit to a given basis. + +Unroll (expand) non-basis, non-opaque instructions recursively to a desired basis, using decomposition rules defined for each instruction. + +Unroller initializer. + + + The class `qiskit.transpiler.passes.basis.unroller.Unroller` is deprecated as of qiskit 0.45.0. It will be removed in the Qiskit 1.0 release. This has been replaced by the BasisTranslator pass. + + +**Parameters** + +* **basis** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] or None*) – Target basis names to unroll to, e.g. \[‘u3’, ‘cx’] . If None, does not unroll any gate. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing the target backend, if both `basis` and this are specified then this argument will take precedence and `basis` will be ignored. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Unroller pass on dag. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – input dag + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if unable to unroll given the basis due to undefined +* **decomposition rules**\*\* (****such as a bad basis****) or \*\***excessive recursion.** – + +**Returns** + +output unrolled dag + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2Layout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2Layout.md new file mode 100644 index 00000000000..c73c716b2ae --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2Layout.md @@ -0,0 +1,137 @@ +--- +title: VF2Layout +description: API reference for qiskit.transpiler.passes.VF2Layout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.VF2Layout +--- + +# VF2Layout + + + +`qiskit.transpiler.passes.VF2Layout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/vf2_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +A pass for choosing a Layout of a circuit onto a Coupling graph, as a subgraph isomorphism problem, solved by VF2++. + +If a solution is found that means there is a “perfect layout” and that no further swap mapping or routing is needed. If a solution is found the layout will be set in the property set as `property_set['layout']`. However, if no solution is found, no `property_set['layout']` is set. The stopping reason is set in `property_set['VF2Layout_stop_reason']` in all the cases and will be one of the values enumerated in `VF2LayoutStopReason` which has the following values: + +> * `"solution found"`: If a perfect layout was found. +> * `"nonexistent solution"`: If no perfect layout was found. +> * `">2q gates in basis"`: If VF2Layout can’t work with basis + +By default, this pass will construct a heuristic scoring map based on the error rates in the provided `target` (or `properties` if `target` is not provided). However, analysis passes can be run prior to this pass and set `vf2_avg_error_map` in the property set with a `ErrorMap` instance. If a value is `NaN` that is treated as an ideal edge For example if an error map is created as: + +```python +from qiskit.transpiler.passes.layout.vf2_utils import ErrorMap + +error_map = ErrorMap(3) +error_map.add_error((0, 0), 0.0024) +error_map.add_error((0, 1), 0.01) +error_map.add_error((1, 1), 0.0032) +``` + +that represents the error map for a 2 qubit target, where the avg 1q error rate is `0.0024` on qubit 0 and `0.0032` on qubit 1. Then the avg 2q error rate for gates that operate on (0, 1) is 0.01 and (1, 0) is not supported by the target. This will be used for scoring if it’s set as the `vf2_avg_error_map` key in the property set when [`VF2Layout`](#qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout") is run. + +Initialize a `VF2Layout` pass instance + +**Parameters** + +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – Directed graph representing a coupling map. +* **strict\_direction** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, considers the direction of the coupling map. Default is False. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Sets the seed of the PRNG. -1 Means no node shuffling. +* **call\_limit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of state visits to attempt in each execution of VF2. +* **time\_limit** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The total time limit in seconds to run `VF2Layout` +* **properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – The backend properties for the backend. If [`readout_error()`](qiskit.providers.models.BackendProperties#readout_error "qiskit.providers.models.BackendProperties.readout_error") is available it is used to score the layout. +* **max\_trials** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of trials to run VF2 to find a layout. If this is not specified the number of trials will be limited based on the number of edges in the interaction graph or the coupling graph (whichever is larger) if no other limits are set. If set to a value \<= 0 no limit on the number of trials will be set. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – A target representing the backend device to run `VF2Layout` on. If specified it will supersede a set value for `properties` and `coupling_map`. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – At runtime, if neither `coupling_map` or `target` are provided. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +run the layout method + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2PostLayout.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2PostLayout.md new file mode 100644 index 00000000000..6258e33d590 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.VF2PostLayout.md @@ -0,0 +1,139 @@ +--- +title: VF2PostLayout +description: API reference for qiskit.transpiler.passes.VF2PostLayout +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.VF2PostLayout +--- + +# VF2PostLayout + + + +`qiskit.transpiler.passes.VF2PostLayout(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/layout/vf2_post_layout.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +A pass for choosing a Layout after transpilation of a circuit onto a Coupling graph, as a subgraph isomorphism problem, solved by VF2++. + +Unlike the [`VF2Layout`](qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout") transpiler pass which is designed to find an initial layout for a circuit early in the transpilation pipeline this transpiler pass is designed to try and find a better layout after transpilation is complete. The initial layout phase of the transpiler doesn’t have as much information available as we do after transpilation. This pass is designed to be paired in a similar pipeline as the layout passes. This pass will strip any idle wires from the circuit, use VF2 to find a subgraph in the coupling graph for the circuit to run on with better fidelity and then update the circuit layout to use the new qubits. The algorithm used in this pass is described in [arXiv:2209.15512](https://arxiv.org/abs/2209.15512). + +If a solution is found that means there is a lower error layout available for the circuit. If a solution is found the layout will be set in the property set as `property_set['post_layout']`. However, if no solution is found, no `property_set['post_layout']` is set. The stopping reason is set in `property_set['VF2PostLayout_stop_reason']` in all the cases and will be one of the values enumerated in `VF2PostLayoutStopReason` which has the following values: + +> * `"solution found"`: If a solution was found. +> * `"nonexistent solution"`: If no solution was found. +> * `">2q gates in basis"`: If VF2PostLayout can’t work with basis + +By default, this pass will construct a heuristic scoring map based on the error rates in the provided `target` (or `properties` if `target` is not provided). However, analysis passes can be run prior to this pass and set `vf2_avg_error_map` in the property set with a `ErrorMap` instance. If a value is `NaN` that is treated as an ideal edge For example if an error map is created as: + +```python +from qiskit.transpiler.passes.layout.vf2_utils import ErrorMap + +error_map = ErrorMap(3) +error_map.add_error((0, 0), 0.0024) +error_map.add_error((0, 1), 0.01) +error_map.add_error((1, 1), 0.0032) +``` + +that represents the error map for a 2 qubit target, where the avg 1q error rate is `0.0024` on qubit 0 and `0.0032` on qubit 1. Then the avg 2q error rate for gates that operate on (0, 1) is 0.01 and (1, 0) is not supported by the target. This will be used for scoring if it’s set as the `vf2_avg_error_map` key in the property set when [`VF2PostLayout`](#qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout") is run. + +Initialize a `VF2PostLayout` pass instance + +**Parameters** + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – A target representing the backend device to run `VF2PostLayout` on. If specified it will supersede a set value for `properties` and `coupling_map`. +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – Directed graph representing a coupling map. +* **properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – The backend properties for the backend. If [`readout_error()`](qiskit.providers.models.BackendProperties#readout_error "qiskit.providers.models.BackendProperties.readout_error") is available it is used to score the layout. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Sets the seed of the PRNG. -1 Means no node shuffling. +* **call\_limit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of state visits to attempt in each execution of VF2. +* **time\_limit** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The total time limit in seconds to run `VF2PostLayout` +* **strict\_direction** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Whether the pass is configured to follow the strict direction in the coupling graph. If this is set to false, the pass will treat any edge in the coupling graph as a weak edge and the interaction graph will be undirected. For the purposes of evaluating layouts the avg error rate for each qubit and 2q link will be used. This enables the pass to be run prior to basis translation and work with any 1q and 2q operations. However, if `strict_direction=True` the pass expects the input [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object to [`run()`](#qiskit.transpiler.passes.VF2PostLayout.run "qiskit.transpiler.passes.VF2PostLayout.run") to be in the target set of instructions. +* **max\_trials** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of trials to run VF2 to find a layout. A value of `0` (the default) means ‘unlimited’. + +**Raises** + +[**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – At runtime, if neither `coupling_map` or `target` are provided. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +run the layout method + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.ValidatePulseGates.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ValidatePulseGates.md new file mode 100644 index 00000000000..2c392b26f2c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.ValidatePulseGates.md @@ -0,0 +1,132 @@ +--- +title: ValidatePulseGates +description: API reference for qiskit.transpiler.passes.ValidatePulseGates +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.ValidatePulseGates +--- + +# ValidatePulseGates + + + +`qiskit.transpiler.passes.ValidatePulseGates(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/scheduling/alignments/pulse_gate_validation.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Check custom gate length. + +This is a control electronics aware analysis pass. + +Quantum gates (instructions) are often implemented with shaped analog stimulus signals. These signals may be digitally stored in the waveform memory of the control electronics and converted into analog voltage signals by electronic components known as digital to analog converters (DAC). + +In Qiskit SDK, we can define the pulse-level implementation of custom quantum gate instructions, as a [pulse gate](https://docs.quantum-computing.ibm.com/build/pulse), thus user gates should satisfy all waveform memory constraints imposed by the backend. + +This pass validates all attached calibration entries and raises `TranspilerError` to kill the transpilation process if any invalid calibration entry is found. This pass saves users from waiting until job execution time to get an invalid pulse error from the backend control electronics. + +Create new pass. + +**Parameters** + +* **granularity** – Integer number representing the minimum time resolution to define the pulse gate length in units of `dt`. This value depends on the control electronics of your quantum processor. +* **min\_length** – Integer number representing the minimum data point length to define the pulse gate in units of `dt`. This value depends on the control electronics of your quantum processor. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the pulse gate validation attached to `dag`. + +**Parameters** + +**dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.dagcircuit.DAGCircuit")) – DAG to be validated. + +**Returns** + +DAG with consistent timing and op nodes annotated with duration. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – When pulse gate violate pulse controller constraints. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.Width.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Width.md new file mode 100644 index 00000000000..e135edc3229 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.Width.md @@ -0,0 +1,103 @@ +--- +title: Width +description: API reference for qiskit.transpiler.passes.Width +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.Width +--- + +# Width + + + +`qiskit.transpiler.passes.Width(*args, **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/analysis/width.py "view source code") + +Bases: [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.basepasses.AnalysisPass") + +Calculate the width of a DAG circuit. + +The result is saved in `property_set['width']` as an integer that contains the number of qubits + the number of clbits. + +## Attributes + + + +### is\_analysis\_pass + +Check if the pass is an analysis pass. + +If the pass is an AnalysisPass, that means that the pass can analyze the DAG and write the results of that analysis in the property set. Modifications on the DAG are not allowed by this kind of pass. + + + +### is\_transformation\_pass + +Check if the pass is a transformation pass. + +If the pass is a TransformationPass, that means that the pass can manipulate the DAG, but cannot modify the property set (but it can be read). + +## Methods + +### execute + + + +`execute(passmanager_ir, state, callback=None)` + +Execute optimization task for input Qiskit IR. + +**Parameters** + +* **passmanager\_ir** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")) – Qiskit IR to optimize. +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – State associated with workflow execution by the pass manager itself. +* **callback** ([*Callable*](https://docs.python.org/3/library/collections.abc.html#collections.abc.Callable "(in Python v3.12)") *| None*) – A callback function which is caller per execution of optimization task. + +**Returns** + +Optimized Qiskit IR and state of the workflow. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)"), [qiskit.passmanager.compilation\_status.PassManagerState](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")] + +### name + + + +`name()` + +Name of the pass. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### run + + + +`run(dag)` + +Run the Width pass on dag. + +### update\_status + + + +`update_status(state, run_state)` + +Update workflow status. + +**Parameters** + +* **state** ([*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState")) – Pass manager state to update. +* **run\_state** (*RunState*) – Completion status of current task. + +**Returns** + +Updated pass manager state. + +**Return type** + +[*PassManagerState*](qiskit.passmanager.PassManagerState "qiskit.passmanager.compilation_status.PassManagerState") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.md new file mode 100644 index 00000000000..09997127db7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.md @@ -0,0 +1,48 @@ +--- +title: HighLevelSynthesisPlugin +description: API reference for qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin +--- + +# HighLevelSynthesisPlugin + + + +`qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/plugin.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Abstract high-level synthesis plugin class. + +This abstract class defines the interface for high-level synthesis plugins. + +## Methods + +### run + + + +`abstract run(high_level_object, coupling_map=None, target=None, qubits=None, **options)` + +Run synthesis for the given Operation. + +**Parameters** + +* **high\_level\_object** ([*Operation*](qiskit.circuit.Operation "qiskit.circuit.Operation")) – The Operation to synthesize to a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object. +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – The coupling map of the backend in case synthesis is done on a physical circuit. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – A target representing the target backend. +* **qubits** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – 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](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.md new file mode 100644 index 00000000000..d9428503746 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager.md @@ -0,0 +1,36 @@ +--- +title: HighLevelSynthesisPluginManager +description: API reference for qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager +--- + +# HighLevelSynthesisPluginManager + + + +`qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/plugin.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Class tracking the installed high-level-synthesis plugins. + +## Methods + +### method + + + +`method(op_name, method_name)` + +Returns the plugin for `op_name` and `method_name`. + +### method\_names + + + +`method_names(op_name)` + +Returns plugin methods for op\_name. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.md new file mode 100644 index 00000000000..23e00b3647c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.md @@ -0,0 +1,200 @@ +--- +title: UnitarySynthesisPlugin +description: API reference for qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin +--- + +# UnitarySynthesisPlugin + + + +`qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/plugin.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +Abstract unitary synthesis plugin class + +This abstract class defines the interface for unitary synthesis plugins. + +## Attributes + + + +### max\_qubits + +Return the maximum number of qubits the unitary synthesis plugin supports. + +If the size of the unitary to be synthesized exceeds this value the `default` plugin will be used. If there is no upper bound return `None` and all unitaries (`>= min_qubits` if it’s defined) will be passed to this plugin when it’s enabled. + + + +### min\_qubits + +Return the minimum number of qubits the unitary synthesis plugin supports. + +If the size of the unitary to be synthesized is below this value the `default` plugin will be used. If there is no lower bound return `None` and all unitaries (`<= max_qubits` if it’s defined) will be passed to this plugin when it’s enabled. + + + +### supported\_bases + +Returns a dictionary of supported bases for synthesis + +This is expected to return a dictionary where the key is a string basis and the value is a list of gate names that the basis works in. If the synthesis method doesn’t support multiple bases this should return `None`. For example: + +```python +{ + "XZX": ["rz", "rx"], + "XYX": ["rx", "ry"], +} +``` + +If a dictionary is returned by this method the run kwargs will be passed a parameter `matched_basis` which contains a list of the basis strings (i.e. keys in the dictionary) which match the target basis gate set for the transpilation. If no entry in the dictionary matches the target basis gate set then the `matched_basis` kwarg will be set to an empty list, and a plugin can choose how to deal with the target basis gate set not matching the plugin’s capabilities. + + + +### supports\_basis\_gates + +Return whether the plugin supports taking `basis_gates` + +If this returns `True` the plugin’s `run()` method will be passed a `basis_gates` kwarg with a list of gate names the target backend supports. For example, `['sx', 'x', 'cx', 'id', 'rz']`. + + + +### supports\_coupling\_map + +Return whether the plugin supports taking `coupling_map` + +If this returns `True` the plugin’s `run()` method will receive one kwarg `coupling_map`. The `coupling_map` kwarg will be set to a tuple with the first element being a [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") object representing the qubit connectivity of the target backend, the second element will be a list of integers that represent the qubit indices in the coupling map that unitary is on. Note that if the target backend doesn’t have a coupling map set, the `coupling_map` kwarg’s value will be `(None, qubit_indices)`. + + + +### supports\_gate\_errors + +Return whether the plugin supports taking `gate_errors` + +`gate_errors` will be a dictionary in the form of `{gate_name: {(qubit_1, qubit_2): error}}`. For example: + +```python +{ +'sx': {(0,): 0.0006149355812506126, (1,): 0.0006149355812506126}, +'cx': {(0, 1): 0.012012477900732316, (1, 0): 5.191111111111111e-07} +} +``` + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate errors on every gate for each qubit. The gate error rates reported in `gate_errors` are provided by the target device `Backend` object and the exact meaning might be different depending on the backend. + + + +### supports\_gate\_errors\_by\_qubit + +Return whether the plugin supports taking `gate_errors_by_qubit` + +This differs from `supports_gate_errors`/`gate_errors` by using a different view of the same data. Instead of being keyed by gate name this is keyed by qubit and uses [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to represent gates (instead of gate names). + +`gate_errors_by_qubit` will be a dictionary in the form of `{(qubits,): [Gate, error]}`. For example: + +```python +{ +(0,): [SXGate(): 0.0006149355812506126, RZGate(): 0.0], +(0, 1): [CXGate(): 0.012012477900732316] +} +``` + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate errors on every gate for each qubit. The gate error rates reported in `gate_errors` are provided by the target device `Backend` object and the exact meaning might be different depending on the backend. + +This defaults to False + + + +### supports\_gate\_lengths + +Return whether the plugin supports taking `gate_lengths` + +`gate_lengths` will be a dictionary in the form of `{gate_name: {(qubit_1, qubit_2): length}}`. For example: + +```python +{ +'sx': {(0,): 0.0006149355812506126, (1,): 0.0006149355812506126}, +'cx': {(0, 1): 0.012012477900732316, (1, 0): 5.191111111111111e-07} +} +``` + +where the `length` value is in units of seconds. + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate lengths on every gate for each qubit. + + + +### supports\_gate\_lengths\_by\_qubit + +Return whether the plugin supports taking `gate_lengths_by_qubit` + +This differs from `supports_gate_lengths`/`gate_lengths` by using a different view of the same data. Instead of being keyed by gate name this is keyed by qubit and uses [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") instances to represent gates (instead of gate names) + +`gate_lengths_by_qubit` will be a dictionary in the form of `{(qubits,): [Gate, length]}`. For example: + +```python +{ +(0,): [SXGate(): 0.0006149355812506126, RZGate(): 0.0], +(0, 1): [CXGate(): 0.012012477900732316] +} +``` + +where the `length` value is in units of seconds. + +Do note that this dictionary might not be complete or could be empty as it depends on the target backend reporting gate lengths on every gate for each qubit. + +This defaults to False + + + +### supports\_natural\_direction + +Return whether the plugin supports a toggle for considering directionality of 2-qubit gates as `natural_direction`. + +Refer to the documentation for [`UnitarySynthesis`](qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") for the possible values and meaning of these values. + + + +### supports\_pulse\_optimize + +Return whether the plugin supports a toggle to optimize pulses during synthesis as `pulse_optimize`. + +Refer to the documentation for [`UnitarySynthesis`](qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") for the possible values and meaning of these values. + + + +### supports\_target + +Whether the plugin supports taking `target` as an option + +`target` will be a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the target device for the output of the synthesis pass. + +By default this will be `False` since the plugin interface predates the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") class. If a plugin returns `True` for this attribute, it is expected that the plugin will use the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") instead of the values passed if any of `supports_gate_lengths`, `supports_gate_errors`, `supports_coupling_map`, and `supports_basis_gates` are set (although ideally all those parameters should contain duplicate information). + +## Methods + +### run + + + +`abstract run(unitary, **options)` + +Run synthesis for the given unitary matrix + +**Parameters** + +* **unitary** ([*numpy.ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – The unitary matrix to synthesize to a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object +* **options** – The optional kwargs that are passed based on the output the `support_*` methods on the class. Refer to the documentation for these methods on [`UnitarySynthesisPlugin`](#qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") to see what the keys and values are. + +**Returns** + +The dag circuit representation of the unitary. Alternatively, you can return a tuple of the form `(dag, wires)` where `dag` is the dag circuit representation of the circuit representation of the unitary and `wires` is the mapping wires to use for [`qiskit.dagcircuit.DAGCircuit.substitute_node_with_dag()`](qiskit.dagcircuit.DAGCircuit#substitute_node_with_dag "qiskit.dagcircuit.DAGCircuit.substitute_node_with_dag"). If you return a tuple and `wires` is `None` this will behave just as if only a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") was returned. Additionally if this returns `None` no substitution will be made. + +**Return type** + +[DAGCircuit](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.md new file mode 100644 index 00000000000..08ab5da53cd --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager.md @@ -0,0 +1,20 @@ +--- +title: UnitarySynthesisPluginManager +description: API reference for qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager +--- + +# UnitarySynthesisPluginManager + + + +`qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/plugin.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Unitary Synthesis plugin manager class + +This class tracks the installed plugins, it has a single property, `ext_plugins` which contains a list of stevedore plugin objects. + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.md b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.md new file mode 100644 index 00000000000..e271476482c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names.md @@ -0,0 +1,26 @@ +--- +title: unitary_synthesis_plugin_names +description: API reference for qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names +--- + + + +# qiskit.transpiler.passes.synthesis.plugin.unitary\_synthesis\_plugin\_names + + + +`qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/passes/synthesis/plugin.py "view source code") + +Return a list of installed unitary synthesis plugin names + +**Returns** + +A list of the installed unitary synthesis plugin names. The plugin names are valid values for the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") kwarg `unitary_synthesis_method`. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.md b/docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.md new file mode 100644 index 00000000000..f8f64d28ba1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.md @@ -0,0 +1,39 @@ +--- +title: PassManagerStagePlugin +description: API reference for qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin +--- + +# PassManagerStagePlugin + + + +`qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/plugin.py "view source code") + +Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.12)") + +A `PassManagerStagePlugin` is a plugin interface object for using custom stages in [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"). + +A `PassManagerStagePlugin` object can be added to an external package and integrated into the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function with an entry point. This will enable users to use the output of [`pass_manager()`](#qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.pass_manager "qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin.pass_manager") to implement a stage in the compilation process. + +## Methods + +### pass\_manager + + + +`abstract pass_manager(pass_manager_config, optimization_level=None)` + +This method is designed to return a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") for the stage this implements + +**Parameters** + +* **pass\_manager\_config** ([*PassManagerConfig*](qiskit.transpiler.PassManagerConfig "qiskit.transpiler.passmanager_config.PassManagerConfig")) – A configuration object that defines all the target device specifications and any user specified options to [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") or [`generate_preset_pass_manager()`](transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") +* **optimization\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The optimization level of the transpilation, if set this should be used to set values for any tunable parameters to trade off runtime for potential optimization. Valid values should be `0`, `1`, `2`, or `3` and the higher the number the more optimization is expected. + +**Return type** + +[*PassManager*](qiskit.transpiler.PassManager "qiskit.transpiler.passmanager.PassManager") + diff --git a/docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.md b/docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.md new file mode 100644 index 00000000000..3f9d49eb406 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager.md @@ -0,0 +1,32 @@ +--- +title: PassManagerStagePluginManager +description: API reference for qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager +--- + +# PassManagerStagePluginManager + + + +`qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/plugin.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Manager class for preset pass manager stage plugins. + +## Methods + +### get\_passmanager\_stage + + + +`get_passmanager_stage(stage_name, plugin_name, pm_config, optimization_level=None)` + +Get a stage + +**Return type** + +[*PassManager*](qiskit.transpiler.PassManager "qiskit.transpiler.passmanager.PassManager") + diff --git a/docs/api/qiskit/0.46/qiskit.utils.QuantumInstance.md b/docs/api/qiskit/0.46/qiskit.utils.QuantumInstance.md new file mode 100644 index 00000000000..d57cf46fdc7 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.utils.QuantumInstance.md @@ -0,0 +1,316 @@ +--- +title: QuantumInstance +description: API reference for qiskit.utils.QuantumInstance +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.utils.QuantumInstance +--- + +# QuantumInstance + + + +`qiskit.utils.QuantumInstance(backend, shots=None, seed_simulator=None, basis_gates=None, coupling_map=None, initial_layout=None, pass_manager=None, bound_pass_manager=None, seed_transpiler=None, optimization_level=None, backend_options=None, noise_model=None, timeout=None, wait=5.0, skip_qobj_validation=True, measurement_error_mitigation_cls=None, cals_matrix_refresh_period=30, measurement_error_mitigation_shots=None, job_callback=None, mit_pattern=None, max_job_retries=50)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/quantum_instance.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: Quantum Backend including execution setting. + +Quantum Instance holds a Qiskit Terra backend as well as configuration for circuit transpilation and execution. When provided to an Aqua algorithm the algorithm will execute the circuits it needs to run using the instance. + + + The class `qiskit.utils.quantum_instance.QuantumInstance` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/qi\_migration](https://qisk.it/qi_migration). + + +**Parameters** + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – Instance of selected backend +* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Number of repetitions of each circuit, for sampling. If None, the shots are extracted from the backend. If the backend has none set, the default is 1024. +* **seed\_simulator** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Random seed for simulators +* **basis\_gates** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] | None*) – List of basis gate names supported by the target. Defaults to basis gates of the backend. +* **coupling\_map** (*Optional\[Union\['CouplingMap', List\[List]]]*) – Coupling map (perhaps custom) to target in mapping +* **initial\_layout** (*Optional\[Union\['Layout', Dict, List]]*) – Initial layout of qubits in mapping +* **pass\_manager** (*Optional\['PassManager']*) – Pass manager to handle how to compile the circuits. To run only this pass manager and not the `bound_pass_manager`, call the [`transpile()`](#qiskit.utils.QuantumInstance.transpile "qiskit.utils.QuantumInstance.transpile") method with the argument `pass_manager=quantum_instance.unbound_pass_manager`. +* **bound\_pass\_manager** (*Optional\['PassManager']*) – A second pass manager to apply on bound circuits only, that is, circuits without any free parameters. To only run this pass manager and not `pass_manager` call the [`transpile()`](#qiskit.utils.QuantumInstance.transpile "qiskit.utils.QuantumInstance.transpile") method with the argument `pass_manager=quantum_instance.bound_pass_manager`. manager should also be run. +* **seed\_transpiler** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The random seed for circuit mapper +* **optimization\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – How much optimization to perform on the circuits. Higher levels generate more optimized circuits, at the expense of longer transpilation time. +* **backend\_options** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)") *| None*) – All running options for backend, please refer to the provider of the backend for information as to what options it supports. +* **noise\_model** (*Optional\['NoiseModel']*) – noise model for simulator +* **timeout** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – Seconds to wait for job. If None, wait indefinitely. +* **wait** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Seconds between queries for job result +* **skip\_qobj\_validation** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Bypass Qobj validation to decrease circuit processing time during submission to backend. +* **measurement\_error\_mitigation\_cls** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – The approach to mitigate measurement errors. The classes [`CompleteMeasFitter`](qiskit.utils.mitigation.CompleteMeasFitter "qiskit.utils.mitigation.CompleteMeasFitter") or [`TensoredMeasFitter`](qiskit.utils.mitigation.TensoredMeasFitter "qiskit.utils.mitigation.TensoredMeasFitter") from the [`qiskit.utils.mitigation`](utils_mitigation#module-qiskit.utils.mitigation "qiskit.utils.mitigation") module can be used here as exact values, not instances. `TensoredMeasFitter` doesn’t support the `subset_fitter` method. +* **cals\_matrix\_refresh\_period** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – How often to refresh the calibration matrix in measurement mitigation. in minutes +* **measurement\_error\_mitigation\_shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – The number of shots number for building calibration matrix. If None, the main shots parameter value is used. +* **job\_callback** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – Optional user supplied callback which can be used to monitor job progress as jobs are submitted for processing by an Aqua algorithm. The callback is provided the following arguments: job\_id, job\_status, queue\_position, job +* **mit\_pattern** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]] | None*) – Qubits on which to perform the TensoredMeasFitter measurement correction, divided to groups according to tensors. If None and qr is given then assumed to be performed over the entire qr as one group (default None). +* **max\_job\_retries** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – positive non-zero number of trials for the job set (-1 for infinite trials) (default: 50) + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – the shots exceeds the maximum number of shots +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – set noise model but the backend does not support that +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – set backend\_options but the backend does not support that + +## Attributes + + + +### backend + +Return Backend backend object. + + + +### backend\_config + +Getter of backend\_config. + + + +### backend\_name + +Return backend name. + + + +### backend\_options + +Getter of backend\_options. + + + +### bound\_pass\_manager + +Return the pass manager for designated for bound circuits. + +**Returns** + +The pass manager for bound circuits, if it has been set. + +**Return type** + +Optional\[‘PassManager’] + + + +### cals\_matrix\_refresh\_period + +returns matrix refresh period + + + +### circuit\_summary + +Getter of circuit summary. + + + +### compile\_config + +Getter of compile\_config. + + + +### is\_local + +Return True if backend is a local backend. + + + +### is\_simulator + +Return True if backend is a simulator. + + + +### is\_statevector + +Return True if backend is a statevector-type simulator. + + + +### max\_job\_retries + +Getter of max tries + + + +### measurement\_error\_mitigation\_cls + +returns measurement error mitigation cls + + + +### measurement\_error\_mitigation\_shots + +returns measurement error mitigation shots + + + +### noise\_config + +Getter of noise\_config. + + + +### qjob\_config + +Getter of qjob\_config. + + + +### run\_config + +Getter of run\_config. + + + +### skip\_qobj\_validation + +checks if skip qobj validation + + + +### time\_taken + +Accumulated time taken for execution. + + + +### unbound\_pass\_manager + +Return the pass manager for designated for unbound circuits. + +**Returns** + +The pass manager for unbound circuits, if it has been set. + +**Return type** + +Optional\[‘PassManager’] + +## Methods + +### assemble + + + +`assemble(circuits)` + +assemble circuits + +**Return type** + +[*QasmQobj*](qiskit.qobj.QasmQobj "qiskit.qobj.qasm_qobj.QasmQobj") | [*PulseQobj*](qiskit.qobj.PulseQobj "qiskit.qobj.pulse_qobj.PulseQobj") + +### cals\_matrix + + + +`cals_matrix(qubit_index=None)` + +Get the stored calibration matrices and its timestamp. + +**Parameters** + +**qubit\_index** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – the qubit index of corresponding calibration matrix. If None, return all stored calibration matrices. + +**Returns** + +The calibration matrix and the creation timestamp if qubit\_index is not None otherwise, return all matrices and their timestamp in a dictionary. + +**Return type** + +[*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")] | [*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")\[[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")\[[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)"), [float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")]] | None + +### execute + + + +`execute(circuits, had_transpiled=False)` + +A wrapper to interface with quantum backend. + +**Parameters** + +* **circuits** (*Union\['QuantumCircuit', List\['QuantumCircuit']]*) – circuits to execute +* **had\_transpiled** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether or not circuits had been transpiled + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – Invalid error mitigation fitter class +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – TensoredMeasFitter class doesn’t support subset fitter +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Ignis not installed + +**Returns** + +result object + +**Return type** + +[Result](qiskit.result.Result "qiskit.result.Result") + +**TODO: Maybe we can combine the circuits for the main ones and calibration circuits before** + +assembling to the qobj. + +### maybe\_refresh\_cals\_matrix + + + +`maybe_refresh_cals_matrix(timestamp=None)` + +Calculate the time difference from the query of last time. + +**Parameters** + +**timestamp** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *| None*) – timestamp + +**Returns** + +Whether or not refresh the cals\_matrix + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### reset\_execution\_results + + + +`reset_execution_results()` + +Reset execution results + +### set\_config + + + +`set_config(**kwargs)` + +Set configurations for the quantum instance. + +### transpile + + + +`transpile(circuits, pass_manager=None)` + +A wrapper to transpile circuits to allow algorithm access the transpiled circuits. + +**Parameters** + +* **circuits** (*Union\['QuantumCircuit', List\['QuantumCircuit']]*) – circuits to transpile +* **pass\_manager** (*Optional\['PassManager']*) – A pass manager to transpile the circuits. If none is given, but either `pass_manager` or `bound_pass_manager` has been set in the initializer, these are run. If none has been provided there either, the backend and compile configs from the initializer are used. + +**Returns** + +**The transpiled circuits, it is always a list even though** + +the length is one. + +**Return type** + +List\[‘QuantumCircuit’] + diff --git a/docs/api/qiskit/0.46/qiskit.utils.mitigation.CompleteMeasFitter.md b/docs/api/qiskit/0.46/qiskit.utils.mitigation.CompleteMeasFitter.md new file mode 100644 index 00000000000..7a71cec3797 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.utils.mitigation.CompleteMeasFitter.md @@ -0,0 +1,128 @@ +--- +title: CompleteMeasFitter +description: API reference for qiskit.utils.mitigation.CompleteMeasFitter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.utils.mitigation.CompleteMeasFitter +--- + +# CompleteMeasFitter + + + +`qiskit.utils.mitigation.CompleteMeasFitter(results, state_labels, qubit_list=None, circlabel='')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/mitigation/fitters.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: Measurement correction fitter for a full calibration + +Initialize a measurement calibration matrix from the results of running the circuits returned by measurement\_calibration\_circuits + +A wrapper for the tensored fitter + + + This class is not a public API. The internals are not stable and will likely change. It is used solely for the `measurement_error_mitigation_cls` kwarg of the [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") class’s constructor (as a class not an instance). Anything outside of that usage does not have the normal user-facing API stability. + + + + The class `qiskit.utils.mitigation.fitters.CompleteMeasFitter` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/qi\_migration](https://qisk.it/qi_migration). + + +**Parameters** + +* **results** – the results of running the measurement calibration circuits. If this is None the user will set a calibration matrix later. +* **state\_labels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – list of calibration state labels returned from measurement\_calibration\_circuits. The output matrix will obey this ordering. +* **qubit\_list** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]*) – List of the qubits (for reference and if the subset is needed). If None, the qubit\_list will be created according to the length of state\_labels\[0]. +* **circlabel** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – if the qubits were labeled. + +## Attributes + + + +### cal\_matrix + +Return cal\_matrix. + + + +### filter + +Return a measurement filter using the cal matrix. + + + +### qubit\_list + +Return list of qubits. + + + +### state\_labels + +Return state\_labels. + +## Methods + +### add\_data + + + +`add_data(new_results, rebuild_cal_matrix=True)` + +Add measurement calibration data + +**Parameters** + +* **new\_results** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*qiskit.result.Result*](qiskit.result.Result "qiskit.result.Result")) – a single result or list of result objects. +* **rebuild\_cal\_matrix** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – rebuild the calibration matrix + +### readout\_fidelity + + + +`readout_fidelity(label_list=None)` + +Based on the results, output the readout fidelity which is the normalized trace of the calibration matrix + +**Parameters** + +**label\_list** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If None, returns the average assignment fidelity of a single state. Otherwise it returns the assignment fidelity to be in any one of these states averaged over the second index. + +**Returns** + +readout fidelity (assignment fidelity) + +**Return type** + +numpy.array + +**Additional Information:** + +The on-diagonal elements of the calibration matrix are the probabilities of measuring state ‘x’ given preparation of state ‘x’ and so the normalized trace is the average assignment fidelity + +### subset\_fitter + + + +`subset_fitter(qubit_sublist)` + +Return a fitter object that is a subset of the qubits in the original list. + +**Parameters** + +**qubit\_sublist** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – must be a subset of qubit\_list + +**Returns** + +**A new fitter that has the calibration for a** + +subset of qubits + +**Return type** + +[CompleteMeasFitter](#qiskit.utils.mitigation.CompleteMeasFitter "qiskit.utils.mitigation.CompleteMeasFitter") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the calibration matrix is not initialized + diff --git a/docs/api/qiskit/0.46/qiskit.utils.mitigation.TensoredMeasFitter.md b/docs/api/qiskit/0.46/qiskit.utils.mitigation.TensoredMeasFitter.md new file mode 100644 index 00000000000..0c48b247637 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.utils.mitigation.TensoredMeasFitter.md @@ -0,0 +1,139 @@ +--- +title: TensoredMeasFitter +description: API reference for qiskit.utils.mitigation.TensoredMeasFitter +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.utils.mitigation.TensoredMeasFitter +--- + +# TensoredMeasFitter + + + +`qiskit.utils.mitigation.TensoredMeasFitter(results, mit_pattern, substate_labels_list=None, circlabel='')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/mitigation/fitters.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Deprecated: Measurement correction fitter for a tensored calibration. + +Initialize a measurement calibration matrix from the results of running the circuits returned by measurement\_calibration\_circuits. + + + This class is not a public API. The internals are not stable and will likely change. It is used solely for the `measurement_error_mitigation_cls` kwarg of the [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") class’s constructor (as a class not an instance). Anything outside of that usage does not have the normal user-facing API stability. + + + + The class `qiskit.utils.mitigation.fitters.TensoredMeasFitter` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/qi\_migration](https://qisk.it/qi_migration). + + +**Parameters** + +* **results** – the results of running the measurement calibration circuits. If this is None, the user will set calibration matrices later. +* **mit\_pattern** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – qubits to perform the measurement correction on, divided to groups according to tensors +* **substate\_labels\_list** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]]*) – for each calibration matrix, the labels of its rows and columns. If None, the labels are ordered lexicographically +* **circlabel** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – if the qubits were labeled + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if the mit\_pattern doesn’t match the substate\_labels\_list + +## Attributes + + + +### cal\_matrices + +Return cal\_matrices. + + + +### filter + +Return a measurement filter using the cal matrices. + + + +### nqubits + +Return \_qubit\_list\_sizes. + + + +### substate\_labels\_list + +Return \_substate\_labels\_list. + +## Methods + +### add\_data + + + +`add_data(new_results, rebuild_cal_matrix=True)` + +Add measurement calibration data + +**Parameters** + +* **new\_results** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*qiskit.result.Result*](qiskit.result.Result "qiskit.result.Result")) – a single result or list of Result objects. +* **rebuild\_cal\_matrix** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – rebuild the calibration matrix + +### readout\_fidelity + + + +`readout_fidelity(cal_index=0, label_list=None)` + +Based on the results, output the readout fidelity, which is the average of the diagonal entries in the calibration matrices. + +**Parameters** + +* **cal\_index** (*integer*) – readout fidelity for this index in \_cal\_matrices +* **label\_list** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Returns the average fidelity over of the groups f states. In the form of a list of lists of states. If None, then each state used in the construction of the calibration matrices forms a group of size 1 + +**Returns** + +The readout fidelity (assignment fidelity) + +**Return type** + +numpy.array + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the calibration matrix has not been set for the object. + +**Additional Information:** + +The on-diagonal elements of the calibration matrices are the probabilities of measuring state ‘x’ given preparation of state ‘x’. + +### subset\_fitter + + + +`subset_fitter(qubit_sublist)` + +Return a fitter object that is a subset of the qubits in the original list. + +This is only a partial implementation of the `subset_fitter` method since only mitigation patterns of length 1 are supported. This corresponds to patterns of the form `[[0], [1], [2], ...]`. Note however, that such patterns are a good first approximation to mitigate readout errors on large quantum circuits. + +**Parameters** + +**qubit\_sublist** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – must be a subset of qubit\_list + +**Returns** + +**A new fitter that has the calibration for a** + +subset of qubits + +**Return type** + +[TensoredMeasFitter](#qiskit.utils.mitigation.TensoredMeasFitter "qiskit.utils.mitigation.TensoredMeasFitter") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the calibration matrix is not initialized +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If the mit pattern is not a tensor of single-qubit measurement error mitigation. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If a qubit in the given `qubit_sublist` is not in the list of qubits in the mit. pattern. + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.array_to_latex.md b/docs/api/qiskit/0.46/qiskit.visualization.array_to_latex.md new file mode 100644 index 00000000000..6846804a895 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.array_to_latex.md @@ -0,0 +1,51 @@ +--- +title: array_to_latex +description: API reference for qiskit.visualization.array_to_latex +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.array_to_latex +--- + + + +# qiskit.visualization.array\_to\_latex + + + +`qiskit.visualization.array_to_latex(array, precision=10, prefix='', source=False, max_size=8)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/array.py "view source code") + +Latex representation of a complex numpy array (with dimension 1 or 2) + +**Parameters** + +* **array** (*ndarray*) – The array to be converted to latex, must have dimension 1 or 2 and contain only numerical data. + +* **precision** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – For numbers not close to integers or common terms, the number of decimal places to round to. + +* **prefix** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Latex string to be prepended to the latex, intended for labels. + +* **source** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `False`, will return IPython.display.Latex object. If display is `True`, will instead return the LaTeX source string. + +* **max\_size** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*(*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*) or* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – + + The maximum size of the output Latex array. + + * If list(`int`), then the 0th element of the list specifies the maximum width (including dots characters) and the 1st specifies the maximum height (also inc. dots characters). + * If a single `int` then this value sets the maximum width \_and\_ maximum height. + +**Returns** + +**If `source` is `True`, a `str` of the LaTeX** + +representation of the array, else an `IPython.display.Latex` representation of the array. + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") or IPython.display.Latex + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – If array can not be interpreted as a numerical numpy array. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the dimension of array is not 1 or 2. +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – If `source` is `False` and `IPython.display.Latex` cannot be imported. + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.circuit.qcstyle.DefaultStyle.md b/docs/api/qiskit/0.46/qiskit.visualization.circuit.qcstyle.DefaultStyle.md new file mode 100644 index 00000000000..646f7fcbc40 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.circuit.qcstyle.DefaultStyle.md @@ -0,0 +1,161 @@ +--- +title: DefaultStyle +description: API reference for qiskit.visualization.circuit.qcstyle.DefaultStyle +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.visualization.circuit.qcstyle.DefaultStyle +--- + +# DefaultStyle + + + +`qiskit.visualization.circuit.qcstyle.DefaultStyle`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/circuit/qcstyle.py "view source code") + +Bases: [`object`](https://docs.python.org/3/library/functions.html#object "(in Python v3.12)") + +Creates a Default Style dictionary + +**Style Dict Details** + +The style dict contains numerous options that define the style of the output circuit visualization. The style dict is used by the mpl or latex output. The options available in the style dict are defined below: + +**name (str): the name of the style. The name can be set to `iqp`,** + +`iqp-dark`, `textbook`, `bw`, `clifford`, or the name of a user-created json file. This overrides the setting in the user config file (usually `~/.qiskit/settings.conf`). + +**textcolor (str): the color code to use for all text not inside a gate.** + +Defaults to `#000000` + +**subtextcolor (str): the color code to use for subtext. Defaults to** + +`#000000` + +**linecolor (str): the color code to use for lines. Defaults to** + +`#000000` + +**creglinecolor (str): the color code to use for classical register** + +lines. Defaults to `#778899` + +**gatetextcolor (str): the color code to use for gate text. Defaults to** + +`#000000` + +**gatefacecolor (str): the color code to use for a gate if no color** + +specified in the ‘displaycolor’ dict. Defaults to `#BB8BFF` + +**barrierfacecolor (str): the color code to use for barriers. Defaults to** + +`#BDBDBD` + +**backgroundcolor (str): the color code to use for the background.** + +Defaults to `#FFFFFF` + +**edgecolor (str): the color code to use for gate edges when using the** + +bw style. Defaults to `#000000`. + +fontsize (int): the font size to use for text. Defaults to 13. + +subfontsize (int): the font size to use for subtext. Defaults to 8. + +**showindex (bool): if set to True, show the index numbers at the top.** + +Defaults to False. + +**figwidth (int): the maximum width (in inches) for the output figure.** + +If set to -1, the maximum displayable width will be used. Defaults to -1. + +dpi (int): the DPI to use for the output image. Defaults to 150. + +**margin (list): a list of margin values to adjust spacing around output** + +image. Takes a list of 4 ints: \[x left, x right, y bottom, y top]. Defaults to \[2.0, 0.1, 0.1, 0.3]. + +**creglinestyle (str): The style of line to use for classical registers.** + +Choices are `solid`, `doublet`, or any valid matplotlib linestyle kwarg value. Defaults to `doublet`. + +**displaytext (dict): a dictionary of the text to use for certain element** + +types in the output visualization. These items allow the use of LaTeX formatting for gate names. The ‘displaytext’ dict can contain any number of elements. User created names and labels may be used as keys, which allow these to have Latex formatting. The default values are (default.json): + +```python +{ + 'u1': 'U_1', + 'u2': 'U_2', + 'u3': 'U_3', + 'sdg': 'S^\dagger', + 'sx': '\sqrt{X}', + 'sxdg': '\sqrt{X}^\dagger', + 't': 'T', + 'tdg': 'T^\dagger', + 'dcx': 'Dcx', + 'iswap': 'Iswap', + 'ms': 'MS', + 'rx': 'R_X', + 'ry': 'R_Y', + 'rz': 'R_Z', + 'rxx': 'R_{XX}', + 'ryy': 'R_{YY}', + 'rzx': 'R_{ZX}', + 'rzz': 'ZZ', + 'reset': '\left|0\right\rangle', + 'initialize': '|\psi\rangle' +} +``` + +**displaycolor (dict): the color codes to use for each circuit element in** + +the form (gate\_color, text\_color). Colors can also be entered without the text color, such as ‘u1’: ‘#FA74A6’, in which case the text color will always be gatetextcolor. The displaycolor dict can contain any number of elements. User names and labels may be used as keys, which allows for custom colors for user-created gates. The default values are (default.json): + +```python +{ + 'u1': ('#FA74A6', '#000000'), + 'u2': ('#FA74A6', '#000000'), + 'u3': ('#FA74A6', '#000000'), + 'id': ('#05BAB6', '#000000'), + 'u': ('#BB8BFF', '#000000'), + 'p': ('#BB8BFF', '#000000'), + 'x': ('#05BAB6', '#000000'), + 'y': ('#05BAB6', '#000000'), + 'z': ('#05BAB6', '#000000'), + 'h': ('#6FA4FF', '#000000'), + 'cx': ('#6FA4FF', '#000000'), + 'ccx': ('#BB8BFF', '#000000'), + 'mcx': ('#BB8BFF', '#000000'), + 'mcx_gray': ('#BB8BFF', '#000000'), + 'cy': ('#6FA4FF', '#000000'), + 'cz': ('#6FA4FF', '#000000'), + 'swap': ('#6FA4FF', '#000000'), + 'cswap': ('#BB8BFF', '#000000'), + 'ccswap': ('#BB8BFF', '#000000'), + 'dcx': ('#6FA4FF', '#000000'), + 'cdcx': ('#BB8BFF', '#000000'), + 'ccdcx': ('#BB8BFF', '#000000'), + 'iswap': ('#6FA4FF', '#000000'), + 's': ('#6FA4FF', '#000000'), + 'sdg': ('#6FA4FF', '#000000'), + 't': ('#BB8BFF', '#000000'), + 'tdg': ('#BB8BFF', '#000000'), + 'sx': ('#6FA4FF', '#000000'), + 'sxdg': ('#6FA4FF', '#000000') + 'r': ('#BB8BFF', '#000000'), + 'rx': ('#BB8BFF', '#000000'), + 'ry': ('#BB8BFF', '#000000'), + 'rz': ('#BB8BFF', '#000000'), + 'rxx': ('#BB8BFF', '#000000'), + 'ryy': ('#BB8BFF', '#000000'), + 'rzx': ('#BB8BFF', '#000000'), + 'reset': ('#000000', '#FFFFFF'), + 'target': ('#FFFFFF', '#FFFFFF'), + 'measure': ('#000000', '#FFFFFF'), +} +``` + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.circuit_drawer.md b/docs/api/qiskit/0.46/qiskit.visualization.circuit_drawer.md new file mode 100644 index 00000000000..5a089c3f88b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.circuit_drawer.md @@ -0,0 +1,91 @@ +--- +title: circuit_drawer +description: API reference for qiskit.visualization.circuit_drawer +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.circuit_drawer +--- + + + +# qiskit.visualization.circuit\_drawer + + + +`qiskit.visualization.circuit_drawer(circuit, scale=None, filename=None, style=None, output=None, interactive=False, plot_barriers=True, reverse_bits=None, justify=None, vertical_compression='medium', idle_wires=True, with_layout=True, fold=None, ax=None, initial_state=False, cregbundle=None, wire_order=None, expr_len=30)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/circuit/circuit_visualization.py "view source code") + +Draw the quantum circuit. Use the output parameter to choose the drawing format: + +**text**: ASCII art TextDrawing that can be printed in the console. + +**matplotlib**: images with color rendered purely in Python. + +**latex**: high-quality images compiled via latex. + +**latex\_source**: raw uncompiled latex output. + + + Support for [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") nodes in conditions and `SwitchCaseOp.target` fields is preliminary and incomplete. The `text` and `mpl` drawers will make a best-effort attempt to show data dependencies, but the LaTeX-based drawers will skip these completely. + + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – the quantum circuit to draw +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – scale of image to draw (shrink if \< 1.0). Only used by the mpl, latex and latex\_source outputs. Defaults to 1.0. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. Defaults to None. +* **style** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – dictionary of style or file name of style json file. This option is only used by the mpl or latex output type. If style is a str, it is used as the path to a json file which contains a style dict. The file will be opened, parsed, and then any style elements in the dict will replace the default values in the input dict. A file to be loaded must end in `.json`, but the name entered here can omit `.json`. For example, `style='iqp.json'` or `style='iqp'`. If style is a dict and the `'name'` key is set, that name will be used to load a json file, followed by loading the other items in the style dict. For example, `style={'name': 'iqp'}`. If style is not a str and name is not a key in the style dict, then the default value from the user config file (usually `~/.qiskit/settings.conf`) will be used, for example, `circuit_mpl_style = iqp`. If none of these are set, the clifford style will be used. The search path for style json files can be specified in the user config, for example, `circuit_mpl_style_path = /home/user/styles:/home/user`. See: [`DefaultStyle`](qiskit.visualization.circuit.qcstyle.DefaultStyle "qiskit.visualization.circuit.qcstyle.DefaultStyle") for more information on the contents. +* **output** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – select the output method to use for drawing the circuit. Valid choices are `text`, `mpl`, `latex`, `latex_source`. By default, the text drawer is used unless the user config file (usually `~/.qiskit/settings.conf`) has an alternative backend set as the default. For example, `circuit_drawer = latex`. If the output kwarg is set, that backend will always be used over the default in the user config file. +* **interactive** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to true, show the circuit in a new window (for mpl this depends on the matplotlib backend being used supporting this). Note when used with either the text or the latex\_source output type this has no effect and will be silently ignored. Defaults to False. +* **reverse\_bits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – when set to True, reverse the bit order inside registers for the output visualization. Defaults to False unless the user config file (usually `~/.qiskit/settings.conf`) has an alternative value set. For example, `circuit_reverse_bits = True`. +* **plot\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – enable/disable drawing barriers in the output circuit. Defaults to True. +* **justify** (*string*) – options are `left`, `right` or `none`. If anything else is supplied, it defaults to left justified. It refers to where gates should be placed in the output circuit if there is an option. `none` results in each gate being placed in its own column. +* **vertical\_compression** (*string*) – `high`, `medium` or `low`. It merges the lines generated by the text output so the drawing will take less vertical room. Default is `medium`. Only used by the text output, will be silently ignored otherwise. +* **idle\_wires** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – include idle wires (wires with no circuit elements) in output visualization. Default is True. +* **with\_layout** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – include layout information, with labels on the physical layout. Default is True. +* **fold** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – sets pagination. It can be disabled using -1. In text, sets the length of the lines. This is useful when the drawing does not fit in the console. If None (default), it will try to guess the console width using `shutil.get_terminal_size()`. However, if running in jupyter, the default line length is set to 80 characters. In mpl, it is the number of (visual) layers before folding. Default is 25. +* **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – Only used by the mpl backend. An optional Axes object to be used for the visualization output. If none is specified, a new matplotlib Figure will be created and used. Additionally, if specified there will be no returned Figure since it is redundant. +* **initial\_state** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional. Adds `|0>` in the beginning of the wire. Default is False. +* **cregbundle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional. If set True, bundle classical registers into a single wire. Default is true if possible, and false if a block instruction needs to access an individual bit from a register. +* **wire\_order** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Optional. A list of integers used to reorder the display of the bits. The list must have an entry for every bit with the bits in the range 0 to (num\_qubits + num\_clbits). +* **expr\_len** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The number of characters to display if an [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") is used for the condition in a [`ControlFlowOp`](qiskit.circuit.ControlFlowOp "qiskit.circuit.ControlFlowOp"). If this number is exceeded, the string will be truncated at that number and ‘…’ added to the end. + +**Returns** + +`TextDrawing` or `matplotlib.figure` or `PIL.Image` or [`str`](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"): + +* **TextDrawing (output=’text’)** + + A drawing that can be printed as ascii art. + +* **matplotlib.figure.Figure (output=’mpl’)** + + A matplotlib figure object for the circuit diagram. + +* **PIL.Image (output=’latex’)** + + An in-memory representation of the image of the circuit diagram. + +* **str (output=’latex\_source’)** + + The LaTeX source code for visualizing the circuit diagram. + +**Raises** + +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – when an invalid output method is selected +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – when the output methods requires non-installed libraries. + +**Example** + +```python +from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit +from qiskit.tools.visualization import circuit_drawer +q = QuantumRegister(1) +c = ClassicalRegister(1) +qc = QuantumCircuit(q, c) +qc.h(q) +qc.measure(q, c) +circuit_drawer(qc, output='mpl', style={'backgroundcolor': '#EEEEEE'}) +``` + +![../\_images/qiskit-visualization-circuit\_drawer-1.png](/images/api/qiskit/0.46/qiskit-visualization-circuit_drawer-1.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.dag_drawer.md b/docs/api/qiskit/0.46/qiskit.visualization.dag_drawer.md new file mode 100644 index 00000000000..e715833e0f2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.dag_drawer.md @@ -0,0 +1,62 @@ +--- +title: dag_drawer +description: API reference for qiskit.visualization.dag_drawer +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.dag_drawer +--- + + + +# qiskit.visualization.dag\_drawer + + + +`qiskit.visualization.dag_drawer(dag, scale=0.7, filename=None, style='color')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/dag_visualization.py "view source code") + +Plot the directed acyclic graph (dag) to represent operation dependencies in a quantum circuit. + +This function calls the [`graphviz_draw()`](https://www.rustworkx.org/apiref/rustworkx.visualization.graphviz_draw.html#rustworkx.visualization.graphviz_draw "(in rustworkx v0.14.0)") function from the `rustworkx` package to draw the DAG. + +**Parameters** + +* **dag** ([*DAGCircuit*](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit")) – The dag to draw. +* **scale** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – scaling factor +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to (format inferred from name) +* **style** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – ‘plain’: B\&W graph ‘color’ (default): color input/output/op nodes + +**Returns** + +**if in Jupyter notebook and not saving to file,** + +otherwise None. + +**Return type** + +PIL.Image + +**Raises** + +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – when style is not recognized. +* [**InvalidFileError**](exceptions#qiskit.exceptions.InvalidFileError "qiskit.exceptions.InvalidFileError") – when filename provided is not valid + +**Example** + +```python +from qiskit import QuantumRegister, ClassicalRegister, QuantumCircuit +from qiskit.dagcircuit import DAGCircuit +from qiskit.converters import circuit_to_dag +from qiskit.visualization import dag_drawer + +q = QuantumRegister(3, 'q') +c = ClassicalRegister(3, 'c') +circ = QuantumCircuit(q, c) +circ.h(q[0]) +circ.cx(q[0], q[1]) +circ.measure(q[0], c[0]) +circ.rz(0.5, q[1]).c_if(c, 2) + +dag = circuit_to_dag(circ) +dag_drawer(dag) +``` + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.pass_manager_drawer.md b/docs/api/qiskit/0.46/qiskit.visualization.pass_manager_drawer.md new file mode 100644 index 00000000000..068c6b20607 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.pass_manager_drawer.md @@ -0,0 +1,62 @@ +--- +title: pass_manager_drawer +description: API reference for qiskit.visualization.pass_manager_drawer +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.pass_manager_drawer +--- + + + +# qiskit.visualization.pass\_manager\_drawer + + + +`qiskit.visualization.pass_manager_drawer(pass_manager, filename=None, style=None, raw=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/pass_manager_visualization.py "view source code") + +Draws the pass manager. + +This function needs [pydot](https://github.com/pydot/pydot), which in turn needs [Graphviz](https://www.graphviz.org/) to be installed. + +**Parameters** + +* **pass\_manager** ([*PassManager*](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager")) – the pass manager to be drawn +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to +* **style** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *or OrderedDict*) – keys are the pass classes and the values are the colors to make them. An example can be seen in the DEFAULT\_STYLE. An ordered dict can be used to ensure a priority coloring when pass falls into multiple categories. Any values not included in the provided dict will be filled in from the default dict +* **raw** ([*Bool*](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool")) – True if you want to save the raw Dot output not an image. The default is False. + +**Returns** + +an in-memory representation of the pass manager. Or None if no image was generated or PIL is not installed. + +**Return type** + +PIL.Image or None + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – when nxpd or pydot not installed. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – If raw=True and filename=None. + +**Example** + +```python + %matplotlib inline +from qiskit import QuantumCircuit +from qiskit.compiler import transpile +from qiskit.transpiler import PassManager +from qiskit.visualization import pass_manager_drawer +from qiskit.transpiler.passes import Unroller + +circ = QuantumCircuit(3) +circ.ccx(0, 1, 2) +circ.draw() + +pass_ = Unroller(['u1', 'u2', 'u3', 'cx']) +pm = PassManager(pass_) +new_circ = pm.run(circ) +new_circ.draw(output='mpl') + +pass_manager_drawer(pm, "passmanager.jpg") +``` + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_multivector.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_multivector.md new file mode 100644 index 00000000000..9163bb4f15b --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_multivector.md @@ -0,0 +1,85 @@ +--- +title: plot_bloch_multivector +description: API reference for qiskit.visualization.plot_bloch_multivector +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_bloch_multivector +--- + + + +# qiskit.visualization.plot\_bloch\_multivector + + + +`qiskit.visualization.plot_bloch_multivector(state, title='', figsize=None, *, reverse_bits=False, filename=None, font_size=None, title_font_size=None, title_pad=1)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/state_visualization.py "view source code") + +Plot a Bloch sphere for each qubit. + +Each component $(x,y,z)$ of the Bloch sphere labeled as ‘qubit i’ represents the expected value of the corresponding Pauli operator acting only on that qubit, that is, the expected value of $I_{N-1} \otimes\dotsb\otimes I_{i+1}\otimes P_i \otimes I_{i-1}\otimes\dotsb\otimes I_0$, where $N$ is the number of qubits, $P\in \{X,Y,Z\}$ and $I$ is the identity operator. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") *or ndarray*) – an N-qubit quantum state. +* **title** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a string that represents the plot title +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – size of each individual Bloch sphere figure, in inches. +* **reverse\_bits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, plots qubits following Qiskit’s convention \[Default:False]. +* **font\_size** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Font size for the Bloch ball figures. +* **title\_font\_size** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Font size for the title. +* **title\_pad** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Padding for the title (suptitle y position is y=1+title\_pad/100). + +**Returns** + +A matplotlib figure instance. + +**Return type** + +[`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.2)") + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Requires matplotlib. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – if input is not a valid N-qubit state. + +**Examples** + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import Statevector +from qiskit.visualization import plot_bloch_multivector + +qc = QuantumCircuit(2) +qc.h(0) +qc.x(1) + +state = Statevector(qc) +plot_bloch_multivector(state) +``` + +![../\_images/qiskit-visualization-plot\_bloch\_multivector-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_multivector-1.png) + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import Statevector +from qiskit.visualization import plot_bloch_multivector + +qc = QuantumCircuit(2) +qc.h(0) +qc.x(1) + +# You can reverse the order of the qubits. + +from qiskit.quantum_info import DensityMatrix + +qc = QuantumCircuit(2) +qc.h([0, 1]) +qc.t(1) +qc.s(0) +qc.cx(0,1) + +matrix = DensityMatrix(qc) +plot_bloch_multivector(matrix, title='My Bloch Spheres', reverse_bits=True) +``` + +![../\_images/qiskit-visualization-plot\_bloch\_multivector-2.png](/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_multivector-2.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_vector.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_vector.md new file mode 100644 index 00000000000..7de41a589f2 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_bloch_vector.md @@ -0,0 +1,62 @@ +--- +title: plot_bloch_vector +description: API reference for qiskit.visualization.plot_bloch_vector +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_bloch_vector +--- + + + +# qiskit.visualization.plot\_bloch\_vector + + + +`qiskit.visualization.plot_bloch_vector(bloch, title='', ax=None, figsize=None, coord_type='cartesian', font_size=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/state_visualization.py "view source code") + +Plot the Bloch sphere. + +Plot a Bloch sphere with the specified coordinates, that can be given in both cartesian and spherical systems. + +**Parameters** + +* **bloch** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[double]*) – array of three elements where \[\, \, \] (Cartesian) or \[\, \, \] (spherical in radians) \ is inclination angle from +z direction \ is azimuth from +x direction +* **title** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a string that represents the plot title +* **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An Axes to use for rendering the bloch sphere +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. Has no effect is passing `ax`. +* **coord\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a string that specifies coordinate type for bloch (Cartesian or spherical), default is Cartesian +* **font\_size** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Font size. + +**Returns** + +A matplotlib figure instance if `ax = None`. + +**Return type** + +[`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.2)") + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Requires matplotlib. + +**Examples** + +```python +from qiskit.visualization import plot_bloch_vector + +plot_bloch_vector([0,1,0], title="New Bloch Sphere") +``` + +![../\_images/qiskit-visualization-plot\_bloch\_vector-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_vector-1.png) + +```python +import numpy as np +from qiskit.visualization import plot_bloch_vector + +# You can use spherical coordinates instead of cartesian. + +plot_bloch_vector([1, np.pi/2, np.pi/3], coord_type='spherical') +``` + +![../\_images/qiskit-visualization-plot\_bloch\_vector-2.png](/images/api/qiskit/0.46/qiskit-visualization-plot_bloch_vector-2.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_circuit_layout.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_circuit_layout.md new file mode 100644 index 00000000000..e9135816645 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_circuit_layout.md @@ -0,0 +1,62 @@ +--- +title: plot_circuit_layout +description: API reference for qiskit.visualization.plot_circuit_layout +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_circuit_layout +--- + + + +# qiskit.visualization.plot\_circuit\_layout + + + +`qiskit.visualization.plot_circuit_layout(circuit, backend, view='virtual', qubit_coordinates=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/gate_map.py "view source code") + +Plot the layout of a circuit transpiled for a given target backend. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Input quantum circuit. +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – Target backend. +* **view** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Layout view: either ‘virtual’ or ‘physical’. +* **qubit\_coordinates** (*Sequence*) – An optional sequence input (list or array being the most common) of 2d coordinates for each qubit. The length of the sequence must match the number of qubits on the backend. The sequence should be the planar coordinates in a 0-based square grid where each qubit is located. + +**Returns** + +A matplotlib figure showing layout. + +**Return type** + +Figure + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – Invalid view type given. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – Circuit has no layout attribute. + +**Example** + +```python +import numpy as np +from qiskit import QuantumCircuit, transpile +from qiskit.providers.fake_provider import FakeVigoV2 +from qiskit.visualization import plot_circuit_layout +from qiskit.tools.monitor import job_monitor +from qiskit.providers.fake_provider import FakeVigoV2 +import matplotlib.pyplot as plt + +ghz = QuantumCircuit(3, 3) +ghz.h(0) +for idx in range(1,3): + ghz.cx(0,idx) +ghz.measure(range(3), range(3)) + +backend = FakeVigoV2() +new_circ_lv3 = transpile(ghz, backend=backend, optimization_level=3) +plot_circuit_layout(new_circ_lv3, backend) +``` + +![../\_images/qiskit-visualization-plot\_circuit\_layout-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_circuit_layout-1.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_coupling_map.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_coupling_map.md new file mode 100644 index 00000000000..c8aaf26be62 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_coupling_map.md @@ -0,0 +1,62 @@ +--- +title: plot_coupling_map +description: API reference for qiskit.visualization.plot_coupling_map +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_coupling_map +--- + + + +# qiskit.visualization.plot\_coupling\_map + + + +`qiskit.visualization.plot_coupling_map(num_qubits, qubit_coordinates, coupling_map, figsize=None, plot_directed=False, label_qubits=True, qubit_size=None, line_width=4, font_size=None, qubit_color=None, qubit_labels=None, line_color=None, font_color='white', ax=None, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/gate_map.py "view source code") + +Plots an arbitrary coupling map of qubits (embedded in a plane). + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of qubits defined and plotted. +* **qubit\_coordinates** (*List\[List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – A list of two-element lists, with entries of each nested list being the planar coordinates in a 0-based square grid where each qubit is located. +* **coupling\_map** (*List\[List\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – A list of two-element lists, with entries of each nested list being the qubit numbers of the bonds to be plotted. +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Output figure size (wxh) in inches. +* **plot\_directed** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot directed coupling map. +* **label\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label the qubits. +* **qubit\_size** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Size of qubit marker. +* **line\_width** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width of lines. +* **font\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Font size of qubit labels. +* **qubit\_color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of colors for the qubits +* **qubit\_labels** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of qubit labels +* **line\_color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of colors for each line from coupling\_map. +* **font\_color** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The font color for the qubit labels. +* **ax** (*Axes*) – A Matplotlib axes instance. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. + +**Returns** + +A Matplotlib figure instance. + +**Return type** + +Figure + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – If matplotlib or graphviz is not installed. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If length of qubit labels does not match number of qubits. + +**Example** + +```python +from qiskit.visualization import plot_coupling_map + +num_qubits = 8 +qubit_coordinates = [[0, 1], [1, 1], [1, 0], [1, 2], [2, 0], [2, 2], [2, 1], [3, 1]] +coupling_map = [[0, 1], [1, 2], [2, 3], [3, 5], [4, 5], [5, 6], [2, 4], [6, 7]] +plot_coupling_map(num_qubits, qubit_coordinates, coupling_map) +``` + +![../\_images/qiskit-visualization-plot\_coupling\_map-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_coupling_map-1.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_distribution.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_distribution.md new file mode 100644 index 00000000000..0a1031aeba0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_distribution.md @@ -0,0 +1,79 @@ +--- +title: plot_distribution +description: API reference for qiskit.visualization.plot_distribution +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_distribution +--- + + + +# qiskit.visualization.plot\_distribution + + + +`qiskit.visualization.plot_distribution(data, figsize=(7, 5), color=None, number_to_keep=None, sort='asc', target_string=None, legend=None, bar_labels=True, title=None, ax=None, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/counts_visualization.py "view source code") + +Plot a distribution from input sampled data. + +**Parameters** + +* **data** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – This is either a list of dictionaries or a single dict containing the values to represent (ex \{‘001’: 130}) +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. +* **color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – String or list of strings for distribution bar colors. +* **number\_to\_keep** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of terms to plot per dataset. The rest is made into a single bar called ‘rest’. If multiple datasets are given, the `number_to_keep` applies to each dataset individually, which may result in more bars than `number_to_keep + 1`. The `number_to_keep` applies to the total values, rather than the x-axis sort. +* **sort** (*string*) – Could be ‘asc’, ‘desc’, ‘hamming’, ‘value’, or ‘value\_desc’. If set to ‘value’ or ‘value\_desc’ the x axis will be sorted by the maximum probability for each bitstring. Defaults to ‘asc’. +* **target\_string** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Target string if ‘sort’ is a distance measure. +* **legend** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of strings to use for labels of the data. The number of entries must match the length of data (if data is a list or 1 if it’s a dict) +* **bar\_labels** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label each bar in histogram with probability value. +* **title** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A string to use for the plot title +* **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. Additionally, if specified there will be no returned Figure since it is redundant. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. + +**Returns** + +A figure for the rendered distribution, if the `ax` kwarg is not set. + +**Return type** + +matplotlib.Figure + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Matplotlib not available. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – When legend is provided and the length doesn’t match the input data. + +**Examples** + +```python +# Plot two counts in the same figure with legends and colors specified. + +from qiskit.visualization import plot_distribution + +counts1 = {'00': 525, '11': 499} +counts2 = {'00': 511, '11': 514} + +legend = ['First execution', 'Second execution'] + +plot_distribution([counts1, counts2], legend=legend, color=['crimson','midnightblue'], + title="New Distribution") + +# You can sort the bitstrings using different methods. + +counts = {'001': 596, '011': 211, '010': 50, '000': 117, '101': 33, '111': 8, + '100': 6, '110': 3} + +# Sort by the counts in descending order +dist1 = plot_distribution(counts, sort='value_desc') + +# Sort by the hamming distance (the number of bit flips to change from +# one bitstring to the other) from a target string. +dist2 = plot_distribution(counts, sort='hamming', target_string='001') +``` + +![../\_images/qiskit-visualization-plot\_distribution-1\_00.png](/images/api/qiskit/0.46/qiskit-visualization-plot_distribution-1_00.png) + +![../\_images/qiskit-visualization-plot\_distribution-1\_01.png](/images/api/qiskit/0.46/qiskit-visualization-plot_distribution-1_01.png) + +![../\_images/qiskit-visualization-plot\_distribution-1\_02.png](/images/api/qiskit/0.46/qiskit-visualization-plot_distribution-1_02.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_error_map.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_error_map.md new file mode 100644 index 00000000000..0ed2f68688a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_error_map.md @@ -0,0 +1,51 @@ +--- +title: plot_error_map +description: API reference for qiskit.visualization.plot_error_map +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_error_map +--- + + + +# qiskit.visualization.plot\_error\_map + + + +`qiskit.visualization.plot_error_map(backend, figsize=(15, 12), show_title=True, qubit_coordinates=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/gate_map.py "view source code") + +Plots the error map of a given backend. + +**Parameters** + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – Given backend. +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. +* **show\_title** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show the title or not. +* **qubit\_coordinates** (*Sequence*) – An optional sequence input (list or array being the most common) of 2d coordinates for each qubit. The length of the sequence much mast the number of qubits on the backend. The sequence should be the planar coordinates in a 0-based square grid where each qubit is located. + +**Returns** + +A matplotlib figure showing error map. + +**Return type** + +Figure + +**Raises** + +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – The backend does not provide gate errors for the ‘sx’ gate. +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – If matplotlib or seaborn is not installed. + +**Example** + +```python +from qiskit import QuantumCircuit, execute +from qiskit.visualization import plot_error_map +from qiskit.providers.fake_provider import FakeVigoV2 + +backend = FakeVigoV2() +plot_error_map(backend) +``` + +![../\_images/qiskit-visualization-plot\_error\_map-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_error_map-1.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_gate_map.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_gate_map.md new file mode 100644 index 00000000000..7ed7fe14ce5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_gate_map.md @@ -0,0 +1,62 @@ +--- +title: plot_gate_map +description: API reference for qiskit.visualization.plot_gate_map +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_gate_map +--- + + + +# qiskit.visualization.plot\_gate\_map + + + +`qiskit.visualization.plot_gate_map(backend, figsize=None, plot_directed=False, label_qubits=True, qubit_size=None, line_width=4, font_size=None, qubit_color=None, qubit_labels=None, line_color=None, font_color='white', ax=None, filename=None, qubit_coordinates=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/gate_map.py "view source code") + +Plots the gate map of a device. + +**Parameters** + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – The backend instance that will be used to plot the device gate map. +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Output figure size (wxh) in inches. +* **plot\_directed** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Plot directed coupling map. +* **label\_qubits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label the qubits. +* **qubit\_size** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Size of qubit marker. +* **line\_width** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Width of lines. +* **font\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Font size of qubit labels. +* **qubit\_color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of colors for the qubits +* **qubit\_labels** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of qubit labels +* **line\_color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of colors for each line from coupling\_map. +* **font\_color** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The font color for the qubit labels. +* **ax** (*Axes*) – A Matplotlib axes instance. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. +* **qubit\_coordinates** (*Sequence*) – An optional sequence input (list or array being the most common) of 2d coordinates for each qubit. The length of the sequence much match the number of qubits on the backend. The sequence should be the planar coordinates in a 0-based square grid where each qubit is located. + +**Returns** + +A Matplotlib figure instance. + +**Return type** + +Figure + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if tried to pass a simulator, or if the backend is None, but one of num\_qubits, mpl\_data, or cmap is None. +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – if matplotlib not installed. + +**Example** + +```python +from qiskit import QuantumCircuit, execute +from qiskit.providers.fake_provider import FakeVigoV2 +from qiskit.visualization import plot_gate_map + +backend = FakeVigoV2() + +plot_gate_map(backend) +``` + +![../\_images/qiskit-visualization-plot\_gate\_map-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_gate_map-1.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_histogram.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_histogram.md new file mode 100644 index 00000000000..f33a5e5687a --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_histogram.md @@ -0,0 +1,84 @@ +--- +title: plot_histogram +description: API reference for qiskit.visualization.plot_histogram +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_histogram +--- + + + +# qiskit.visualization.plot\_histogram + + + +`qiskit.visualization.plot_histogram(data, figsize=(7, 5), color=None, number_to_keep=None, sort='asc', target_string=None, legend=None, bar_labels=True, title=None, ax=None, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/counts_visualization.py "view source code") + +Plot a histogram of input counts data. + + + Using plot\_histogram() `data` argument with QuasiDistribution, ProbDistribution, or a distribution dictionary is deprecated as of qiskit-terra 0.22.0. It will be removed no earlier than 3 months after the release date. Instead, use `plot_distribution()`. + + +**Parameters** + +* **data** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – This is either a list of dictionaries or a single dict containing the values to represent (ex `{'001': 130}`) +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. +* **color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – String or list of strings for histogram bar colors. +* **number\_to\_keep** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of terms to plot per dataset. The rest is made into a single bar called ‘rest’. If multiple datasets are given, the `number_to_keep` applies to each dataset individually, which may result in more bars than `number_to_keep + 1`. The `number_to_keep` applies to the total values, rather than the x-axis sort. +* **sort** (*string*) – Could be ‘asc’, ‘desc’, ‘hamming’, ‘value’, or ‘value\_desc’. If set to ‘value’ or ‘value\_desc’ the x axis will be sorted by the number of counts for each bitstring. Defaults to ‘asc’. +* **target\_string** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Target string if ‘sort’ is a distance measure. +* **legend** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of strings to use for labels of the data. The number of entries must match the length of data (if data is a list or 1 if it’s a dict) +* **bar\_labels** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Label each bar in histogram with counts value. +* **title** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – A string to use for the plot title +* **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. Additionally, if specified there will be no returned Figure since it is redundant. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. + +**Returns** + +A figure for the rendered histogram, if the `ax` kwarg is not set. + +**Return type** + +matplotlib.Figure + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Matplotlib not available. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – When legend is provided and the length doesn’t match the input data. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – Input must be Counts or a dict + +**Examples** + +```python +# Plot two counts in the same figure with legends and colors specified. + +from qiskit.visualization import plot_histogram + +counts1 = {'00': 525, '11': 499} +counts2 = {'00': 511, '11': 514} + +legend = ['First execution', 'Second execution'] + +plot_histogram([counts1, counts2], legend=legend, color=['crimson','midnightblue'], + title="New Histogram") + +# You can sort the bitstrings using different methods. + +counts = {'001': 596, '011': 211, '010': 50, '000': 117, '101': 33, '111': 8, + '100': 6, '110': 3} + +# Sort by the counts in descending order +hist1 = plot_histogram(counts, sort='value_desc') + +# Sort by the hamming distance (the number of bit flips to change from +# one bitstring to the other) from a target string. +hist2 = plot_histogram(counts, sort='hamming', target_string='001') +``` + +![../\_images/qiskit-visualization-plot\_histogram-1\_00.png](/images/api/qiskit/0.46/qiskit-visualization-plot_histogram-1_00.png) + +![../\_images/qiskit-visualization-plot\_histogram-1\_01.png](/images/api/qiskit/0.46/qiskit-visualization-plot_histogram-1_01.png) + +![../\_images/qiskit-visualization-plot\_histogram-1\_02.png](/images/api/qiskit/0.46/qiskit-visualization-plot_histogram-1_02.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_state_city.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_city.md new file mode 100644 index 00000000000..13598298d07 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_city.md @@ -0,0 +1,89 @@ +--- +title: plot_state_city +description: API reference for qiskit.visualization.plot_state_city +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_state_city +--- + + + +# qiskit.visualization.plot\_state\_city + + + +`qiskit.visualization.plot_state_city(state, title='', figsize=None, color=None, alpha=1, ax_real=None, ax_imag=None, *, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/state_visualization.py "view source code") + +Plot the cityscape of quantum state. + +Plot two 3d bar graphs (two dimensional) of the real and imaginary part of the density matrix rho. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") *or ndarray*) – an N-qubit quantum state. +* **title** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a string that represents the plot title +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. +* **color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of len=2 giving colors for real and imaginary components of matrix elements. +* **alpha** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Transparency value for bars +* **ax\_real** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. If this is specified without an ax\_imag only the real component plot will be generated. Additionally, if specified there will be no returned Figure since it is redundant. +* **ax\_imag** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. If this is specified without an ax\_real only the imaginary component plot will be generated. Additionally, if specified there will be no returned Figure since it is redundant. + +**Returns** + +The matplotlib.Figure of the visualization if the `ax_real` and `ax_imag` kwargs are not set + +**Return type** + +[`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.2)") + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Requires matplotlib. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – When ‘color’ is not a list of len=2. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – if input is not a valid N-qubit state. + +**Examples** + +```python +# You can choose different colors for the real and imaginary parts of the density matrix. + +from qiskit import QuantumCircuit +from qiskit.quantum_info import DensityMatrix +from qiskit.visualization import plot_state_city + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) + +state = DensityMatrix(qc) +plot_state_city(state, color=['midnightblue', 'crimson'], title="New State City") +``` + +![../\_images/qiskit-visualization-plot\_state\_city-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_state_city-1.png) + +```python +# You can make the bars more transparent to better see the ones that are behind +# if they overlap. + +import numpy as np +from qiskit.quantum_info import Statevector +from qiskit.visualization import plot_state_city +from qiskit import QuantumCircuit + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) + + +qc = QuantumCircuit(2) +qc.h([0, 1]) +qc.cz(0,1) +qc.ry(np.pi/3, 0) +qc.rx(np.pi/5, 1) + +state = Statevector(qc) +plot_state_city(state, alpha=0.6) +``` + +![../\_images/qiskit-visualization-plot\_state\_city-2.png](/images/api/qiskit/0.46/qiskit-visualization-plot_state_city-2.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_state_hinton.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_hinton.md new file mode 100644 index 00000000000..27e62eea163 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_hinton.md @@ -0,0 +1,62 @@ +--- +title: plot_state_hinton +description: API reference for qiskit.visualization.plot_state_hinton +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_state_hinton +--- + + + +# qiskit.visualization.plot\_state\_hinton + + + +`qiskit.visualization.plot_state_hinton(state, title='', figsize=None, ax_real=None, ax_imag=None, *, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/state_visualization.py "view source code") + +Plot a hinton diagram for the density matrix of a quantum state. + +The hinton diagram represents the values of a matrix using squares, whose size indicate the magnitude of their corresponding value and their color, its sign. A white square means the value is positive and a black one means negative. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") *or ndarray*) – An N-qubit quantum state. +* **title** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a string that represents the plot title +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – file path to save image to. +* **ax\_real** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. If this is specified without an ax\_imag only the real component plot will be generated. Additionally, if specified there will be no returned Figure since it is redundant. +* **ax\_imag** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. If this is specified without an ax\_imag only the real component plot will be generated. Additionally, if specified there will be no returned Figure since it is redundant. + +**Returns** + +The matplotlib.Figure of the visualization if neither ax\_real or ax\_imag is set. + +**Return type** + +[`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.2)") + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Requires matplotlib. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – if input is not a valid N-qubit state. + +**Examples** + +```python +import numpy as np +from qiskit import QuantumCircuit +from qiskit.quantum_info import DensityMatrix +from qiskit.visualization import plot_state_hinton + +qc = QuantumCircuit(2) +qc.h([0, 1]) +qc.cz(0,1) +qc.ry(np.pi/3 , 0) +qc.rx(np.pi/5, 1) + +state = DensityMatrix(qc) +plot_state_hinton(state, title="New Hinton Plot") +``` + +![../\_images/qiskit-visualization-plot\_state\_hinton-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_state_hinton-1.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_state_paulivec.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_paulivec.md new file mode 100644 index 00000000000..0ae95376352 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_paulivec.md @@ -0,0 +1,92 @@ +--- +title: plot_state_paulivec +description: API reference for qiskit.visualization.plot_state_paulivec +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_state_paulivec +--- + + + +# qiskit.visualization.plot\_state\_paulivec + + + +`qiskit.visualization.plot_state_paulivec(state, title='', figsize=None, color=None, ax=None, *, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/state_visualization.py "view source code") + +Plot the Pauli-vector representation of a quantum state as bar graph. + +The Pauli-vector of a density matrix $\rho$ is defined by the expectation of each possible tensor product of single-qubit Pauli operators (including the identity), that is + +$$ +\rho = \frac{1}{2^n} \sum_{\sigma \in \{I, X, Y, Z\}^{\otimes n}} + \mathrm{Tr}(\sigma \rho) \sigma. +$$ + +This function plots the coefficients $\mathrm{Tr}(\sigma\rho)$ as bar graph. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") *or ndarray*) – an N-qubit quantum state. +* **title** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – a string that represents the plot title +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. +* **color** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") *or*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Color of the coefficient value bars. +* **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. Additionally, if specified there will be no returned Figure since it is redundant. + +**Returns** + +The matplotlib.Figure of the visualization if the `ax` kwarg is not set + +**Return type** + +[`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.2)") + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Requires matplotlib. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – if input is not a valid N-qubit state. + +**Examples** + +```python +# You can set a color for all the bars. + +from qiskit import QuantumCircuit +from qiskit.quantum_info import Statevector +from qiskit.visualization import plot_state_paulivec + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) + +state = Statevector(qc) +plot_state_paulivec(state, color='midnightblue', title="New PauliVec plot") +``` + +![../\_images/qiskit-visualization-plot\_state\_paulivec-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_state_paulivec-1.png) + +```python +# If you introduce a list with less colors than bars, the color of the bars will +# alternate following the sequence from the list. + +import numpy as np +from qiskit.quantum_info import DensityMatrix +from qiskit import QuantumCircuit +from qiskit.visualization import plot_state_paulivec + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) + +qc = QuantumCircuit(2) +qc.h([0, 1]) +qc.cz(0, 1) +qc.ry(np.pi/3, 0) +qc.rx(np.pi/5, 1) + +matrix = DensityMatrix(qc) +plot_state_paulivec(matrix, color=['crimson', 'midnightblue', 'seagreen']) +``` + +![../\_images/qiskit-visualization-plot\_state\_paulivec-2.png](/images/api/qiskit/0.46/qiskit-visualization-plot_state_paulivec-2.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.plot_state_qsphere.md b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_qsphere.md new file mode 100644 index 00000000000..8e2d662146c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.plot_state_qsphere.md @@ -0,0 +1,81 @@ +--- +title: plot_state_qsphere +description: API reference for qiskit.visualization.plot_state_qsphere +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.plot_state_qsphere +--- + + + +# qiskit.visualization.plot\_state\_qsphere + + + +`qiskit.visualization.plot_state_qsphere(state, figsize=None, ax=None, show_state_labels=True, show_state_phases=False, use_degrees=False, *, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/state_visualization.py "view source code") + +Plot the qsphere representation of a quantum state. Here, the size of the points is proportional to the probability of the corresponding term in the state and the color represents the phase. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") *or ndarray*) – an N-qubit quantum state. +* **figsize** ([*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – Figure size in inches. +* **ax** ([*matplotlib.axes.Axes*](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.html#matplotlib.axes.Axes "(in Matplotlib v3.8.2)")) – An optional Axes object to be used for the visualization output. If none is specified a new matplotlib Figure will be created and used. Additionally, if specified there will be no returned Figure since it is redundant. +* **show\_state\_labels** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – An optional boolean indicating whether to show labels for each basis state. +* **show\_state\_phases** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – An optional boolean indicating whether to show the phase for each basis state. +* **use\_degrees** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – An optional boolean indicating whether to use radians or degrees for the phase values in the plot. + +**Returns** + +A matplotlib figure instance if the `ax` kwarg is not set + +**Return type** + +[`matplotlib.figure.Figure`](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure "(in Matplotlib v3.8.2)") + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Requires matplotlib. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – if input is not a valid N-qubit state. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – Input statevector does not have valid dimensions. + +**Examples** + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import Statevector +from qiskit.visualization import plot_state_qsphere + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) + +state = Statevector(qc) +plot_state_qsphere(state) +``` + +![../\_images/qiskit-visualization-plot\_state\_qsphere-1.png](/images/api/qiskit/0.46/qiskit-visualization-plot_state_qsphere-1.png) + +```python +# You can show the phase of each state and use +# degrees instead of radians + +from qiskit.quantum_info import DensityMatrix +import numpy as np +from qiskit import QuantumCircuit +from qiskit.visualization import plot_state_qsphere + +qc = QuantumCircuit(2) +qc.h([0, 1]) +qc.cz(0,1) +qc.ry(np.pi/3, 0) +qc.rx(np.pi/5, 1) +qc.z(1) + +matrix = DensityMatrix(qc) +plot_state_qsphere(matrix, + show_state_phases = True, use_degrees = True) +``` + +![../\_images/qiskit-visualization-plot\_state\_qsphere-2.png](/images/api/qiskit/0.46/qiskit-visualization-plot_state_qsphere-2.png) + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXDebugging.md b/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXDebugging.md new file mode 100644 index 00000000000..2928b54b7f0 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXDebugging.md @@ -0,0 +1,113 @@ +--- +title: IQXDebugging +description: API reference for qiskit.visualization.pulse.IQXDebugging +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.visualization.pulse.IQXDebugging +--- + +# IQXDebugging + + + +`qiskit.visualization.pulse.IQXDebugging(**kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/pulse_v2/stylesheet.py "view source code") + +Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +Pulse stylesheet for pulse programmers. Show details of instructions. + +\# TODO: add more generators + +* Generate stepwise waveform envelope with latex pulse names. +* Generate annotation for waveform height. +* Apply phase modulation to waveforms. +* Plot frame change symbol with raw operand values. +* Show chart name and channel frequency. +* Show snapshot and barrier. +* Show acquire channels. +* Channels are sorted by index and control channels are added to the end. + +## Methods + +### clear + + + +`clear() → None.  Remove all items from D.` + +### copy + + + +`copy() → a shallow copy of D` + +### fromkeys + + + +`fromkeys(value=None, /)` + +Create a new dictionary with keys from iterable and values set to value. + +### get + + + +`get(key, default=None, /)` + +Return the value for key if key is in the dictionary, else default. + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### pop + + + +`pop(k[, d]) → v, remove specified key and return the corresponding value.` + +If key is not found, default is returned if given, otherwise KeyError is raised + +### popitem + + + +`popitem()` + +Remove and return a (key, value) pair as a 2-tuple. + +Pairs are returned in LIFO (last-in, first-out) order. Raises KeyError if the dict is empty. + +### setdefault + + + +`setdefault(key, default=None, /)` + +Insert key with a value of default if key is not in the dictionary. + +Return the value for key if key is in the dictionary, else default. + +### update + + + +`update([E, ]**F) → None.  Update D from dict/iterable E and F.` + +If E is present and has a .keys() method, then does: for k in E: D\[k] = E\[k] If E is present and lacks a .keys() method, then does: for k, v in E: D\[k] = v In either case, this is followed by: for k in F: D\[k] = F\[k] + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXSimple.md b/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXSimple.md new file mode 100644 index 00000000000..8d15cb026c5 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXSimple.md @@ -0,0 +1,110 @@ +--- +title: IQXSimple +description: API reference for qiskit.visualization.pulse.IQXSimple +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.visualization.pulse.IQXSimple +--- + +# IQXSimple + + + +`qiskit.visualization.pulse.IQXSimple(**kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/pulse_v2/stylesheet.py "view source code") + +Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +Simple pulse stylesheet without channel notation. + +* Generate stepwise waveform envelope with latex pulse names. +* Apply phase modulation to waveforms. +* Do not show frame changes. +* Show chart name. +* Do not show snapshot and barrier. +* Do not show acquire channels. +* Channels are sorted by qubit index. + +## Methods + +### clear + + + +`clear() → None.  Remove all items from D.` + +### copy + + + +`copy() → a shallow copy of D` + +### fromkeys + + + +`fromkeys(value=None, /)` + +Create a new dictionary with keys from iterable and values set to value. + +### get + + + +`get(key, default=None, /)` + +Return the value for key if key is in the dictionary, else default. + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### pop + + + +`pop(k[, d]) → v, remove specified key and return the corresponding value.` + +If key is not found, default is returned if given, otherwise KeyError is raised + +### popitem + + + +`popitem()` + +Remove and return a (key, value) pair as a 2-tuple. + +Pairs are returned in LIFO (last-in, first-out) order. Raises KeyError if the dict is empty. + +### setdefault + + + +`setdefault(key, default=None, /)` + +Insert key with a value of default if key is not in the dictionary. + +Return the value for key if key is in the dictionary, else default. + +### update + + + +`update([E, ]**F) → None.  Update D from dict/iterable E and F.` + +If E is present and has a .keys() method, then does: for k in E: D\[k] = E\[k] If E is present and lacks a .keys() method, then does: for k, v in E: D\[k] = v In either case, this is followed by: for k in F: D\[k] = F\[k] + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXStandard.md b/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXStandard.md new file mode 100644 index 00000000000..23d0b0883bf --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.pulse.IQXStandard.md @@ -0,0 +1,110 @@ +--- +title: IQXStandard +description: API reference for qiskit.visualization.pulse.IQXStandard +in_page_toc_min_heading_level: 1 +python_api_type: class +python_api_name: qiskit.visualization.pulse.IQXStandard +--- + +# IQXStandard + + + +`qiskit.visualization.pulse.IQXStandard(**kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/pulse_v2/stylesheet.py "view source code") + +Bases: [`dict`](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +Standard pulse stylesheet. + +* Generate stepwise waveform envelope with latex pulse names. +* Apply phase modulation to waveforms. +* Plot frame change symbol with formatted operand values. +* Show chart name with scaling factor. +* Show snapshot and barrier. +* Do not show acquire channels. +* Channels are sorted by index and control channels are added to the end. + +## Methods + +### clear + + + +`clear() → None.  Remove all items from D.` + +### copy + + + +`copy() → a shallow copy of D` + +### fromkeys + + + +`fromkeys(value=None, /)` + +Create a new dictionary with keys from iterable and values set to value. + +### get + + + +`get(key, default=None, /)` + +Return the value for key if key is in the dictionary, else default. + +### items + + + +`items() → a set-like object providing a view on D's items` + +### keys + + + +`keys() → a set-like object providing a view on D's keys` + +### pop + + + +`pop(k[, d]) → v, remove specified key and return the corresponding value.` + +If key is not found, default is returned if given, otherwise KeyError is raised + +### popitem + + + +`popitem()` + +Remove and return a (key, value) pair as a 2-tuple. + +Pairs are returned in LIFO (last-in, first-out) order. Raises KeyError if the dict is empty. + +### setdefault + + + +`setdefault(key, default=None, /)` + +Insert key with a value of default if key is not in the dictionary. + +Return the value for key if key is in the dictionary, else default. + +### update + + + +`update([E, ]**F) → None.  Update D from dict/iterable E and F.` + +If E is present and has a .keys() method, then does: for k in E: D\[k] = E\[k] If E is present and lacks a .keys() method, then does: for k, v in E: D\[k] = v In either case, this is followed by: for k in F: D\[k] = F\[k] + +### values + + + +`values() → an object providing a view on D's values` + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.pulse_drawer.md b/docs/api/qiskit/0.46/qiskit.visualization.pulse_drawer.md new file mode 100644 index 00000000000..65cdb11761c --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.pulse_drawer.md @@ -0,0 +1,323 @@ +--- +title: pulse_drawer +description: API reference for qiskit.visualization.pulse_drawer +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.pulse_drawer +--- + + + +# qiskit.visualization.pulse\_drawer + + + +`qiskit.visualization.pulse_drawer(program, style=None, backend=None, time_range=None, time_unit='dt', disable_channels=None, show_snapshot=True, show_framechange=True, show_waveform_info=True, show_barrier=True, plotter='mpl2d', axis=None)` + +Generate visualization data for pulse programs. + +**Parameters** + +* **program** ([*Waveform*](qiskit.pulse.library.Waveform "qiskit.pulse.library.waveform.Waveform") *|*[*ParametricPulse*](qiskit.pulse.library.ParametricPulse "qiskit.pulse.library.parametric_pulses.ParametricPulse") *|*[*SymbolicPulse*](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.symbolic_pulses.SymbolicPulse") *|*[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")) – Program to visualize. This program can be arbitrary Qiskit Pulse program, such as `Waveform`, `ParametricPulse`, `SymbolicPulse`, [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule") and [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"). + +* **style** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Stylesheet options. This can be dictionary or preset stylesheet classes. See `IQXStandard`, `IQXSimple`, and `IQXDebugging` for details of preset stylesheets. See also the stylesheet section for details of configuration keys. + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.backend.Backend") *| None*) – Backend object to play the input pulse program. If provided, the plotter may use to make the visualization hardware aware. + +* **time\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Set horizontal axis limit. Tuple `(tmin, tmax)`. + +* **time\_unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unit of specified time range either `dt` or `ns`. The unit of `ns` is available only when `backend` object is provided. + +* **disable\_channels** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*Channel*](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel")*] | None*) – A control property to show specific pulse channel. Pulse channel instances provided as a list is not shown in the output image. + +* **show\_snapshot** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show snapshot instructions. + +* **show\_framechange** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show frame change instructions. The frame change represents instructions that modulate phase or frequency of pulse channels. + +* **show\_waveform\_info** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show waveform annotations, i.e. name, of waveforms. Set `True` to show additional information about waveforms. + +* **show\_barrier** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Show barrier lines. + +* **plotter** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – + + Name of plotter API to generate an output image. One of following APIs should be specified: + + ```python + mpl2d: Matplotlib API for 2D image generation. + Matplotlib API to generate 2D image. Charts are placed along y axis with + vertical offset. This API takes matplotlib.axes.Axes as `axis` input. + ``` + + axis and style kwargs may depend on the plotter. + +* **axis** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") *| None*) – Arbitrary object passed to the plotter. If this object is provided, the plotters use a given `axis` instead of internally initializing a figure object. This object format depends on the plotter. See plotter argument for details. + +**Returns** + +Visualization output data. The returned data type depends on the plotter. If matplotlib family is specified, this will be a matplotlib.pyplot.Figure data. The returned data is generated by the `get_image()` method of the specified plotter API. + +**Style Dict Details** + +The stylesheet kwarg contains numerous options that define the style of the output pulse visualization. The stylesheet options can be classified into formatter, generator and layout. Those options available in the stylesheet are defined below: + +**Parameters** + +* **formatter.general.fig\_width** – Width of output image (default 13). + +* **formatter.general.fig\_chart\_height** – Height of output image per chart. The height of each chart is multiplied with this factor and the sum of all chart heights becomes the height of output image (default 1.5). + +* **formatter.general.vertical\_resolution** – Vertical resolution of the pulse envelope. The change of data points below this limit is ignored (default 1e-6). + +* **formatter.general.max\_scale** – Maximum scaling factor of each chart. This factor is considered when chart auto-scaling is enabled (default 100). + +* **formatter.color.waveforms** – + + A dictionary of the waveform colors to use for each element type in the output visualization. The default values are: + + ```python + { + 'W': `['#648fff', '#002999']`, + 'D': `['#648fff', '#002999']`, + 'U': `['#ffb000', '#994A00']`, + 'M': `['#dc267f', '#760019']`, + 'A': `['#dc267f', '#760019']` + } + ``` + +* **formatter.color.baseline** – Color code of lines of zero line of each chart (default ‘#000000’). + +* **formatter.color.barrier** – Color code of lines of barrier (default ‘#222222’). + +* **formatter.color.background** – Color code of the face color of canvas (default ‘#f2f3f4’). + +* **formatter.color.fig\_title** – Color code of the figure title text (default ‘#000000’). + +* **formatter.color.annotate** – Color code of annotation texts in the canvas (default ‘#222222’). + +* **formatter.color.frame\_change** – Color code of the symbol for frame changes (default ‘#000000’). + +* **formatter.color.snapshot** – Color code of the symbol for snapshot (default ‘#000000’) + +* **formatter.color.opaque\_shape** – Color code of the face and edge of opaque shape box (default \[‘#fffacd’, ‘#000000’]) + +* **formatter.color.axis\_label** – Color code of axis labels (default ‘#000000’). + +* **formatter.alpha.fill\_waveform** – Transparency of waveforms. A value in the range from 0 to 1. The value 0 gives completely transparent waveforms (default 0.3). + +* **formatter.alpha.baseline** – Transparency of base lines. A value in the range from 0 to 1. The value 0 gives completely transparent base lines (default 1.0). + +* **formatter.alpha.barrier** – Transparency of barrier lines. A value in the range from 0 to 1. The value 0 gives completely transparent barrier lines (default 0.7). + +* **formatter.alpha.opaque\_shape** – Transparency of opaque shape box. A value in the range from 0 to 1. The value 0 gives completely transparent barrier lines (default 0.7). + +* **formatter.layer.fill\_waveform** – Layer index of waveforms. Larger number comes in the front of the output image (default 2). + +* **formatter.layer.baseline** – Layer index of baselines. Larger number comes in the front of the output image (default 1). + +* **formatter.layer.barrier** – Layer index of barrier lines. Larger number comes in the front of the output image (default 1). + +* **formatter.layer.annotate** – Layer index of annotations. Larger number comes in the front of the output image (default 5). + +* **formatter.layer.axis\_label** – Layer index of axis labels. Larger number comes in the front of the output image (default 5). + +* **formatter.layer.frame\_change** – Layer index of frame change symbols. Larger number comes in the front of the output image (default 4). + +* **formatter.layer.snapshot** – Layer index of snapshot symbols. Larger number comes in the front of the output image (default 3). + +* **formatter.layer.fig\_title** – Layer index of the figure title. Larger number comes in the front of the output image (default 6). + +* **formatter.margin.top** – Margin from the top boundary of the figure canvas to the surface of the first chart (default 0.5). + +* **formatter.margin.bottom** – Margin from the bottom boundary of the figure canvas to the surface of the last chart (default 0.5). + +* **formatter.margin.left\_percent** – Margin from the left boundary of the figure canvas to the zero point of the horizontal axis. The value is in units of percentage of the whole program duration. If the duration is 100 and the value of 0.5 is set, this keeps left margin of 5 (default 0.05). + +* **formatter.margin.right\_percent** – Margin from the right boundary of the figure canvas to the left limit of the horizontal axis. The value is in units of percentage of the whole program duration. If the duration is 100 and the value of 0.5 is set, this keeps right margin of 5 (default 0.05). + +* **formatter.margin.between\_channel** – Vertical margin between charts (default 0.2). + +* **formatter.label\_offset.pulse\_name** – Offset of pulse name annotations from the chart baseline (default 0.3). + +* **formatter.label\_offset.chart\_info** – Offset of chart info annotations from the chart baseline (default 0.3). + +* **formatter.label\_offset.frame\_change** – Offset of frame change annotations from the chart baseline (default 0.3). + +* **formatter.label\_offset.snapshot** – Offset of snapshot annotations from the chart baseline (default 0.3). + +* **formatter.text\_size.axis\_label** – Text size of axis labels (default 15). + +* **formatter.text\_size.annotate** – Text size of annotations (default 12). + +* **formatter.text\_size.frame\_change** – Text size of frame change symbols (default 20). + +* **formatter.text\_size.snapshot** – Text size of snapshot symbols (default 20). + +* **formatter.text\_size.fig\_title** – Text size of the figure title (default 15). + +* **formatter.text\_size.axis\_break\_symbol** – Text size of axis break symbols (default 15). + +* **formatter.line\_width.fill\_waveform** – Line width of the fringe of filled waveforms (default 0). + +* **formatter.line\_width.axis\_break** – Line width of axis breaks. The axis break line paints over other drawings with the background face color (default 6). + +* **formatter.line\_width.baseline** – Line width of base lines (default 1) + +* **formatter.line\_width.barrier** – Line width of barrier lines (default 1). + +* **formatter.line\_width.opaque\_shape** – Line width of opaque shape box (default 1). + +* **formatter.line\_style.fill\_waveform** – Line style of the fringe of filled waveforms. This conforms to the line style spec of matplotlib (default ‘-’). + +* **formatter.line\_style.baseline** – Line style of base lines. This conforms to the line style spec of matplotlib (default ‘-’). + +* **formatter.line\_style.barrier** – Line style of barrier lines. This conforms to the line style spec of matplotlib (default ‘:’). + +* **formatter.line\_style.opaque\_shape** – Line style of opaque shape box. This conforms to the line style spec of matplotlib (default ‘–’). + +* **formatter.channel\_scaling.drive** – Default scaling value of drive channel waveforms (default 1.0). + +* **formatter.channel\_scaling.control** – Default scaling value of control channel waveforms (default 1.0). + +* **formatter.channel\_scaling.measure** – Default scaling value of measure channel waveforms (default 1.0). + +* **formatter.channel\_scaling.acquire** – Default scaling value of acquire channel waveforms (default 1.0). + +* **formatter.channel\_scaling.pos\_spacing** – Minimum height of chart above the baseline. Chart top is determined based on the maximum height of waveforms associated with the chart. If the maximum height is below this value, this value is set as the chart top (default 0.1). + +* **formatter.channel\_scaling.neg\_spacing** – Minimum height of chart below the baseline. Chart bottom is determined based on the minimum height of waveforms associated with the chart. If the minimum height is above this value, this value is set as the chart bottom (default -0.1). + +* **formatter.box\_width.opaque\_shape** – Default box length of the waveform representation when the instruction is parameterized and duration is not bound or not defined. Value is units in dt (default: 150). + +* **formatter.box\_height.opaque\_shape** – Default box height of the waveform representation when the instruction is parameterized (default: 0.4). + +* **formatter.axis\_break.length** – Waveform or idle time duration that axis break is applied. Intervals longer than this value are truncated. The value is in units of data points (default 3000). + +* **formatter.axis\_break.max\_length** – Length of new waveform or idle time duration after axis break is applied. Longer intervals are truncated to this length (default 1000). + +* **formatter.control.fill\_waveform** – Set True to fill waveforms with face color (default True). When you disable this option, you should set finite line width to formatter.line\_width.fill\_waveform, otherwise nothing will appear in the graph. + +* **formatter.control.apply\_phase\_modulation** – Set True to apply phase modulation to the waveforms (default True). + +* **formatter.control.show\_snapshot\_channel** – Set True to show snapshot instructions (default True). + +* **formatter.control.show\_acquire\_channel** – Set True to show acquire channels (default True). + +* **formatter.control.show\_empty\_channel** – Set True to show charts without any waveforms (default True). + +* **formatter.control.auto\_chart\_scaling** – Set True to apply auto-scaling to charts (default True). + +* **formatter.control.axis\_break** – Set True to apply axis break for long intervals (default True). + +* **formatter.unicode\_symbol.frame\_change** – Text that represents the symbol of frame change. This text is used when the plotter doesn’t support latex (default u’↺’). + +* **formatter.unicode\_symbol.snapshot** – Text that represents the symbol of snapshot. This text is used when the plotter doesn’t support latex (default u’↯’). + +* **formatter.unicode\_symbol.phase\_parameter** – Text that represents the symbol of parameterized phase value. This text is used when the plotter doesn’t support latex (default u’θ’). + +* **formatter.unicode\_symbol.freq\_parameter** – Text that represents the symbol of parameterized frequency value. This text is used when the plotter doesn’t support latex (default ‘f’). + +* **formatter.latex\_symbol.frame\_change** – Latex text that represents the symbol of frame change (default r’circlearrowleft’). + +* **formatter.latex\_symbol.snapshot** – Latex text that represents the symbol of snapshot (default ‘’). + +* **formatter.latex\_symbol.phase\_parameter** – Latex text that represents the symbol of parameterized phase value (default r’ heta’). + +* **formatter.latex\_symbol.freq\_parameter** – Latex text that represents the symbol of parameterized frequency value (default ‘f’). + +* **generator.waveform** – List of callback functions that generates drawing for waveforms. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the pulse drawer. See `waveform` for more details. No default generator is set. + +* **generator.frame** – List of callback functions that generates drawing for frame changes. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the pulse drawer. See `frame` for more details. No default generator is set. + +* **generator.chart** – List of callback functions that generates drawing for charts. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the pulse drawer. See `chart` for more details. No default generator is set. + +* **generator.snapshot** – List of callback functions that generates drawing for snapshots. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the pulse drawer. See `snapshot` for more details. No default generator is set. + +* **generator.barrier** – List of callback functions that generates drawing for barriers. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the pulse drawer. See `barrier` for more details. No default generator is set. + +* **layout.chart\_channel\_map** – Callback function that determines the relationship between pulse channels and charts. See `layout` for more details. No default layout is set. + +* **layout.time\_axis\_map** – Callback function that determines the layout of horizontal axis labels. See `layout` for more details. No default layout is set. + +* **layout.figure\_title** – Callback function that generates a string for the figure title. See `layout` for more details. No default layout is set. + +**Examples** + +To visualize a pulse program, you can call this function with set of control arguments. Most of appearance of the output image can be controlled by the stylesheet. + +Drawing with the default stylesheet. + +```python +from qiskit import QuantumCircuit, transpile, schedule +from qiskit.visualization.pulse_v2 import draw +from qiskit.providers.fake_provider import FakeBoeblingen + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) +qc.measure_all() +qc = transpile(qc, FakeBoeblingen(), layout_method='trivial') +sched = schedule(qc, FakeBoeblingen()) + +draw(sched, backend=FakeBoeblingen()) +``` + +![../\_images/qiskit-visualization-pulse\_drawer-1.png](/images/api/qiskit/0.46/qiskit-visualization-pulse_drawer-1.png) + +Drawing with the stylesheet suited for publication. + +```python +from qiskit import QuantumCircuit, transpile, schedule +from qiskit.visualization.pulse_v2 import draw, IQXSimple +from qiskit.providers.fake_provider import FakeBoeblingen + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) +qc.measure_all() +qc = transpile(qc, FakeBoeblingen(), layout_method='trivial') +sched = schedule(qc, FakeBoeblingen()) + +draw(sched, style=IQXSimple(), backend=FakeBoeblingen()) +``` + +![../\_images/qiskit-visualization-pulse\_drawer-2.png](/images/api/qiskit/0.46/qiskit-visualization-pulse_drawer-2.png) + +Drawing with the stylesheet suited for program debugging. + +```python +from qiskit import QuantumCircuit, transpile, schedule +from qiskit.visualization.pulse_v2 import draw, IQXDebugging +from qiskit.providers.fake_provider import FakeBoeblingen + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0, 1) +qc.measure_all() +qc = transpile(qc, FakeBoeblingen(), layout_method='trivial') +sched = schedule(qc, FakeBoeblingen()) + +draw(sched, style=IQXDebugging(), backend=FakeBoeblingen()) +``` + +![../\_images/qiskit-visualization-pulse\_drawer-3.png](/images/api/qiskit/0.46/qiskit-visualization-pulse_drawer-3.png) + +You can partially customize a preset stylesheet when initializing it. + +```python +my_style = { + 'formatter.channel_scaling.drive': 5, + 'formatter.channel_scaling.control': 1, + 'formatter.channel_scaling.measure': 5 +} +style = IQXStandard(**my_style) +# draw +draw(sched, style=style, backend=FakeBoeblingen()) +``` + +In the same way as above, you can create custom generator or layout functions and update the existing stylesheet with custom functions. This feature enables you to customize most of the appearance of the output image without modifying the codebase. + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – When required visualization package is not installed. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – When invalid plotter API or invalid time range is specified. + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.timeline_drawer.md b/docs/api/qiskit/0.46/qiskit.visualization.timeline_drawer.md new file mode 100644 index 00000000000..1800e433bb1 --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.timeline_drawer.md @@ -0,0 +1,321 @@ +--- +title: timeline_drawer +description: API reference for qiskit.visualization.timeline_drawer +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.timeline_drawer +--- + + + +# qiskit.visualization.timeline\_drawer + + + +`qiskit.visualization.timeline_drawer(program, style=None, time_range=None, disable_bits=None, show_clbits=None, show_idle=None, show_barriers=None, show_delays=None, show_labels=True, plotter='mpl', axis=None, filename=None)` + +Generate visualization data for scheduled circuit programs. + +**Parameters** + +* **program** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – Program to visualize. This program should be a QuantumCircuit which is transpiled with a scheduling\_method, thus containing gate time information. + +* **style** ([*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)")*] | None*) – Stylesheet options. This can be dictionary or preset stylesheet classes. See `IQXStandard`, `IQXSimple`, and `IQXDebugging` for details of preset stylesheets. See also the stylesheet section for details of configuration keys. + +* **time\_range** ([*Tuple*](https://docs.python.org/3/library/typing.html#typing.Tuple "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*,* [*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – Set horizontal axis limit. + +* **disable\_bits** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[Bits] | None*) – List of qubits of classical bits not shown in the output image. + +* **show\_clbits** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – A control property to show classical bits. Set True to show classical bits. + +* **show\_idle** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – A control property to show idle timeline. Set True to show timeline without gates. + +* **show\_barriers** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – A control property to show barrier instructions. Set True to show barrier instructions. + +* **show\_delays** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – A control property to show delay instructions. Set True to show delay instructions. + +* **show\_labels** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – A control property to show annotations, i.e. name, of gates. Set True to show annotations. + +* **plotter** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – + + Name of plotter API to generate an output image. One of following APIs should be specified: + + ```python + mpl: Matplotlib API + Matplotlib API to generate 2D image. Timelines are placed along y axis with + vertical offset. This API takes matplotlib.axes.Axes as `axis` input. + ``` + + axis and style kwargs may depend on the plotter. + +* **axis** ([*Any*](https://docs.python.org/3/library/typing.html#typing.Any "(in Python v3.12)") *| None*) – Arbitrary object passed to the plotter. If this object is provided, the plotters uses given axis instead of internally initializing a figure object. This object format depends on the plotter. See plotters section for details. + +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – If provided the output image is dumped into a file under the filename. + +**Returns** + +Visualization output data. + +The returned data type depends on the plotter. If matplotlib family is specified, this will be a matplotlib.pyplot.Figure data. The returned data is generated by the .get\_image method of the specified plotter API. + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – When required visualization package is not installed. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – When invalid plotter API is specified. + +**Style Dict Details** + +The stylesheet kwarg contains numerous options that define the style of the output timeline visualization. The stylesheet options can be classified into formatter, generator and layout. Those options available in the stylesheet are defined below: + +**Parameters** + +* **formatter.general.fig\_width** – Width of output image (default 14). + +* **formatter.general.fig\_unit\_height** – Height of output image per timeline. The sum of all timeline becomes the height of the output image (default 0.8). + +* **formatter.general.dpi** – Dot per inch of image if filename is set (default 150). + +* **formatter.margin.top** – Margin from the top boundary of the figure canvas to the zero line of the first time slot (default 0.5). + +* **formatter.margin.bottom** – Margin from the bottom boundary of the figure canvas to the zero lien of the last time slot (default 0.5). + +* **formatter.margin.left\_percent** – Margin from the left boundary of the figure canvas to the left limit of the horizontal axis. The value is in units of percentage of the whole program duration. If the duration is 100 and the value of 0.5 is set, this keeps left margin of 5 (default 0.02). + +* **formatter.margin.right\_percent** – Margin from the right boundary of the figure canvas to the right limit of the horizontal axis. The value is in units of percentage of the whole program duration. If the duration is 100 and the value of 0.5 is set, this keeps right margin of 5 (default 0.02). + +* **formatter.margin.link\_interval\_percent** – Allowed overlap of gate links. If multiple gate links are drawing within this range, links are horizontally shifted not to overlap with each other. The value is in units of percentage of the whole program duration (default 0.01). + +* **formatter.time\_bucket.edge\_dt** – The length of round edge of gate boxes. Gate boxes are smoothly faded in and out from the zero line. This value is in units of the system cycle time dt (default 10). + +* **formatter.margin.minimum\_duration** – Minimum scheduled circuit duration. If the duration of input circuit is below this value, horizontal limit is set based on this value. This value is in units of the system cycle time dt (default 50). + +* **formatter.color.background** – Color code of the face color of canvas (default #FFFFFF). + +* **formatter.color.timeslot** – Face color of the time slot box (default #DDDDDD). + +* **formatter.color.gate\_name** – Text color of the gate name annotations (default #000000). + +* **formatter.color.bit\_name** – Text color of the bit label annotations (default #000000). + +* **formatter.color.barrier** – Line color of barriers (default #222222). + +* **formatter.color.gates** – + + A dictionary of the gate box or gate symbol colors to use for each element type in the output visualization. The default values are: + + ```python + { + 'u0': '#FA74A6', + 'u1': '#000000', + 'u2': '#FA74A6', + 'u3': '#FA74A6', + 'id': '#05BAB6', + 'sx': '#FA74A6', + 'sxdg': '#FA74A6', + 'x': '#05BAB6', + 'y': '#05BAB6', + 'z': '#05BAB6', + 'h': '#6FA4FF', + 'cx': '#6FA4FF', + 'cy': '#6FA4FF', + 'cz': '#6FA4FF', + 'swap': '#6FA4FF', + 's': '#6FA4FF', + 'sdg': '#6FA4FF', + 'dcx': '#6FA4FF', + 'iswap': '#6FA4FF', + 't': '#BB8BFF', + 'tdg': '#BB8BFF', + 'r': '#BB8BFF', + 'rx': '#BB8BFF', + 'ry': '#BB8BFF', + 'rz': '#000000', + 'reset': '#808080', + 'measure': '#808080' + } + ``` + + You must specify all the necessary values if using this. If a gate name is not specified, the color in formatter.color.default\_gate is applied. + +* **formatter.color.default\_gate** – Default gate color. This color is applied when a gate name to visualize is not contained in the dictionary of formatter.color.gates (default #BB8BFF). + +* **formatter.latex\_symbol.gates** – + + A dictionary of latex representation of gate names to use for each element type in the output visualization. The default values are: + + ```python + { + 'u0': r'{\rm U}_0', + 'u1': r'{\rm U}_1', + 'u2': r'{\rm U}_2', + 'u3': r'{\rm U}_3', + 'id': r'{\rm Id}', + 'x': r'{\rm X}', + 'y': r'{\rm Y}', + 'z': r'{\rm Z}', + 'h': r'{\rm H}', + 'cx': r'{\rm CX}', + 'cy': r'{\rm CY}', + 'cz': r'{\rm CZ}', + 'swap': r'{\rm SWAP}', + 's': r'{\rm S}', + 'sdg': r'{\rm S}^\dagger', + 'sx': r'{\rm √X}', + 'sxdg': r'{\rm √X}^\dagger', + 'dcx': r'{\rm DCX}', + 'iswap': r'{\rm iSWAP}', + 't': r'{\rm T}', + 'tdg': r'{\rm T}^\dagger', + 'r': r'{\rm R}', + 'rx': r'{\rm R}_x', + 'ry': r'{\rm R}_y', + 'rz': r'{\rm R}_z', + 'reset': r'|0\rangle', + 'measure': r'{\rm Measure}' + } + ``` + + You must specify all the necessary values if using this. There is no provision for passing an incomplete dict in. + +* **formatter.latex\_symbol.frame\_change** – Latex representation of the frame change symbol (default r\`circlearrowleft\`). + +* **formatter.unicode\_symbol.frame\_change** – Unicode representation of the frame change symbol (default u’u21BA’). + +* **formatter.box\_height.gate** – Height of gate box (default 0.5). + +* **formatter.box\_height.timeslot** – Height of time slot (default 0.6). + +* **formatter.layer.gate** – Layer index of gate boxes. Larger number comes in the front of the output image (default 3). + +* **formatter.layer.timeslot** – Layer index of time slots. Larger number comes in the front of the output image (default 0). + +* **formatter.layer.gate\_name** – Layer index of gate name annotations. Larger number comes in the front of the output image (default 5). + +* **formatter.layer.bit\_name** – Layer index of bit labels. Larger number comes in the front of the output image (default 5). + +* **formatter.layer.frame\_change** – Layer index of frame change symbols. Larger number comes in the front of the output image (default 4). + +* **formatter.layer.barrier** – Layer index of barrier lines. Larger number comes in the front of the output image (default 1). + +* **formatter.layer.gate\_link** – Layer index of gate link lines. Larger number comes in the front of the output image (default 2). + +* **formatter.alpha.gate** – Transparency of gate boxes. A value in the range from 0 to 1. The value 0 gives completely transparent boxes (default 1.0). + +* **formatter.alpha.timeslot** – Transparency of time slots. A value in the range from 0 to 1. The value 0 gives completely transparent boxes (default 0.7). + +* **formatter.alpha.barrier** – Transparency of barrier lines. A value in the range from 0 to 1. The value 0 gives completely transparent lines (default 0.5). + +* **formatter.alpha.gate\_link** – Transparency of gate link lines. A value in the range from 0 to 1. The value 0 gives completely transparent lines (default 0.8). + +* **formatter.line\_width.gate** – Line width of the fringe of gate boxes (default 0). + +* **formatter.line\_width.timeslot** – Line width of the fringe of time slots (default 0). + +* **formatter.line\_width.barrier** – Line width of barrier lines (default 3). + +* **formatter.line\_width.gate\_link** – Line width of gate links (default 3). + +* **formatter.line\_style.barrier** – Line style of barrier lines. This conforms to the line style spec of matplotlib (default ‘-’). + +* **formatter.line\_style.gate\_link** – Line style of gate link lines. This conforms to the line style spec of matplotlib (default ‘-’). + +* **formatter.text\_size.gate\_name** – Text size of gate name annotations (default 12). + +* **formatter.text\_size.bit\_name** – Text size of bit labels (default 15). + +* **formatter.text\_size.frame\_change** – Text size of frame change symbols (default 18). + +* **formatter.text\_size.axis\_label** – Text size of axis labels (default 13). + +* **formatter.label\_offset.frame\_change** – Offset of zero duration gate name annotations from the zero line of time slot (default 0.25). + +* **formatter.control.show\_idle** – Set True to show time slots without gate (default True). + +* **formatter.control.show\_clbits** – Set True to show time slots of classical bits (default True). + +* **formatter.control.show\_barriers** – Set True to show barriers (default True). + +* **formatter.control.show\_delays** – Set True to show delay boxes (default True). + +* **generator.gates** – List of callback functions that generates drawings for gates. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the timeline drawer. See `generators` for more details. No default generator is set (default \[]). + +* **generator.bits** – List of callback functions that generates drawings for bit labels and time slots. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the timeline drawer. See `generators` for more details. No default generator is set (default \[]). + +* **generator.barriers** – List of callback functions that generates drawings for barriers. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the timeline drawer. See `generators` for more details. No default generator is set (default \[]). + +* **generator.gate\_links** – List of callback functions that generates drawings for gate links. Arbitrary callback functions satisfying the generator format can be set here. There are some default generators in the timeline drawer. See `generators` for more details. No default generator is set (default \[]). + +* **layout.bit\_arrange** – Callback function that sorts bits. See `layouts` for more details. No default layout is set. (default None). + +* **layout.time\_axis\_map** – Callback function that determines the layout of horizontal axis labels. See `layouts` for more details. No default layout is set. (default None). + +**Examples** + +To visualize a scheduled circuit program, you can call this function with set of control arguments. Most of appearance of the output image can be controlled by the stylesheet. + +Drawing with the default stylesheet. + +```python +from qiskit import QuantumCircuit, transpile, schedule +from qiskit.visualization.timeline import draw +from qiskit.providers.fake_provider import FakeBoeblingen + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0,1) + +qc = transpile(qc, FakeBoeblingen(), scheduling_method='alap', layout_method='trivial') +draw(qc) +``` + +![../\_images/qiskit-visualization-timeline\_drawer-1.png](/images/api/qiskit/0.46/qiskit-visualization-timeline_drawer-1.png) + +Drawing with the simple stylesheet. + +```python +from qiskit import QuantumCircuit, transpile, schedule +from qiskit.visualization.timeline import draw, IQXSimple +from qiskit.providers.fake_provider import FakeBoeblingen + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0,1) + +qc = transpile(qc, FakeBoeblingen(), scheduling_method='alap', layout_method='trivial') +draw(qc, style=IQXSimple()) +``` + +![../\_images/qiskit-visualization-timeline\_drawer-2.png](/images/api/qiskit/0.46/qiskit-visualization-timeline_drawer-2.png) + +Drawing with the stylesheet suited for program debugging. + +```python +from qiskit import QuantumCircuit, transpile, schedule +from qiskit.visualization.timeline import draw, IQXDebugging +from qiskit.providers.fake_provider import FakeBoeblingen + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0,1) + +qc = transpile(qc, FakeBoeblingen(), scheduling_method='alap', layout_method='trivial') +draw(qc, style=IQXDebugging()) +``` + +![../\_images/qiskit-visualization-timeline\_drawer-3.png](/images/api/qiskit/0.46/qiskit-visualization-timeline_drawer-3.png) + +You can partially customize a preset stylesheet when call it: + +```python +my_style = { + 'formatter.general.fig_width': 16, + 'formatter.general.fig_unit_height': 1 +} +style = IQXStandard(**my_style) + +# draw +draw(qc, style=style) +``` + +In the same way as above, you can create custom generator or layout functions and update existing stylesheet with custom functions. This feature enables you to control the most of appearance of the output image without modifying the codebase of the scheduled circuit drawer. + diff --git a/docs/api/qiskit/0.46/qiskit.visualization.visualize_transition.md b/docs/api/qiskit/0.46/qiskit.visualization.visualize_transition.md new file mode 100644 index 00000000000..c3746ef468d --- /dev/null +++ b/docs/api/qiskit/0.46/qiskit.visualization.visualize_transition.md @@ -0,0 +1,39 @@ +--- +title: visualize_transition +description: API reference for qiskit.visualization.visualize_transition +in_page_toc_min_heading_level: 1 +python_api_type: function +python_api_name: qiskit.visualization.visualize_transition +--- + + + +# qiskit.visualization.visualize\_transition + + + +`qiskit.visualization.visualize_transition(circuit, trace=False, saveas=None, fpg=100, spg=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/transition_visualization.py "view source code") + +Creates animation showing transitions between states of a single qubit by applying quantum gates. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")) – Qiskit single-qubit QuantumCircuit. Gates supported are h,x, y, z, rx, ry, rz, s, sdg, t, tdg and u1. +* **trace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Controls whether to display tracing vectors - history of 10 past vectors at each step of the animation. +* **saveas** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – User can choose to save the animation as a video to their filesystem. This argument is a string of path with filename and extension (e.g. “movie.mp4” to save the video in current working directory). +* **fpg** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Frames per gate. Finer control over animation smoothness and computational needs to render the animation. Works well for tkinter GUI as it is, for jupyter GUI it might be preferable to choose fpg between 5-30. +* **spg** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Seconds per gate. How many seconds should animation of individual gate transitions take. + +**Returns** + +If arg jupyter is set to True. Otherwise opens tkinter GUI and returns after the GUI is closed. + +**Return type** + +IPython.core.display.HTML + +**Raises** + +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – Must have Matplotlib (and/or IPython) installed. +* [**VisualizationError**](visualization#qiskit.visualization.VisualizationError "qiskit.visualization.VisualizationError") – Given gate(s) are not supported. + diff --git a/docs/api/qiskit/0.46/qobj.md b/docs/api/qiskit/0.46/qobj.md new file mode 100644 index 00000000000..8f12c528eb2 --- /dev/null +++ b/docs/api/qiskit/0.46/qobj.md @@ -0,0 +1,51 @@ +--- +title: qobj +description: API reference for qiskit.qobj +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.qobj +--- + + + + + + + +# Qobj + + + +`qiskit.qobj` + +## Base + +| | | +| --------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------- | +| [`QobjExperimentHeader`](qiskit.qobj.QobjExperimentHeader "qiskit.qobj.QobjExperimentHeader")(\*\*kwargs) | A class representing a header dictionary for a Qobj Experiment. | +| [`QobjHeader`](qiskit.qobj.QobjHeader "qiskit.qobj.QobjHeader")(\*\*kwargs) | A class used to represent a dictionary header in Qobj objects. | + +## Qasm + +| | | +| ------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------- | +| [`QasmQobj`](qiskit.qobj.QasmQobj "qiskit.qobj.QasmQobj")(\[qobj\_id, config, experiments, header]) | An OpenQASM 2 Qobj. | +| [`QasmQobjInstruction`](qiskit.qobj.QasmQobjInstruction "qiskit.qobj.QasmQobjInstruction")(name\[, params, qubits, ...]) | A class representing a single instruction in an QasmQobj Experiment. | +| [`QasmQobjExperimentConfig`](qiskit.qobj.QasmQobjExperimentConfig "qiskit.qobj.QasmQobjExperimentConfig")(\[calibrations, ...]) | Configuration for a single OpenQASM 2 experiment in the qobj. | +| [`QasmQobjExperiment`](qiskit.qobj.QasmQobjExperiment "qiskit.qobj.QasmQobjExperiment")(\[config, header, ...]) | An OpenQASM 2 Qobj Experiment. | +| [`QasmQobjConfig`](qiskit.qobj.QasmQobjConfig "qiskit.qobj.QasmQobjConfig")(\[shots, seed\_simulator, ...]) | A configuration for an OpenQASM 2 Qobj. | +| [`QasmExperimentCalibrations`](qiskit.qobj.QasmExperimentCalibrations "qiskit.qobj.QasmExperimentCalibrations")(gates) | A container for any calibrations data. | +| [`GateCalibration`](qiskit.qobj.GateCalibration "qiskit.qobj.GateCalibration")(name, qubits, params, ...) | Each calibration specifies a unique gate by name, qubits and params, and contains the Pulse instructions to implement it. | + +## Pulse + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------- | +| [`PulseQobj`](qiskit.qobj.PulseQobj "qiskit.qobj.PulseQobj")(qobj\_id, config, experiments\[, header]) | A Pulse Qobj. | +| [`PulseQobjInstruction`](qiskit.qobj.PulseQobjInstruction "qiskit.qobj.PulseQobjInstruction")(name, t0\[, ch, ...]) | A class representing a single instruction in an PulseQobj Experiment. | +| [`PulseQobjExperimentConfig`](qiskit.qobj.PulseQobjExperimentConfig "qiskit.qobj.PulseQobjExperimentConfig")(\[qubit\_lo\_freq, ...]) | A config for a single Pulse experiment in the qobj. | +| [`PulseQobjExperiment`](qiskit.qobj.PulseQobjExperiment "qiskit.qobj.PulseQobjExperiment")(instructions\[, config, ...]) | A Pulse Qobj Experiment. | +| [`PulseQobjConfig`](qiskit.qobj.PulseQobjConfig "qiskit.qobj.PulseQobjConfig")(meas\_level, meas\_return, ...) | A configuration for a Pulse Qobj. | +| [`QobjMeasurementOption`](qiskit.qobj.QobjMeasurementOption "qiskit.qobj.QobjMeasurementOption")(name\[, params]) | An individual measurement option. | +| [`PulseLibraryItem`](qiskit.qobj.PulseLibraryItem "qiskit.qobj.PulseLibraryItem")(name, samples) | An item in a pulse library. | + diff --git a/docs/api/qiskit/0.46/qpy.md b/docs/api/qiskit/0.46/qpy.md new file mode 100644 index 00000000000..066b775c41c --- /dev/null +++ b/docs/api/qiskit/0.46/qpy.md @@ -0,0 +1,1088 @@ +--- +title: qpy +description: API reference for qiskit.qpy +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.qpy +--- + + + + + + + +# QPY serialization + + + +`qiskit.qpy` + +QPY is a binary serialization format for [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") objects that is designed to be cross-platform, Python version agnostic, and backwards compatible moving forward. QPY should be used if you need a mechanism to save or copy between systems a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") or [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") that preserves the full Qiskit object structure (except for custom attributes defined outside of Qiskit code). This differs from other serialization formats like [OpenQASM](https://github.com/openqasm/openqasm) (2.0 or 3.0) which has a different abstraction model and can result in a loss of information contained in the original circuit (or is unable to represent some aspects of the Qiskit objects) or Python’s [pickle](https://docs.python.org/3/library/pickle.html) which will preserve the Qiskit object exactly but will only work for a single Qiskit version (it is also [potentially insecure](https://docs.python.org/3/library/pickle.html#module-pickle)). + +## Using QPY + +Using QPY is defined to be straightforward and mirror the user API of the serializers in Python’s standard library, `pickle` and `json`. There are 2 user facing functions: [`qiskit.qpy.dump()`](#qiskit.qpy.dump "qiskit.qpy.dump") and [`qiskit.qpy.load()`](#qiskit.qpy.load "qiskit.qpy.load") which are used to dump QPY data to a file object and load circuits from QPY data in a file object respectively. For example: + +```python +from qiskit.circuit import QuantumCircuit +from qiskit import qpy + +qc = QuantumCircuit(2, name='Bell', metadata={'test': True}) +qc.h(0) +qc.cx(0, 1) +qc.measure_all() + +with open('bell.qpy', 'wb') as fd: + qpy.dump(qc, fd) + +with open('bell.qpy', 'rb') as fd: + new_qc = qpy.load(fd)[0] +``` + +The [`qiskit.qpy.dump()`](#qiskit.qpy.dump "qiskit.qpy.dump") function also lets you include multiple circuits in a single QPY file: + +```python +with open('twenty_bells.qpy', 'wb') as fd: + qpy.dump([qc] * 20, fd) +``` + +and then loading that file will return a list with all the circuits + +> **with open(‘twenty\_bells.qpy’, ‘rb’) as fd:** +> +> twenty\_new\_bells = qpy.load(fd) + +### API documentation + +### load + + + +`qiskit.qpy.load(file_obj, metadata_deserializer=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qpy/interface.py "view source code") + +Load a QPY binary file + +This function is used to load a serialized QPY Qiskit program file and create [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects or [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") objects from its contents. For example: + +```python +from qiskit import qpy + +with open('bell.qpy', 'rb') as fd: + circuits = qpy.load(fd) +``` + +or with a gzip compressed file: + +```python +import gzip +from qiskit import qpy + +with gzip.open('bell.qpy.gz', 'rb') as fd: + circuits = qpy.load(fd) +``` + +which will read the contents of the qpy and return a list of [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects or [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock") objects from the file. + +**Parameters** + +* **file\_obj** ([*BinaryIO*](https://docs.python.org/3/library/typing.html#typing.BinaryIO "(in Python v3.12)")) – A file like object that contains the QPY binary data for a circuit or pulse schedule. +* **metadata\_deserializer** ([*Type*](https://docs.python.org/3/library/typing.html#typing.Type "(in Python v3.12)")*\[JSONDecoder] | None*) – An optional JSONDecoder class that will be used for the `cls` kwarg on the internal `json.load` call used to deserialize the JSON payload used for the `.metadata` attribute for any programs in the QPY file. If this is not specified the circuit metadata will be parsed as JSON with the stdlib `json.load()` function using the default `JSONDecoder` class. + +**Returns** + +The list of Qiskit programs contained in the QPY data. A list is always returned, even if there is only 1 program in the QPY data. + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if `file_obj` is not a valid QPY file +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – When invalid data type is loaded. + +**Return type** + +[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")\[[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") | [*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")] + +### dump + + + +`qiskit.qpy.dump(programs, file_obj, metadata_serializer=None, use_symengine=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qpy/interface.py "view source code") + +Write QPY binary data to a file + +This function is used to save a circuit to a file for later use or transfer between machines. The QPY format is backwards compatible and can be loaded with future versions of Qiskit. + +For example: + +```python +from qiskit.circuit import QuantumCircuit +from qiskit import qpy + +qc = QuantumCircuit(2, name='Bell', metadata={'test': True}) +qc.h(0) +qc.cx(0, 1) +qc.measure_all() +``` + +from this you can write the qpy data to a file: + +```python +with open('bell.qpy', 'wb') as fd: + qpy.dump(qc, fd) +``` + +or a gzip compressed file: + +```python +import gzip + +with gzip.open('bell.qpy.gz', 'wb') as fd: + qpy.dump(qc, fd) +``` + +Which will save the qpy serialized circuit to the provided file. + +**Parameters** + +* **programs** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")*] |* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit") *|*[*ScheduleBlock*](qiskit.pulse.ScheduleBlock "qiskit.pulse.schedule.ScheduleBlock")) – QPY supported object(s) to store in the specified file like object. QPY supports [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock"). Different data types must be separately serialized. +* **file\_obj** ([*BinaryIO*](https://docs.python.org/3/library/typing.html#typing.BinaryIO "(in Python v3.12)")) – The file like object to write the QPY data too +* **metadata\_serializer** ([*Type*](https://docs.python.org/3/library/typing.html#typing.Type "(in Python v3.12)")*\[JSONEncoder] | None*) – An optional JSONEncoder class that will be passed the `.metadata` attribute for each program in `programs` and will be used as the `cls` kwarg on the json.dump()\` call to JSON serialize that dictionary. +* **use\_symengine** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, all objects containing symbolic expressions will be serialized using symengine’s native mechanism. This is a faster serialization alternative, but not supported in all platforms. Please check that your target platform is supported by the symengine library before setting this option, as it will be required by qpy to deserialize the payload. For this reason, the option defaults to False. + +**Raises** + +* [**QpyError**](#qiskit.qpy.QpyError "qiskit.qpy.QpyError") – When multiple data format is mixed in the output. +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – When invalid data type is input. + +These functions will raise a custom subclass of [`QiskitError`](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") if they encounter problems during serialization or deserialization. + +### QpyError + + + +`qiskit.qpy.QpyError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/qpy/exceptions.py "view source code") + +Errors raised by the qpy module. + +Set the error message. + +### QPY Compatibility + +The QPY format is designed to be backwards compatible moving forward. This means you should be able to load a QPY with any newer Qiskit version than the one that generated it. However, loading a QPY file with an older Qiskit version is not supported and may not work. + +For example, if you generated a QPY file using qiskit-terra 0.18.1 you could load that QPY file with qiskit-terra 0.19.0 and a hypothetical qiskit-terra 0.29.0. However, loading that QPY file with 0.18.0 is not supported and may not work. + + + +## QPY Format + +The QPY serialization format is a portable cross-platform binary serialization format for [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") objects in Qiskit. The basic file format is as follows: + +A QPY file (or memory object) always starts with the following 6 byte UTF8 string: `QISKIT` which is immediately followed by the overall file header. The contents of the file header as defined as a C struct are: + +```python +struct { + uint8_t qpy_version; + uint8_t qiskit_major_version; + uint8_t qiskit_minor_version; + uint8_t qiskit_patch_version; + uint64_t num_circuits; +} +``` + +From V10 on, a new field is added to the file header struct to represent the encoding scheme used for symbolic expressions: + +```python +struct { + uint8_t qpy_version; + uint8_t qiskit_major_version; + uint8_t qiskit_minor_version; + uint8_t qiskit_patch_version; + uint64_t num_circuits; + char symbolic_encoding; +} +``` + +All values use network byte order [\[1\]](#f1) (big endian) for cross platform compatibility. + +The file header is immediately followed by the circuit payloads. Each individual circuit is composed of the following parts: + +`HEADER | METADATA | REGISTERS | CUSTOM_DEFINITIONS | INSTRUCTIONS` + +There is a circuit payload for each circuit (where the total number is dictated by `num_circuits` in the file header). There is no padding between the circuits in the data. + + + +### Version 10 + +Version 10 adds support for symengine-native serialization for objects of type [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") as well as symbolic expressions in Pulse schedule blocks. Version 10 also adds support for new fields in the [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") class added in the Qiskit 0.45.0 release. + +The symbolic\_encoding field is added to the file header, and a new encoding type char is introduced, mapped to each symbolic library as follows: `p` refers to sympy encoding and `e` refers to symengine encoding. + + + +#### FILE\_HEADER + +The contents of FILE\_HEADER after V10 are defined as a C struct as: + +```python +struct { + uint8_t qpy_version; + uint8_t qiskit_major_version; + uint8_t qiskit_minor_version; + uint8_t qiskit_patch_version; + uint64_t num_circuits; + char symbolic_encoding; +} +``` + +#### LAYOUT + +The `LAYOUT` struct is updated to have an additional `input_qubit_count` field. With version 10 the `LAYOUT` struct is now: + +```python +struct { + char exists; + int32_t initial_layout_size; + int32_t input_mapping_size; + int32_t final_layout_size; + uint32_t extra_registers; + int32_t input_qubit_count; +} +``` + +The rest of the layout data after the `LAYOUT` struct is represented as in previous versions. If `input qubit_count` is \< 0 that indicates that both `_input_qubit_count` and `_output_qubit_list` in the [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") object are `None`. + + + +### Version 9 + +Version 9 adds support for classical [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") nodes and their associated [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")s. + +#### EXPRESSION + +An [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node is represented by a stream of variable-width data. A node itself is represented by (in order in the byte stream): + +1. a one-byte type code discriminator; +2. an EXPR\_TYPE object; +3. a type-code-specific additional payload; +4. a type-code-specific number of child EXPRESSION payloads (the number of these is implied by the type code and not explicitly stored). + +Each of these are described in the following table: + +| Qiskit class | Type code | Payload | Children | +| --------------------------------------------------------------------------------------------------------- | --------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------- | +| [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") | `x` | One EXPR\_VAR. | 0 | +| [`Value`](circuit_classical#qiskit.circuit.classical.expr.Value "qiskit.circuit.classical.expr.Value") | `v` | One EXPR\_VALUE. | 0 | +| [`Cast`](circuit_classical#qiskit.circuit.classical.expr.Cast "qiskit.circuit.classical.expr.Cast") | `c` | One `_Bool` that corresponds to the value of `implicit`. | 1 | +| [`Unary`](circuit_classical#qiskit.circuit.classical.expr.Unary "qiskit.circuit.classical.expr.Unary") | `u` | One `uint8_t` with the same numeric value as the [`Unary.Op`](circuit_classical#qiskit.circuit.classical.expr.Unary.Op "qiskit.circuit.classical.expr.Unary.Op"). | 1 | +| [`Binary`](circuit_classical#qiskit.circuit.classical.expr.Binary "qiskit.circuit.classical.expr.Binary") | `b` | One `uint8_t` with the same numeric value as the [`Binary.Op`](circuit_classical#qiskit.circuit.classical.expr.Binary.Op "qiskit.circuit.classical.expr.Binary.Op"). | 2 | + + + +#### EXPR\_TYPE + +A [`Type`](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type") is encoded by a single-byte ASCII `char` that encodes the kind of type, followed by a payload that varies depending on the type. The defined codes are: + +| Qiskit class | Type code | Payload | +| ----------------------------------------------------------------------------------------------------- | --------- | --------------------- | +| [`Bool`](circuit_classical#qiskit.circuit.classical.types.Bool "qiskit.circuit.classical.types.Bool") | `b` | None. | +| [`Uint`](circuit_classical#qiskit.circuit.classical.types.Uint "qiskit.circuit.classical.types.Uint") | `u` | One `uint32_t width`. | + + + +#### EXPR\_VAR + +This represents a runtime variable of a [`Var`](circuit_classical#qiskit.circuit.classical.expr.Var "qiskit.circuit.classical.expr.Var") node. These are a type code, followed by a type-code-specific payload: + +| Python class | Type code | Payload | +| ------------------------------------------------------------------------------------------ | --------- | ------------------------------------------------------------------------------------------------------------------------------- | +| [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") | `C` | One `uint32_t index` that is the index of the [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") in the containing circuit. | +| [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") | `R` | One `uint16_t reg_name_size`, followed by that many bytes of UTF-8 string data of the register name. | + + + +#### EXPR\_VALUE + +This represents a literal object in the classical type system, such as an integer. Currently there are very few such literals. These are encoded as a type code, followed by a type-code-specific payload. + +| Python type | Type code | Payload | +| ----------- | --------- | ---------------------------------------------------------------------------------------------------------------------------------------- | +| `bool` | `b` | One `_Bool value`. | +| `int` | `i` | One `uint8_t num_bytes`, followed by the integer encoded into that many many bytes (network order) in a two’s complement representation. | + +#### Changes to INSTRUCTION + +To support the use of [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") nodes in the fields [`IfElseOp.condition`](qiskit.circuit.IfElseOp#condition "qiskit.circuit.IfElseOp.condition"), [`WhileLoopOp.condition`](qiskit.circuit.WhileLoopOp#condition "qiskit.circuit.WhileLoopOp.condition") and `SwitchCaseOp.target`, the INSTRUCTION struct is changed in an ABI compatible-manner to [its previous definition](#qpy-instruction-v5). The new struct is the C struct: + +```python +struct { + uint16_t name_size; + uint16_t label_size; + uint16_t num_parameters; + uint32_t num_qargs; + uint32_t num_cargs; + uint8_t conditional_key; + uint16_t conditional_reg_name_size; + int64_t conditional_value; + uint32_t num_ctrl_qubits; + uint32_t ctrl_state; +} +``` + +where the only change is that a `uint8_t conditional_key` entry has replaced `_Bool has_conditional`. This new `conditional_key` takes the following numeric values, with these effects: + +| Value | Effects | +| ----- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| 0 | The instruction has its `.condition` field set to `None`. The `conditional_reg_name_size` and `conditional_value` fields should be ignored. | +| 1 | The instruction has its `.condition` field set to a 2-tuple of either a [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") or a [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister"), and a integer of value `conditional_value`. The INSTRUCTION payload, including its trailing data is parsed exactly as it would be in QPY versions less than 8. | +| 2 | The instruction has its `.condition` field set to a [`Expr`](circuit_classical#qiskit.circuit.classical.expr.Expr "qiskit.circuit.classical.expr.Expr") node. The `conditional_reg_name_size` and `conditional_value` fields should be ignored. The data following the struct is followed (as in QPY versions less than 8) by `name_size` bytes of UTF-8 string data for the class name and `label_size` bytes of UTF-8 string data for the label (if any). Then, there is one INSTRUCTION\_PARAM, which will contain an EXPRESSION. After that, parsing continues with the INSTRUCTION\_ARG structs, as in previous versions of QPY. | + + + +#### Changes to INSTRUCTION\_PARAM + +A new type code `x` is added that defines an EXPRESSION parameter. + + + +### Version 8 + +Version 8 adds support for handling a [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") stored in the [`QuantumCircuit.layout`](qiskit.circuit.QuantumCircuit#layout "qiskit.circuit.QuantumCircuit.layout") attribute. In version 8 immediately following the calibrations block at the end of the circuit payload there is now the `LAYOUT` struct. This struct outlines the size of the three attributes of a [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout") class. + + + +#### LAYOUT + +```python +struct { + char exists; + int32_t initial_layout_size; + int32_t input_mapping_size; + int32_t final_layout_size; + uint32_t extra_registers; +} +``` + +If any of the signed values are `-1` this indicates the corresponding attribute is `None`. + +Immediately following the `LAYOUT` struct there is a [REGISTERS](#qpy-registers) struct for `extra_registers` (specifically the format introduced in [Version 4](#qpy-version-4)) standalone register definitions that aren’t present in the circuit. Then there are `initial_layout_size` `INITIAL_LAYOUT_BIT` structs to define the [`TranspileLayout.initial_layout`](qiskit.transpiler.TranspileLayout#initial_layout "qiskit.transpiler.TranspileLayout.initial_layout") attribute. + + + +#### INITIAL\_LAYOUT\_BIT + +```python +struct { + int32_t index; + int32_t register_size; +} +``` + +Where a value of `-1` indicates `None` (as in no register is associated with the bit). Following each `INITIAL_LAYOUT_BIT` struct is `register_size` bytes for a `utf8` encoded string for the register name. + +Following the initial layout there is `input_mapping_size` array of `uint32_t` integers representing the positions of the physical bit from the initial layout. This enables constructing a list of virtual bits where the array index is its input mapping position. + +Finally, there is an array of `final_layout_size` `uint32_t` integers. Each element is an index in the circuit’s `qubits` attribute which enables building a mapping from qubit starting position to the output position at the end of the circuit. + + + +### Version 7 + +Version 7 adds support for `Reference` instruction and serialization of a `ScheduleBlock` program while keeping its reference to subroutines: + +```python +from qiskit import pulse +from qiskit import qpy + +with pulse.build() as schedule: + pulse.reference("cr45p", "q0", "q1") + pulse.reference("x", "q0") + pulse.reference("cr45p", "q0", "q1") + +with open('template_ecr.qpy', 'wb') as fd: + qpy.dump(schedule, fd) +``` + +The conventional [SCHEDULE\_BLOCK](#qpy-schedule-block) data model is preserved, but in version 7 it is immediately followed by an extra [MAPPING](#qpy-mapping) utf8 bytes block representing the data of the referenced subroutines. + +New type key character is added to the [SCHEDULE\_BLOCK\_INSTRUCTIONS](#qpy-schedule-instructions) group for the `Reference` instruction. + +* `y`: [`Reference`](qiskit.pulse.instructions.Reference "qiskit.pulse.instructions.Reference") instruction + +New type key character is added to the [SCHEDULE\_BLOCK\_OPERANDS](#qpy-schedule-operands) group for the operands of `Reference` instruction, which is a tuple of strings, e.g. (“cr45p”, “q0”, “q1”). + +* `o`: string (operand string) + +Note that this is the same encoding with the built-in Python string, however, the standard value encoding in QPY uses `s` type character for string data, which conflicts with the [`SymbolicPulse`](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") in the scope of pulse instruction operands. A special type character `o` is reserved for the string data that appears in the pulse instruction operands. + +In addition, version 7 adds two new type keys to the INSTRUCTION\_PARM struct. `"d"` is followed by no data and represents the literal value [`CASE_DEFAULT`](circuit#qiskit.circuit.CASE_DEFAULT "qiskit.circuit.CASE_DEFAULT") for switch-statement support. `"R"` represents a [`ClassicalRegister`](qiskit.circuit.ClassicalRegister "qiskit.circuit.ClassicalRegister") or [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit"), and is followed by the same format as the description of register or classical bit as used in the first element of [the condition of an INSTRUCTION field](#qpy-instructions). + + + +### Version 6 + +Version 6 adds support for `ScalableSymbolicPulse`. These objects are saved and read like SymbolicPulse objects, and the class name is added to the data to correctly handle the class selection. + +SymbolicPulse block now starts with SYMBOLIC\_PULSE\_V2 header: + +```python +struct { + uint16_t class_name_size; + uint16_t type_size; + uint16_t envelope_size; + uint16_t constraints_size; + uint16_t valid_amp_conditions_size; + _bool amp_limited; +} +``` + +The only change compared to [Version 5](#qpy-version-5) is the addition of class\_name\_size. The header is then immediately followed by `class_name_size` utf8 bytes with the name of the class. Currently, either SymbolicPulse or ScalableSymbolicPulse are supported. The rest of the data is then identical to [Version 5](#qpy-version-5). + + + +### Version 5 + +Version 5 changes from [Version 4](#qpy-version-4) by adding support for `ScheduleBlock` and changing two payloads the INSTRUCTION metadata payload and the CUSTOM\_INSTRUCTION block. These now have new fields to better account for [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") objects in a circuit. In addition, new payload MAP\_ITEM is defined to implement the [MAPPING](#qpy-mapping) block. + +With the support of `ScheduleBlock`, now [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") can be serialized together with [`calibrations`](qiskit.circuit.QuantumCircuit#calibrations "qiskit.circuit.QuantumCircuit.calibrations"), or [Pulse Gates](https://docs.quantum-computing.ibm.com/build/pulse). In QPY version 5 and above, [CIRCUIT\_CALIBRATIONS](#qpy-circuit-calibrations) payload is packed after the [INSTRUCTIONS](#qpy-instructions) block. + +In QPY version 5 and above, + +```python +struct { + char type; +} +``` + +immediately follows the file header block to represent the program type stored in the file. + +* When `type==c`, [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") payload follows +* When `type==s`, [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") payload follows + + + Different programs cannot be packed together in the same file. You must create different files for different program types. Multiple objects with the same type can be saved in a single file. + + + + + + +#### SCHEDULE\_BLOCK + +[`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") is first supported in QPY Version 5. This allows users to save pulse programs in the QPY binary format as follows: + +```python +from qiskit import pulse, qpy + +with pulse.build() as schedule: + pulse.play(pulse.Gaussian(160, 0.1, 40), pulse.DriveChannel(0)) + +with open('schedule.qpy', 'wb') as fd: + qpy.dump(qc, fd) + +with open('schedule.qpy', 'rb') as fd: + new_qc = qpy.load(fd)[0] +``` + +Note that circuit and schedule block are serialized and deserialized through the same QPY interface. Input data type is implicitly analyzed and no extra option is required to save the schedule block. + + + + + +#### SCHEDULE\_BLOCK\_HEADER + +[`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") block starts with the following header: + +```python +struct { + uint16_t name_size; + uint64_t metadata_size; + uint16_t num_element; +} +``` + +which is immediately followed by `name_size` utf8 bytes of schedule name and `metadata_size` utf8 bytes of the JSON serialized metadata dictionary attached to the schedule. + + + + + +#### SCHEDULE\_BLOCK\_ALIGNMENTS + +Then, alignment context of the schedule block starts with `char` representing the supported context type followed by the [SEQUENCE](#qpy-sequence) block representing the parameters associated with the alignment context `AlignmentKind._context_params`. The context type char is mapped to each alignment subclass as follows: + +* `l`: [`AlignLeft`](qiskit.pulse.transforms.AlignLeft "qiskit.pulse.transforms.AlignLeft") +* `r`: [`AlignRight`](qiskit.pulse.transforms.AlignRight "qiskit.pulse.transforms.AlignRight") +* `s`: [`AlignSequential`](qiskit.pulse.transforms.AlignSequential "qiskit.pulse.transforms.AlignSequential") +* `e`: [`AlignEquispaced`](qiskit.pulse.transforms.AlignEquispaced "qiskit.pulse.transforms.AlignEquispaced") + +Note that [`AlignFunc`](qiskit.pulse.transforms.AlignFunc "qiskit.pulse.transforms.AlignFunc") context is not supported because of the callback function stored in the context parameters. + + + + + +#### SCHEDULE\_BLOCK\_INSTRUCTIONS + +This alignment block is further followed by `num_element` length of block elements which may consist of nested schedule blocks and schedule instructions. Each schedule instruction starts with `char` representing the instruction type followed by the [SEQUENCE](#qpy-sequence) block representing the instruction `operands`. Note that the data structure of pulse [`Instruction`](pulse#qiskit.pulse.instructions.Instruction "qiskit.pulse.instructions.Instruction") is unified so that instance can be uniquely determined by the class and a tuple of operands. The mapping of type char to the instruction subclass is defined as follows: + +* `a`: [`Acquire`](qiskit.pulse.instructions.Acquire "qiskit.pulse.instructions.Acquire") instruction +* `p`: [`Play`](qiskit.pulse.instructions.Play "qiskit.pulse.instructions.Play") instruction +* `d`: [`Delay`](qiskit.pulse.instructions.Delay "qiskit.pulse.instructions.Delay") instruction +* `f`: [`SetFrequency`](qiskit.pulse.instructions.SetFrequency "qiskit.pulse.instructions.SetFrequency") instruction +* `g`: [`ShiftFrequency`](qiskit.pulse.instructions.ShiftFrequency "qiskit.pulse.instructions.ShiftFrequency") instruction +* `q`: [`SetPhase`](qiskit.pulse.instructions.SetPhase "qiskit.pulse.instructions.SetPhase") instruction +* `r`: [`ShiftPhase`](qiskit.pulse.instructions.ShiftPhase "qiskit.pulse.instructions.ShiftPhase") instruction +* `b`: [`RelativeBarrier`](qiskit.pulse.instructions.RelativeBarrier "qiskit.pulse.instructions.RelativeBarrier") instruction +* `t`: [`TimeBlockade`](qiskit.pulse.instructions.TimeBlockade "qiskit.pulse.instructions.TimeBlockade") instruction +* `y`: [`Reference`](qiskit.pulse.instructions.Reference "qiskit.pulse.instructions.Reference") instruction (new in version 0.7) + + + + + +#### SCHEDULE\_BLOCK\_OPERANDS + +The operands of these instances can be serialized through the standard QPY value serialization mechanism, however there are special object types that only appear in the schedule operands. Since the operands are serialized as [SEQUENCE](#qpy-sequence), each element must be packed with the INSTRUCTION\_PARAM pack struct, where each payload starts with a header block consists of the char `type` and uint64\_t `size`. Special objects start with the following type key: + +* `c`: [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") +* `w`: [`Waveform`](qiskit.pulse.library.Waveform "qiskit.pulse.library.Waveform") +* `s`: [`SymbolicPulse`](qiskit.pulse.library.SymbolicPulse "qiskit.pulse.library.SymbolicPulse") +* `o`: string (operand string, new in version 0.7) + + + +#### CHANNEL + +Channel block starts with channel subtype `char` that maps an object data to [`Channel`](pulse#qiskit.pulse.channels.Channel "qiskit.pulse.channels.Channel") subclass. Mapping is defined as follows: + +* `d`: [`DriveChannel`](qiskit.pulse.channels.DriveChannel "qiskit.pulse.channels.DriveChannel") +* `c`: [`ControlChannel`](qiskit.pulse.channels.ControlChannel "qiskit.pulse.channels.ControlChannel") +* `m`: [`MeasureChannel`](qiskit.pulse.channels.MeasureChannel "qiskit.pulse.channels.MeasureChannel") +* `a`: [`AcquireChannel`](qiskit.pulse.channels.AcquireChannel "qiskit.pulse.channels.AcquireChannel") +* `e`: [`MemorySlot`](qiskit.pulse.channels.MemorySlot "qiskit.pulse.channels.MemorySlot") +* `r`: [`RegisterSlot`](qiskit.pulse.channels.RegisterSlot "qiskit.pulse.channels.RegisterSlot") + +The key is immediately followed by the channel index serialized as the INSTRUCTION\_PARAM. + + + +#### Waveform + +Waveform block starts with WAVEFORM header: + +```python +struct { + double epsilon; + uint32_t data_size; + _bool amp_limited; +} +``` + +which is followed by `data_size` bytes of complex `ndarray` binary generated by [numpy.save](https://numpy.org/doc/stable/reference/generated/numpy.save.html). This represents the complex IQ data points played on a quantum device. [`name`](qiskit.pulse.library.Waveform#name "qiskit.pulse.library.Waveform.name") is saved after the samples in the INSTRUCTION\_PARAM pack struct, which can be string or `None`. + + + +#### SymbolicPulse + +SymbolicPulse block starts with SYMBOLIC\_PULSE header: + +```python +struct { + uint16_t type_size; + uint16_t envelope_size; + uint16_t constraints_size; + uint16_t valid_amp_conditions_size; + _bool amp_limited; +} +``` + +which is followed by `type_size` utf8 bytes of [`SymbolicPulse.pulse_type`](qiskit.pulse.library.SymbolicPulse#pulse_type "qiskit.pulse.library.SymbolicPulse.pulse_type") string that represents a class of waveform, such as “Gaussian” or “GaussianSquare”. Then, `envelope_size`, `constraints_size`, `valid_amp_conditions_size` utf8 bytes of serialized symbolic expressions are generated for [`SymbolicPulse.envelope`](qiskit.pulse.library.SymbolicPulse#envelope "qiskit.pulse.library.SymbolicPulse.envelope"), [`SymbolicPulse.constraints`](qiskit.pulse.library.SymbolicPulse#constraints "qiskit.pulse.library.SymbolicPulse.constraints"), and [`SymbolicPulse.valid_amp_conditions`](qiskit.pulse.library.SymbolicPulse#valid_amp_conditions "qiskit.pulse.library.SymbolicPulse.valid_amp_conditions"), respectively. Since string representation of these expressions are usually lengthy, the expression binary is generated by the python [zlib](https://docs.python.org/3/library/zlib.html) module with data compression. + +To uniquely specify a pulse instance, we also need to store the associated parameters, which consist of `duration` and the rest of parameters as a dictionary. Dictionary parameters are first dumped in the [MAPPING](#qpy-mapping) form, and then `duration` is dumped with the INSTRUCTION\_PARAM pack struct. Lastly, [`name`](qiskit.pulse.library.SymbolicPulse#name "qiskit.pulse.library.SymbolicPulse.name") is saved also with the INSTRUCTION\_PARAM pack struct, which can be string or `None`. + + + +#### MAPPING + +The MAPPING is a representation for arbitrary mapping object. This is a fixed length [SEQUENCE](#qpy-sequence) of key-value pair represented by the MAP\_ITEM payload. + +A MAP\_ITEM starts with a header defined as: + +```python +struct { + uint16_t key_size; + char type; + uint16_t size; +} +``` + +which is immediately followed by the `key_size` utf8 bytes representing the dictionary key in string and `size` utf8 bytes of arbitrary object data of QPY serializable `type`. + + + + + +#### CIRCUIT\_CALIBRATIONS + +The CIRCUIT\_CALIBRATIONS block is a dictionary to define pulse calibrations of the custom instruction set. This block starts with the following CALIBRATION header: + +```python +struct { + uint16_t num_cals; +} +``` + +which is followed by the `num_cals` length of calibration entries, each starts with the CALIBRATION\_DEF header: + +```python +struct { + uint16_t name_size; + uint16_t num_qubits; + uint16_t num_params; + char type; +} +``` + +The calibration definition header is then followed by `name_size` utf8 bytes of the gate name, `num_qubits` length of integers representing a sequence of qubits, and `num_params` length of INSTRUCTION\_PARAM payload for parameters associated to the custom instruction. The `type` indicates the class of pulse program which is either, in principle, [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") or [`Schedule`](qiskit.pulse.Schedule "qiskit.pulse.Schedule"). As of QPY Version 5, only [`ScheduleBlock`](qiskit.pulse.ScheduleBlock "qiskit.pulse.ScheduleBlock") payload is supported. Finally, [SCHEDULE\_BLOCK](#qpy-schedule-block) payload is packed for each CALIBRATION\_DEF entry. + + + +#### INSTRUCTION + +The INSTRUCTION block was modified to add two new fields `num_ctrl_qubits` and `ctrl_state` which are used to model the [`ControlledGate.num_ctrl_qubits`](qiskit.circuit.ControlledGate#num_ctrl_qubits "qiskit.circuit.ControlledGate.num_ctrl_qubits") and [`ControlledGate.ctrl_state`](qiskit.circuit.ControlledGate#ctrl_state "qiskit.circuit.ControlledGate.ctrl_state") attributes. The new payload packed struct format is: + +```python +struct { + uint16_t name_size; + uint16_t label_size; + uint16_t num_parameters; + uint32_t num_qargs; + uint32_t num_cargs; + _Bool has_conditional; + uint16_t conditional_reg_name_size; + int64_t conditional_value; + uint32_t num_ctrl_qubits; + uint32_t ctrl_state; +} +``` + +The rest of the instruction payload is the same. You can refer to [INSTRUCTIONS](#qpy-instructions) for the details of the full payload. + + + +#### CUSTOM\_INSTRUCTION + +The CUSTOM\_INSTRUCTION block in QPY version 5 adds a new field `base_gate_size` which is used to define the size of the [`qiskit.circuit.Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") object stored in the `ControlledGate.base_gate` attribute for a custom [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate") object. With this change the CUSTOM\_INSTRUCTION metadata block becomes: + +```python +struct { + uint16_t name_size; + char type; + uint32_t num_qubits; + uint32_t num_clbits; + _Bool custom_definition; + uint64_t size; + uint32_t num_ctrl_qubits; + uint32_t ctrl_state; + uint64_t base_gate_size +} +``` + +Immediately following the CUSTOM\_INSTRUCTION struct is the utf8 encoded name of size `name_size`. + +If `custom_definition` is `True` that means that the immediately following `size` bytes contains a QPY circuit data which can be used for the custom definition of that gate. If `custom_definition` is `False` then the instruction can be considered opaque (ie no definition). The `type` field determines what type of object will get created with the custom definition. If it’s `'g'` it will be a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") object, `'i'` it will be a [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") object. + +Following this the next `base_gate_size` bytes contain the `INSTRUCTION` payload for the `ControlledGate.base_gate`. + +Additionally an addition value for `type` is added `'c'` which is used to indicate the custom instruction is a custom [`ControlledGate`](qiskit.circuit.ControlledGate "qiskit.circuit.ControlledGate"). + + + +### Version 4 + +Version 4 is identical to [Version 3](#qpy-version-3) except that it adds 2 new type strings to the INSTRUCTION\_PARAM struct, `z` to represent `None` (which is encoded as no data), `q` to represent a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") (which is encoded as a QPY circuit), `r` to represent a `range` of integers (which is encoded as a [RANGE](#qpy-range-pack)), and `t` to represent a `sequence` (which is encoded as defined by [SEQUENCE](#qpy-sequence)). Additionally, version 4 changes the type of register index mapping array from `uint32_t` to `int64_t`. If the values of any of the array elements are negative they represent a register bit that is not present in the circuit. + +The [REGISTERS](#qpy-registers) header format has also been updated to + +```python +struct { + char type; + _Bool standalone; + uint32_t size; + uint16_t name_size; + _bool in_circuit; +} +``` + +which just adds the `in_circuit` field which represents whether the register is part of the circuit or not. + + + +#### RANGE + +A RANGE is a representation of a `range` object. It is defined as: + +```python +struct { + int64_t start; + int64_t stop; + int64_t step; +} +``` + + + +#### SEQUENCE + +A SEQUENCE is a representation of an arbitrary sequence object. As sequence are just fixed length containers of arbitrary python objects their QPY can’t fully represent any sequence, but as long as the contents in a sequence are other QPY serializable types for the INSTRUCTION\_PARAM payload the `sequence` object can be serialized. + +A sequence instruction parameter starts with a header defined as: + +```python +struct { + uint64_t size; +} +``` + +followed by `size` elements that are INSTRUCTION\_PARAM payloads, where each of these define an element in the sequence. The sequence object will be typecasted into proper type, e.g. `tuple`, afterwards. + + + +### Version 3 + +Version 3 of the QPY format is identical to [Version 2](#qpy-version-2) except that it defines a struct format to represent a [`PauliEvolutionGate`](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate") natively in QPY. To accomplish this the [CUSTOM\_DEFINITIONS](#qpy-custom-definition) struct now supports a new type value `'p'` to represent a [`PauliEvolutionGate`](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate"). Enties in the custom instructions tables have unique name generated that start with the string `"###PauliEvolutionGate_"` followed by a uuid string. This gate name is reservered in QPY and if you have a custom [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") object with a definition set and that name prefix it will error. If it’s of type `'p'` the data payload is defined as follows: + + + + + +#### PAULI\_EVOLUTION + +This represents the high level [`PauliEvolutionGate`](qiskit.circuit.library.PauliEvolutionGate "qiskit.circuit.library.PauliEvolutionGate") + +```python +struct { + uint64_t operator_count; + _Bool standalone_op; + char time_type; + uint64_t time_size; + uint64_t synthesis_size; +} +``` + +This is immediately followed by `operator_count` elements defined by the [SPARSE\_PAULI\_OP\_LIST\_ELEM](#qpy-pauli-sum-op) payload. Following that we have `time_size` bytes representing the `time` attribute. If `standalone_op` is `True` then there must only be a single operator. The encoding of these bytes is determined by the value of `time_type`. Possible values of `time_type` are `'f'`, `'p'`, and `'e'`. If `time_type` is `'f'` it’s a double, `'p'` defines a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") object which is represented by a [PARAMETER](#qpy-param-struct), `e` defines a [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") object (that’s not a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) which is represented by a [PARAMETER\_EXPR](#qpy-param-expr). Following that is `synthesis_size` bytes which is a utf8 encoded json payload representing the [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis") class used by the gate. + + + + + +#### SPARSE\_PAULI\_OP\_LIST\_ELEM + +This represents an instance of [`PauliSumOp`](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp"). + +```python +struct { + uint32_t pauli_op_size; +} +``` + +which is immediately followed by `pauli_op_size` bytes which are .npy format [\[2\]](#f2) data which represents the [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp"). + +Version 3 of the QPY format also defines a struct format to represent a `ParameterVectorElement` as a distinct subclass from a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter"). This adds a new parameter type char `'v'` to represent a `ParameterVectorElement` which is now supported as a type string value for an INSTRUCTION\_PARAM. The payload for these parameters are defined below as [PARAMETER\_VECTOR\_ELEMENT](#qpy-param-vector). + + + + + +#### PARAMETER\_VECTOR\_ELEMENT + +A PARAMETER\_VECTOR\_ELEMENT represents a `ParameterVectorElement` object the data for a INSTRUCTION\_PARAM. The contents of the PARAMETER\_VECTOR\_ELEMENT are defined as: + +```python +struct { + uint16_t vector_name_size; + uint64_t vector_size; + char uuid[16]; + uint64_t index; +} +``` + +which is immediately followed by `vector_name_size` utf8 bytes representing the parameter’s vector name. + + + + + +#### PARAMETER\_EXPR + +Additionally, since QPY format version v3 distinguishes between a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") and `ParameterVectorElement` the payload for a [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") needs to be updated to distinguish between the types. The following is the modified payload format which is mostly identical to the format in Version 1 and [Version 2](#qpy-version-2) but just modifies the `map_elements` struct to include a symbol type field. + +A PARAMETER\_EXPR represents a [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") object that the data for an INSTRUCTION\_PARAM. The contents of a PARAMETER\_EXPR are defined as: + +```python +struct { + uint64_t map_elements; + uint64_t expr_size; +} +``` + +Immediately following the header is `expr_size` bytes of utf8 data containing the expression string, which is the sympy srepr of the expression for the parameter expression. Following that is a symbol map which contains `map_elements` elements with the format + +```python +struct { + char symbol_type; + char type; + uint64_t size; +} +``` + +The `symbol_type` key determines the payload type of the symbol representation for the element. If it’s `p` it represents a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") and if it’s `v` it represents a `ParameterVectorElement`. The map element struct is immediately followed by the symbol map key payload, if `symbol_type` is `p` then it is followed immediately by a [PARAMETER](#qpy-param-struct) object (both the struct and utf8 name bytes) and if `symbol_type` is `v` then the struct is imediately followed by [PARAMETER\_VECTOR\_ELEMENT](#qpy-param-vector) (both the struct and utf8 name bytes). That is followed by `size` bytes for the data of the symbol. The data format is dependent on the value of `type`. If `type` is `p` then it represents a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") and size will be 0, the value will just be the same as the key. Similarly if the `type` is `v` then it represents a `ParameterVectorElement` and size will be 0 as the value will just be the same as the key. If `type` is `f` then it represents a double precision float. If `type` is `c` it represents a double precision complex, which is represented by the [COMPLEX](#qpy-complex). Finally, if type is `i` it represents an integer which is an `int64_t`. + + + +### Version 2 + +Version 2 of the QPY format is identical to version 1 except for the HEADER section is slightly different. You can refer to the [Version 1](#qpy-version-1) section for the details on the rest of the payload format. + +#### HEADER + +The contents of HEADER are defined as a C struct are: + +```python +struct { + uint16_t name_size; + char global_phase_type; + uint16_t global_phase_size; + uint32_t num_qubits; + uint32_t num_clbits; + uint64_t metadata_size; + uint32_t num_registers; + uint64_t num_instructions; + uint64_t num_custom_gates; +} +``` + +This is immediately followed by `name_size` bytes of utf8 data for the name of the circuit. Following this is immediately `global_phase_size` bytes representing the global phase. The content of that data is dictated by the value of `global_phase_type`. If it’s `'f'` the data is a float and is the size of a `double`. If it’s `'p'` defines a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") object which is represented by a PARAM struct (see below), `e` defines a [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") object (that’s not a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) which is represented by a PARAM\_EXPR struct (see below). + + + +### Version 1 + + + +#### HEADER + +The contents of HEADER as defined as a C struct are: + +```python +struct { + uint16_t name_size; + double global_phase; + uint32_t num_qubits; + uint32_t num_clbits; + uint64_t metadata_size; + uint32_t num_registers; + uint64_t num_instructions; + uint64_t num_custom_gates; +} +``` + +This is immediately followed by `name_size` bytes of utf8 data for the name of the circuit. + +#### METADATA + +The METADATA field is a UTF8 encoded JSON string. After reading the HEADER (which is a fixed size at the start of the QPY file) and the `name` string you then read the `metadata_size` number of bytes and parse the JSON to get the metadata for the circuit. + + + +#### REGISTERS + +The contents of REGISTERS is a number of REGISTER object. If num\_registers is > 0 then after reading METADATA you read that number of REGISTER structs defined as: + +```python +struct { + char type; + _Bool standalone; + uint32_t size; + uint16_t name_size; +} +``` + +`type` can be `'q'` or `'c'`. + +Immediately following the REGISTER struct is the utf8 encoded register name of size `name_size`. After the `name` utf8 bytes there is then an array of int64\_t values of size `size` that contains a map of the register’s index to the circuit’s qubit index. For example, array element 0’s value is the index of the `register[0]`’s position in the containing circuit’s qubits list. + + + Prior to QPY [Version 4](#qpy-version-4) the type of array elements was uint32\_t. This was changed to enable negative values which represent bits in the array not present in the circuit + + +The standalone boolean determines whether the register is constructed as a standalone register that was added to the circuit or was created from existing bits. A register is considered standalone if it has bits constructed solely as part of it, for example: + +```python +qr = QuantumRegister(2) +qc = QuantumCircuit(qr) +``` + +the register `qr` would be a standalone register. While something like: + +```python +bits = [Qubit(), Qubit()] +qr2 = QuantumRegister(bits=bits) +qc = QuantumCircuit(qr2) +``` + +`qr2` would have `standalone` set to `False`. + + + + + +#### CUSTOM\_DEFINITIONS + +This section specifies custom definitions for any of the instructions in the circuit. + +CUSTOM\_DEFINITION\_HEADER contents are defined as: + +```python +struct { + uint64_t size; +} +``` + +If size is greater than 0 that means the circuit contains custom instruction(s). Each custom instruction is defined with a CUSTOM\_INSTRUCTION block defined as: + +```python +struct { + uint16_t name_size; + char type; + uint32_t num_qubits; + uint32_t num_clbits; + _Bool custom_definition; + uint64_t size; +} +``` + +Immediately following the CUSTOM\_INSTRUCTION struct is the utf8 encoded name of size `name_size`. + +If `custom_definition` is `True` that means that the immediately following `size` bytes contains a QPY circuit data which can be used for the custom definition of that gate. If `custom_definition` is `False` then the instruction can be considered opaque (ie no definition). The `type` field determines what type of object will get created with the custom definition. If it’s `'g'` it will be a [`Gate`](qiskit.circuit.Gate "qiskit.circuit.Gate") object, `'i'` it will be a [`Instruction`](qiskit.circuit.Instruction "qiskit.circuit.Instruction") object. + + + +#### INSTRUCTIONS + +The contents of INSTRUCTIONS is a list of INSTRUCTION metadata objects + +```python +struct { + uint16_t name_size; + uint16_t label_size; + uint16_t num_parameters; + uint32_t num_qargs; + uint32_t num_cargs; + _Bool has_conditional; + uint16_t conditional_reg_name_size; + int64_t conditional_value; +} +``` + +This metadata object is immediately followed by `name_size` bytes of utf8 bytes for the `name`. `name` here is the Qiskit class name for the Instruction class if it’s defined in Qiskit. Otherwise it falls back to the custom instruction name. Following the `name` bytes there are `label_size` bytes of utf8 data for the label if one was set on the instruction. Following the label bytes if `has_conditional` is `True` then there are `conditional_reg_name_size` bytes of utf8 data for the name of the conditional register name. In case of single classical bit conditions the register name utf8 data will be prefixed with a null character “x00” and then a utf8 string integer representing the classical bit index in the circuit that the condition is on. + +This is immediately followed by the INSTRUCTION\_ARG structs for the list of arguments of that instruction. These are in the order of all quantum arguments (there are num\_qargs of these) followed by all classical arguments (num\_cargs of these). + +The contents of each INSTRUCTION\_ARG is: + +```python +struct { + char type; + uint32_t index; +} +``` + +`type` can be `'q'` or `'c'`. + +After all arguments for an instruction the parameters are specified with `num_parameters` INSTRUCTION\_PARAM structs. + +The contents of each INSTRUCTION\_PARAM is: + +```python +struct { + char type; + uint64_t size; +} +``` + +After each INSTRUCTION\_PARAM the next `size` bytes are the parameter’s data. The `type` field can be `'i'`, `'f'`, `'p'`, `'e'`, `'s'`, `'c'` or `'n'` which dictate the format. For `'i'` it’s an integer, `'f'` it’s a double, `'s'` if it’s a string (encoded as utf8), `'c'` is a complex and the data is represented by the struct format in the [PARAMETER\_EXPR](#qpy-param-expr) section. `'p'` defines a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") object which is represented by a [PARAMETER](#qpy-param-struct) struct, `e` defines a [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") object (that’s not a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")) which is represented by a [PARAMETER\_EXPR](#qpy-param-expr) struct (on QPY format [Version 3](#qpy-version-3) the format is tweak slightly see: [PARAMETER\_EXPR](#qpy-param-expr-v3)), `'n'` represents an object from numpy (either an `ndarray` or a numpy type) which means the data is .npy format [\[2\]](#f2) data, and in QPY [Version 3](#qpy-version-3) `'v'` represents a `ParameterVectorElement` which is represented by a [PARAMETER\_VECTOR\_ELEMENT](#qpy-param-vector) struct. + + + +#### PARAMETER + +A PARAMETER represents a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") object the data for a INSTRUCTION\_PARAM. The contents of the PARAMETER are defined as: + +```python +struct { + uint16_t name_size; + char uuid[16]; +} +``` + +which is immediately followed by `name_size` utf8 bytes representing the parameter name. + + + + + +#### PARAMETER\_EXPR + +A PARAMETER\_EXPR represents a [`ParameterExpression`](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") object that the data for an INSTRUCTION\_PARAM. The contents of a PARAMETER\_EXPR are defined as: + +The PARAMETER\_EXPR data starts with a header: + +```python +struct { + uint64_t map_elements; + uint64_t expr_size; +} +``` + +Immediately following the header is `expr_size` bytes of utf8 data containing the expression string, which is the sympy srepr of the expression for the parameter expression. Follwing that is a symbol map which contains `map_elements` elements with the format + +```python +struct { + char type; + uint64_t size; +} +``` + +Which is followed immediately by `PARAMETER` object (both the struct and utf8 name bytes) for the symbol map key. That is followed by `size` bytes for the data of the symbol. The data format is dependent on the value of `type`. If `type` is `p` then it represents a [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter") and size will be 0, the value will just be the same as the key. If `type` is `f` then it represents a double precision float. If `type` is `c` it represents a double precision complex, which is represented by [COMPLEX](#qpy-complex). Finally, if type is `i` it represents an integer which is an `int64_t`. + + + +#### COMPLEX + +When representing a double precision complex value in QPY the following struct is used: + +```python +struct { + double real; + double imag; +} +``` + +this matches the internal C representation of Python’s complex type. [\[3\]](#f3) + +\[[1](#id2)] + +[https://tools.ietf.org/html/rfc1700](https://tools.ietf.org/html/rfc1700) + +\[2] ([1](#id4),[2](#id6)) + +[https://numpy.org/doc/stable/reference/generated/numpy.lib.format.html](https://numpy.org/doc/stable/reference/generated/numpy.lib.format.html) + +\[[3](#id8)] + +[https://docs.python.org/3/c-api/complex.html#c.Py\_complex](https://docs.python.org/3/c-api/complex.html#c.Py_complex) + diff --git a/docs/api/qiskit/0.46/quantum_info.md b/docs/api/qiskit/0.46/quantum_info.md new file mode 100644 index 00000000000..c7f298768fa --- /dev/null +++ b/docs/api/qiskit/0.46/quantum_info.md @@ -0,0 +1,944 @@ +--- +title: quantum_info +description: API reference for qiskit.quantum_info +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.quantum_info +--- + + + + + + + +# Quantum Information + + + +`qiskit.quantum_info` + + + +## Operators + +| | | +| --------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------- | +| [`Operator`](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")(data\[, input\_dims, output\_dims]) | Matrix operator class | +| [`Pauli`](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli")(\[data]) | N-qubit Pauli operator. | +| [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")(data\[, validate, copy]) | An N-qubit unitary operator from the Clifford group. | +| [`ScalarOp`](qiskit.quantum_info.ScalarOp "qiskit.quantum_info.ScalarOp")(\[dims, coeff]) | Scalar identity operator class. | +| [`SparsePauliOp`](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")(data\[, coeffs, ...]) | Sparse N-qubit operator in a Pauli basis representation. | +| [`CNOTDihedral`](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral")(\[data, num\_qubits, validate]) | An N-qubit operator from the CNOT-Dihedral group. | +| [`PauliList`](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList")(data) | List of N-qubit Pauli operators. | +| [`pauli_basis`](qiskit.quantum_info.pauli_basis "qiskit.quantum_info.pauli_basis")(num\_qubits\[, weight]) | Return the ordered PauliList for the n-qubit Pauli basis. | + + + +## States + +| | | +| ----------------------------------------------------------------------------------------------------------------- | ---------------------- | +| [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector")(data\[, dims]) | Statevector class | +| [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")(data\[, dims]) | DensityMatrix class | +| [`StabilizerState`](qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState")(data\[, validate]) | StabilizerState class. | + +## Channels + +| | | +| ---------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------- | +| [`Choi`](qiskit.quantum_info.Choi "qiskit.quantum_info.Choi")(data\[, input\_dims, output\_dims]) | Choi-matrix representation of a Quantum Channel. | +| [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp")(data\[, input\_dims, output\_dims]) | Superoperator representation of a quantum channel. | +| [`Kraus`](qiskit.quantum_info.Kraus "qiskit.quantum_info.Kraus")(data\[, input\_dims, output\_dims]) | Kraus representation of a quantum channel. | +| [`Stinespring`](qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring")(data\[, input\_dims, output\_dims]) | Stinespring representation of a quantum channel. | +| [`Chi`](qiskit.quantum_info.Chi "qiskit.quantum_info.Chi")(data\[, input\_dims, output\_dims]) | Pauli basis Chi-matrix representation of a quantum channel. | +| [`PTM`](qiskit.quantum_info.PTM "qiskit.quantum_info.PTM")(data\[, input\_dims, output\_dims]) | Pauli Transfer Matrix (PTM) representation of a Quantum Channel. | + +## Measures + +### average\_gate\_fidelity + + + +`qiskit.quantum_info.average_gate_fidelity(channel, target=None, require_cp=True, require_tp=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/measures.py "view source code") + +Return the average gate fidelity of a noisy quantum channel. + +The average gate fidelity $F_{\text{ave}}$ is given by + +$$ +\begin{aligned} +F_{\text{ave}}(\mathcal{E}, U) + &= \int d\psi \langle\psi|U^\dagger + \mathcal{E}(|\psi\rangle\!\langle\psi|)U|\psi\rangle \\ + &= \frac{d F_{\text{pro}}(\mathcal{E}, U) + 1}{d + 1} +\end{aligned} + + +$$ + +where $F_{\text{pro}}(\mathcal{E}, U)$ is the [`process_fidelity()`](#qiskit.quantum_info.process_fidelity "qiskit.quantum_info.process_fidelity") of the input quantum *channel* $\mathcal{E}$ with a *target* unitary $U$, and $d$ is the dimension of the *channel*. + +**Parameters** + +* **channel** (*QuantumChannel or* [*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator")) – noisy quantum channel. +* **target** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or None*) – target unitary operator. If None target is the identity operator \[Default: None]. +* **require\_cp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if input and target channels are completely-positive and if non-CP log warning containing negative eigenvalues of Choi-matrix \[Default: True]. +* **require\_tp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if input and target channels are trace-preserving and if non-TP log warning containing negative eigenvalues of partial Choi-matrix $Tr_{\text{out}}[\mathcal{E}] - I$ \[Default: True]. + +**Returns** + +The average gate fidelity $F_{\text{ave}}$. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the channel and target do not have the same dimensions, or have different input and output dimensions. + +### process\_fidelity + + + +`qiskit.quantum_info.process_fidelity(channel, target=None, require_cp=True, require_tp=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/measures.py "view source code") + +Return the process fidelity of a noisy quantum channel. + +The process fidelity $F_{\text{pro}}(\mathcal{E}, \mathcal{F})$ between two quantum channels $\mathcal{E}, \mathcal{F}$ is given by + +$$ +F_{\text{pro}}(\mathcal{E}, \mathcal{F}) + = F(\rho_{\mathcal{E}}, \rho_{\mathcal{F}}) + + +$$ + +where $F$ is the [`state_fidelity()`](#qiskit.quantum_info.state_fidelity "qiskit.quantum_info.state_fidelity"), $\rho_{\mathcal{E}} = \Lambda_{\mathcal{E}} / d$ is the normalized [`Choi`](qiskit.quantum_info.Choi "qiskit.quantum_info.Choi") matrix for the channel $\mathcal{E}$, and $d$ is the input dimension of $\mathcal{E}$. + +When the target channel is unitary this is equivalent to + +$$ +F_{\text{pro}}(\mathcal{E}, U) + = \frac{Tr[S_U^\dagger S_{\mathcal{E}}]}{d^2} + + +$$ + +where $S_{\mathcal{E}}, S_{U}$ are the [`SuperOp`](qiskit.quantum_info.SuperOp "qiskit.quantum_info.SuperOp") matrices for the *input* quantum channel $\mathcal{E}$ and *target* unitary $U$ respectively, and $d$ is the input dimension of the channel. + +**Parameters** + +* **channel** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or QuantumChannel*) – input quantum channel. +* **target** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or QuantumChannel or None*) – target quantum channel. If None target is the identity operator \[Default: None]. +* **require\_cp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if input and target channels are completely-positive and if non-CP log warning containing negative eigenvalues of Choi-matrix \[Default: True]. +* **require\_tp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if input and target channels are trace-preserving and if non-TP log warning containing negative eigenvalues of partial Choi-matrix $Tr_{\text{out}}[\mathcal{E}] - I$ \[Default: True]. + +**Returns** + +The process fidelity $F_{\text{pro}}$. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the channel and target do not have the same dimensions. + +### gate\_error + + + +`qiskit.quantum_info.gate_error(channel, target=None, require_cp=True, require_tp=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/measures.py "view source code") + +Return the gate error of a noisy quantum channel. + +The gate error $E$ is given by the average gate infidelity + +$$ +E(\mathcal{E}, U) = 1 - F_{\text{ave}}(\mathcal{E}, U) + + +$$ + +where $F_{\text{ave}}(\mathcal{E}, U)$ is the [`average_gate_fidelity()`](#qiskit.quantum_info.average_gate_fidelity "qiskit.quantum_info.average_gate_fidelity") of the input quantum *channel* $\mathcal{E}$ with a *target* unitary $U$. + +**Parameters** + +* **channel** (*QuantumChannel*) – noisy quantum channel. +* **target** ([*Operator*](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") *or None*) – target unitary operator. If None target is the identity operator \[Default: None]. +* **require\_cp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if input and target channels are completely-positive and if non-CP log warning containing negative eigenvalues of Choi-matrix \[Default: True]. +* **require\_tp** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if input and target channels are trace-preserving and if non-TP log warning containing negative eigenvalues of partial Choi-matrix $Tr_{\text{out}}[\mathcal{E}] - I$ \[Default: True]. + +**Returns** + +The average gate error $E$. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the channel and target do not have the same dimensions, or have different input and output dimensions. + +### diamond\_norm + + + +`qiskit.quantum_info.diamond_norm(choi, solver='SCS', **kwargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/measures.py "view source code") + +Return the diamond norm of the input quantum channel object. + +This function computes the completely-bounded trace-norm (often referred to as the diamond-norm) of the input quantum channel object using the semidefinite-program from reference \[1]. + +**Parameters** + +* **choi** ([*Choi*](qiskit.quantum_info.Choi "qiskit.quantum_info.Choi") *or QuantumChannel*) – a quantum channel object or Choi-matrix array. +* **solver** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The solver to use. +* **kwargs** – optional arguments to pass to CVXPY solver. + +**Returns** + +The completely-bounded trace norm $\|\mathcal{E}\|_{\diamond}$. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if CVXPY package cannot be found. + +**Additional Information:** + +The input to this function is typically *not* a CPTP quantum channel, but rather the *difference* between two quantum channels $\|\Delta\mathcal{E}\|_\diamond$ where $\Delta\mathcal{E} = \mathcal{E}_1 - \mathcal{E}_2$. + +**Reference:** + +J. Watrous. “Simpler semidefinite programs for completely bounded norms”, arXiv:1207.5726 \[quant-ph] (2012). + + + This function requires the optional CVXPY package to be installed. Any additional kwargs will be passed to the `cvxpy.solve` function. See the CVXPY documentation for information on available SDP solvers. + + +### state\_fidelity + + + +`qiskit.quantum_info.state_fidelity(state1, state2, validate=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/measures.py "view source code") + +Return the state fidelity between two quantum states. + +The state fidelity $F$ for density matrix input states $\rho_1, \rho_2$ is given by + +$$ +F(\rho_1, \rho_2) = Tr[\sqrt{\sqrt{\rho_1}\rho_2\sqrt{\rho_1}}]^2. + + +$$ + +If one of the states is a pure state this simplifies to $F(\rho_1, \rho_2) = \langle\psi_1|\rho_2|\psi_1\rangle$, where $\rho_1 = |\psi_1\rangle\!\langle\psi_1|$. + +**Parameters** + +* **state1** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – the first quantum state. +* **state2** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – the second quantum state. +* **validate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if the inputs are valid quantum states \[Default: True] + +**Returns** + +The state fidelity $F(\rho_1, \rho_2)$. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if `validate=True` and the inputs are invalid quantum states. + +### purity + + + +`qiskit.quantum_info.purity(state, validate=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/measures.py "view source code") + +Calculate the purity of a quantum state. + +The purity of a density matrix $\rho$ is + +$$ +\text{Purity}(\rho) = Tr[\rho^2] +$$ + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – a quantum state. +* **validate** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – check if input state is valid \[Default: True] + +**Returns** + +the purity $Tr[\rho^2]$. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input isn’t a valid quantum state. + +### concurrence + + + +`qiskit.quantum_info.concurrence(state)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/measures.py "view source code") + +Calculate the concurrence of a quantum state. + +The concurrence of a bipartite [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") $|\psi\rangle$ is given by + +$$ +C(|\psi\rangle) = \sqrt{2(1 - Tr[\rho_0^2])} +$$ + +where $\rho_0 = Tr_1[|\psi\rangle\!\langle\psi|]$ is the reduced state from by taking the [`partial_trace()`](#qiskit.quantum_info.partial_trace "qiskit.quantum_info.partial_trace") of the input state. + +For density matrices the concurrence is only defined for 2-qubit states, it is given by: + +$$ +C(\rho) = \max(0, \lambda_1 - \lambda_2 - \lambda_3 - \lambda_4) +$$ + +where $\lambda _1 \ge \lambda _2 \ge \lambda _3 \ge \lambda _4$ are the ordered eigenvalues of the matrix $R=\sqrt{\sqrt{\rho }(Y\otimes Y)\overline{\rho}(Y\otimes Y)\sqrt{\rho}}$. + +**Parameters** + +**state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – a 2-qubit quantum state. + +**Returns** + +The concurrence. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input state is not a valid QuantumState. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input is not a bipartite QuantumState. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if density matrix input is not a 2-qubit state. + +### entropy + + + +`qiskit.quantum_info.entropy(state, base=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/measures.py "view source code") + +Calculate the von-Neumann entropy of a quantum state. + +The entropy $S$ is given by + +$$ +S(\rho) = - Tr[\rho \log(\rho)] +$$ + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – a quantum state. +* **base** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the base of the logarithm \[Default: 2]. + +**Returns** + +The von-Neumann entropy S(rho). + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input state is not a valid QuantumState. + +### entanglement\_of\_formation + + + +`qiskit.quantum_info.entanglement_of_formation(state)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/measures.py "view source code") + +Calculate the entanglement of formation of quantum state. + +The input quantum state must be either a bipartite state vector, or a 2-qubit density matrix. + +**Parameters** + +**state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – a 2-qubit quantum state. + +**Returns** + +The entanglement of formation. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input state is not a valid QuantumState. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input is not a bipartite QuantumState. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if density matrix input is not a 2-qubit state. + +### mutual\_information + + + +`qiskit.quantum_info.mutual_information(state, base=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/measures.py "view source code") + +Calculate the mutual information of a bipartite state. + +The mutual information $I$ is given by: + +$$ +I(\rho_{AB}) = S(\rho_A) + S(\rho_B) - S(\rho_{AB}) +$$ + +where $\rho_A=Tr_B[\rho_{AB}], \rho_B=Tr_A[\rho_{AB}]$, are the reduced density matrices of the bipartite state $\rho_{AB}$. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – a bipartite state. +* **base** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the base of the logarithm \[Default: 2]. + +**Returns** + +The mutual information $I(\rho_{AB})$. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input state is not a valid QuantumState. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input is not a bipartite QuantumState. + +## Utility Functions + +| | | +| ------------------------------------------------------------------------------------- | ---------------------------------- | +| [`Quaternion`](qiskit.quantum_info.Quaternion "qiskit.quantum_info.Quaternion")(data) | A class representing a Quaternion. | + +### partial\_trace + + + +`qiskit.quantum_info.partial_trace(state, qargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/utils.py "view source code") + +Return reduced density matrix by tracing out part of quantum state. + +If all subsystems are traced over this returns the [`trace()`](qiskit.quantum_info.DensityMatrix#trace "qiskit.quantum_info.DensityMatrix.trace") of the input state. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – the input state. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – The subsystems to trace over. + +**Returns** + +The reduced density matrix. + +**Return type** + +[DensityMatrix](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if input state is invalid. + +### schmidt\_decomposition + + + +`qiskit.quantum_info.schmidt_decomposition(state, qargs)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/utils.py "view source code") + +Return the Schmidt Decomposition of a pure quantum state. + +For an arbitrary bipartite state: + +$$ +|\psi\rangle_{AB} = \sum_{i,j} c_{ij} + |x_i\rangle_A \otimes |y_j\rangle_B, + + +$$ + +its Schmidt Decomposition is given by the single-index sum over k: + +$$ +|\psi\rangle_{AB} = \sum_{k} \lambda_{k} + |u_k\rangle_A \otimes |v_k\rangle_B + + +$$ + +where $|u_k\rangle_A$ and $|v_k\rangle_B$ are an orthonormal set of vectors in their respective spaces $A$ and $B$, and the Schmidt coefficients $\lambda_k$ are positive real values. + +**Parameters** + +* **state** ([*Statevector*](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") *or*[*DensityMatrix*](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix")) – the input state. +* **qargs** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – the list of Input state positions corresponding to subsystem $B$. + +**Returns** + +list of tuples `(s, u, v)`, where `s` (float) are the Schmidt coefficients $\lambda_k$, and `u` (Statevector), `v` (Statevector) are the Schmidt vectors $|u_k\rangle_A$, $|u_k\rangle_B$, respectively. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if Input qargs is not a list of positions of the Input state. +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if Input qargs is not a proper subset of Input state. + + + In Qiskit, qubits are ordered using little-endian notation, with the least significant qubits having smaller indices. For example, a four-qubit system is represented as $|q_3q_2q_1q_0\rangle$. Using this convention, setting `qargs=[0]` will partition the state as $|q_3q_2q_1\rangle_A\otimes|q_0\rangle_B$. Furthermore, qubits will be organized in this notation regardless of the order they are passed. For instance, passing either `qargs=[1,2]` or `qargs=[2,1]` will result in partitioning the state as $|q_3q_0\rangle_A\otimes|q_2q_1\rangle_B$. + + +### shannon\_entropy + + + +`qiskit.quantum_info.shannon_entropy(pvec, base=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/utils.py "view source code") + +Compute the Shannon entropy of a probability vector. + +The shannon entropy of a probability vector $\vec{p} = [p_0, ..., p_{n-1}]$ is defined as + +$$ +H(\vec{p}) = \sum_{i=0}^{n-1} p_i \log_b(p_i) +$$ + +where $b$ is the log base and (default 2), and $0 \log_b(0) \equiv 0$. + +**Parameters** + +* **pvec** (*array\_like*) – a probability vector. +* **base** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the base of the logarithm \[Default: 2]. + +**Returns** + +The Shannon entropy H(pvec). + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +### commutator + + + +`qiskit.quantum_info.commutator(a, b)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/utils/commutator.py "view source code") + +Compute commutator of a and b. + +$$ +ab - ba. +$$ + +**Parameters** + +* **a** (*OperatorTypeT*) – Operator a. +* **b** (*OperatorTypeT*) – Operator b. + +**Returns** + +The commutator + +**Return type** + +*OperatorTypeT* + +### anti\_commutator + + + +`qiskit.quantum_info.anti_commutator(a, b)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/utils/anti_commutator.py "view source code") + +Compute anti-commutator of a and b. + +$$ +ab + ba. +$$ + +**Parameters** + +* **a** (*OperatorTypeT*) – Operator a. +* **b** (*OperatorTypeT*) – Operator b. + +**Returns** + +The anti-commutator + +**Return type** + +*OperatorTypeT* + +### double\_commutator + + + +`qiskit.quantum_info.double_commutator(a, b, c, *, commutator=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/utils/double_commutator.py "view source code") + +Compute symmetric double commutator of a, b and c. + +See also Equation (13.6.18) in \[1]. + +If commutator is True, it returns + +$$ +[[A, B], C]/2 + [A, [B, C]]/2 += (2ABC + 2CBA - BAC - CAB - ACB - BCA)/2. +$$ + +If commutator is False, it returns + +$$ +\lbrace[A, B], C\rbrace/2 + \lbrace A, [B, C]\rbrace/2 += (2ABC - 2CBA - BAC + CAB - ACB + BCA)/2. + + +$$ + +**Parameters** + +* **a** (*OperatorTypeT*) – Operator a. +* **b** (*OperatorTypeT*) – Operator b. +* **c** (*OperatorTypeT*) – Operator c. +* **commutator** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` compute the double commutator, if `False` the double anti-commutator. + +**Returns** + +The double commutator + +**Return type** + +*OperatorTypeT* + +**References** + +**\[1]: R. McWeeny.** + +Methods of Molecular Quantum Mechanics. 2nd Edition, Academic Press, 1992. ISBN 0-12-486552-6. + +## Random + +### random\_statevector + + + +`qiskit.quantum_info.random_statevector(dims, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/random.py "view source code") + +Generator a random Statevector. + +The statevector is sampled from the uniform distribution. This is the measure induced by the Haar measure on unitary matrices. + +**Parameters** + +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the dimensions of the state. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +the random statevector. + +**Return type** + +[Statevector](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") + +**Reference:** + +K. Zyczkowski and H. Sommers (2001), “Induced measures in the space of mixed quantum states”, [J. Phys. A: Math. Gen. 34 7111](https://arxiv.org/abs/quant-ph/0012101). + +### random\_density\_matrix + + + +`qiskit.quantum_info.random_density_matrix(dims, rank=None, method='Hilbert-Schmidt', seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/states/random.py "view source code") + +Generator a random DensityMatrix. + +**Parameters** + +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the dimensions of the DensityMatrix. +* **rank** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or None*) – Optional, the rank of the density matrix. The default value is full-rank. +* **method** (*string*) – Optional. The method to use. ‘Hilbert-Schmidt’: (Default) sample from the Hilbert-Schmidt metric. ‘Bures’: sample from the Bures metric. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +the random density matrix. + +**Return type** + +[DensityMatrix](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the method is not valid. + +### random\_unitary + + + +`qiskit.quantum_info.random_unitary(dims, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/random.py "view source code") + +Return a random unitary Operator. + +The operator is sampled from the unitary Haar measure. + +**Parameters** + +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input dimensions of the Operator. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +a unitary operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +### random\_hermitian + + + +`qiskit.quantum_info.random_hermitian(dims, traceless=False, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/random.py "view source code") + +Return a random hermitian Operator. + +The operator is sampled from Gaussian Unitary Ensemble. + +**Parameters** + +* **dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input dimension of the Operator. +* **traceless** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional. If True subtract diagonal entries to return a traceless hermitian operator (Default: False). +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +a Hermitian operator. + +**Return type** + +[Operator](qiskit.quantum_info.Operator "qiskit.quantum_info.Operator") + +### random\_pauli + + + +`qiskit.quantum_info.random_pauli(num_qubits, group_phase=False, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/random.py "view source code") + +Return a random Pauli. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits. +* **group\_phase** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Optional. If True generate random phase. Otherwise the phase will be set so that the Pauli coefficient is +1 (default: False). +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +a random Pauli + +**Return type** + +[Pauli](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") + +### random\_clifford + + + +`qiskit.quantum_info.random_clifford(num_qubits, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/random.py "view source code") + +Return a random Clifford operator. + +The Clifford is sampled using the method of Reference \[1]. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits for the Clifford +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +a random Clifford operator. + +**Return type** + +[Clifford](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") + +**Reference:** + +1. S. Bravyi and D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*. [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) + +### random\_quantum\_channel + + + +`qiskit.quantum_info.random_quantum_channel(input_dims=None, output_dims=None, rank=None, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/random.py "view source code") + +Return a random CPTP quantum channel. + +This constructs the Stinespring operator for the quantum channel by sampling a random isometry from the unitary Haar measure. + +**Parameters** + +* **input\_dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input dimension of the channel. +* **output\_dims** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or*[*tuple*](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")) – the input dimension of the channel. +* **rank** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The rank of the quantum channel Choi-matrix. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +a quantum channel operator. + +**Return type** + +[Stinespring](qiskit.quantum_info.Stinespring "qiskit.quantum_info.Stinespring") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if rank or dimensions are invalid. + +### random\_cnotdihedral + + + +`qiskit.quantum_info.random_cnotdihedral(num_qubits, seed=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/dihedral/random.py "view source code") + +Return a random CNOTDihedral element. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits for the CNOTDihedral object. +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or RandomState*) – Optional. Set a fixed seed or generator for RNG. + +**Returns** + +a random CNOTDihedral element. + +**Return type** + +[CNOTDihedral](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral") + +### random\_pauli\_list + + + +`qiskit.quantum_info.random_pauli_list(num_qubits, size=1, seed=None, phase=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/operators/symplectic/random.py "view source code") + +Return a random PauliList. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the number of qubits. +* **size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Optional. The length of the Pauli list (Default: 1). +* **seed** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *or np.random.Generator*) – Optional. Set a fixed seed or generator for RNG. +* **phase** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True the Pauli phases are randomized, otherwise the phases are fixed to 0. \[Default: True] + +**Returns** + +a random PauliList. + +**Return type** + +[PauliList](qiskit.quantum_info.PauliList "qiskit.quantum_info.PauliList") + +## Analysis + +### hellinger\_distance + + + +`qiskit.quantum_info.hellinger_distance(dist_p, dist_q)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/analysis/distance.py "view source code") + +Computes the Hellinger distance between two counts distributions. + +**Parameters** + +* **dist\_p** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – First dict of counts. +* **dist\_q** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Second dict of counts. + +**Returns** + +Distance + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**References** + +[Hellinger Distance @ wikipedia](https://en.wikipedia.org/wiki/Hellinger_distance) + +### hellinger\_fidelity + + + +`qiskit.quantum_info.hellinger_fidelity(dist_p, dist_q)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/quantum_info/analysis/distance.py "view source code") + +Computes the Hellinger fidelity between two counts distributions. + +The fidelity is defined as $\left(1-H^{2}\right)^{2}$ where H is the Hellinger distance. This value is bounded in the range \[0, 1]. + +This is equivalent to the standard classical fidelity $F(Q,P)=\left(\sum_{i}\sqrt{p_{i}q_{i}}\right)^{2}$ that in turn is equal to the quantum state fidelity for diagonal density matrices. + +**Parameters** + +* **dist\_p** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – First dict of counts. +* **dist\_q** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Second dict of counts. + +**Returns** + +Fidelity + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Example** + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info.analysis import hellinger_fidelity +from qiskit.providers.basic_provider import BasicSimulator + +qc = QuantumCircuit(5, 5) +qc.h(2) +qc.cx(2, 1) +qc.cx(2, 3) +qc.cx(3, 4) +qc.cx(1, 0) +qc.measure(range(5), range(5)) + +sim = BasicSimulator() +res1 = sim.run(qc).result() +res2 = sim.run(qc).result() + +hellinger_fidelity(res1.get_counts(), res2.get_counts()) +``` + +**References** + +[Quantum Fidelity @ wikipedia](https://en.wikipedia.org/wiki/Fidelity_of_quantum_states) [Hellinger Distance @ wikipedia](https://en.wikipedia.org/wiki/Hellinger_distance) + +| | | +| ----------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| [`Z2Symmetries`](qiskit.quantum_info.Z2Symmetries "qiskit.quantum_info.Z2Symmetries")(symmetries, sq\_paulis, sq\_list) | The \$Z\_2\$ symmetry converter identifies symmetries from the problem hamiltonian and uses them to provide a tapered - more efficient - representation of operators as Paulis for this problem. | + diff --git a/docs/api/qiskit/0.46/result.md b/docs/api/qiskit/0.46/result.md new file mode 100644 index 00000000000..3d0e674bce6 --- /dev/null +++ b/docs/api/qiskit/0.46/result.md @@ -0,0 +1,160 @@ +--- +title: result +description: API reference for qiskit.result +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.result +--- + + + + + + + +# Experiment Results + + + +`qiskit.result` + +| | | +| ----------------------------------------------------------------------------------------------------- | ---------------------------------------------------------- | +| [`Result`](qiskit.result.Result "qiskit.result.Result")(backend\_name, backend\_version, ...\[, ...]) | Model for Results. | +| [`ResultError`](qiskit.result.ResultError "qiskit.result.ResultError")(error) | Exceptions raised due to errors in result output. | +| [`Counts`](qiskit.result.Counts "qiskit.result.Counts")(data\[, time\_taken, creg\_sizes, ...]) | A class to store a counts result from a circuit execution. | + +### marginal\_counts + + + +`qiskit.result.marginal_counts(result, indices=None, inplace=False, format_marginal=False, marginalize_memory=True)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/utils.py "view source code") + +Marginalize counts from an experiment over some indices of interest. + +**Parameters** + +* **result** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") *|*[*Result*](qiskit.result.Result "qiskit.result.result.Result")) – result to be marginalized (a Result object or a dict(str, int) of counts). +* **indices** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – The bit positions of interest to marginalize over. If `None` (default), do not marginalize at all. +* **inplace** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Default: False. Operates on the original Result argument if True, leading to loss of original Job Result. It has no effect if `result` is a dict. +* **format\_marginal** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Default: False. If True, takes the output of marginalize and formats it with placeholders between cregs and for non-indices. +* **marginalize\_memory** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") *| None*) – If True, then also marginalize the memory field (if present). If False, remove the memory field from the result. If None, leave the memory field as is. + +**Returns** + +**A Result object or a dictionary with** + +the observed counts, marginalized to only account for frequency of observations of bits of interest. + +**Return type** + +[Result](qiskit.result.Result "qiskit.result.Result") or [dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")([str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – in case of invalid indices to marginalize over. + +### marginal\_distribution + + + +`qiskit.result.marginal_distribution(counts, indices=None, format_marginal=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/utils.py "view source code") + +Marginalize counts from an experiment over some indices of interest. + +Unlike [`marginal_counts()`](#qiskit.result.marginal_counts "qiskit.result.marginal_counts") this function respects the order of the input `indices`. If the input `indices` list is specified then the order the bit indices are specified will be the output order of the bitstrings in the marginalized output. + +**Parameters** + +* **counts** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – result to be marginalized +* **indices** ([*Sequence*](https://docs.python.org/3/library/typing.html#typing.Sequence "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – The bit positions of interest to marginalize over. If `None` (default), do not marginalize at all. +* **format\_marginal** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Default: False. If True, takes the output of marginalize and formats it with placeholders between cregs and for non-indices. + +**Returns** + +A marginalized dictionary + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")([str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)"), [int](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If any value in `indices` is invalid or the `counts` dict +* **is invalid.** – + +### marginal\_memory + + + +`qiskit.result.marginal_memory(memory, indices=None, int_return=False, hex_return=False, avg_data=False, parallel_threshold=1000)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/utils.py "view source code") + +Marginalize shot memory + +This function is multithreaded and will launch a thread pool with threads equal to the number of CPUs by default. You can tune the number of threads with the `RAYON_NUM_THREADS` environment variable. For example, setting `RAYON_NUM_THREADS=4` would limit the thread pool to 4 threads. + +**Parameters** + +* **memory** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*] |* [*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – The input memory list, this is either a list of hexadecimal strings to be marginalized representing measure level 2 memory or a numpy array representing level 0 measurement memory (single or avg) or level 1 measurement memory (single or avg). +* **indices** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*] | None*) – The bit positions of interest to marginalize over. If `None` (default), do not marginalize at all. +* **int\_return** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `True` the output will be a list of integers. By default the return type is a bit string. This and `hex_return` are mutually exclusive and can not be specified at the same time. This option only has an effect with memory level 2. +* **hex\_return** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to `True` the output will be a list of hexadecimal strings. By default the return type is a bit string. This and `int_return` are mutually exclusive and can not be specified at the same time. This option only has an effect with memory level 2. +* **avg\_data** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If a 2 dimensional numpy array is passed in for `memory` this can be set to `True` to indicate it’s a avg level 0 data instead of level 1 single data. +* **parallel\_threshold** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The number of elements in `memory` to start running in multiple threads. If `len(memory)` is >= this value, the function will run in multiple threads. By default this is set to 1000. + +**Returns** + +The list of marginalized memory + +**Return type** + +marginal\_memory + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if both `int_return` and `hex_return` are set to `True` + +## Distributions + +| | | +| ------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------- | +| [`ProbDistribution`](qiskit.result.ProbDistribution "qiskit.result.ProbDistribution")(data\[, shots]) | A generic dict-like class for probability distributions. | +| [`QuasiDistribution`](qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution")(data\[, shots, ...]) | A dict-like class for representing quasi-probabilities. | + +## Expectation values + +### sampled\_expectation\_value + + + +`qiskit.result.sampled_expectation_value(dist, oper)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/result/sampled_expval.py "view source code") + +Computes expectation value from a sampled distribution + +Note that passing a raw dict requires bit-string keys. + +**Parameters** + +* **dist** ([*Counts*](qiskit.result.Counts "qiskit.result.Counts") *or*[*QuasiDistribution*](qiskit.result.QuasiDistribution "qiskit.result.QuasiDistribution") *or*[*ProbDistribution*](qiskit.result.ProbDistribution "qiskit.result.ProbDistribution") *or*[*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Input sampled distribution +* **oper** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*Pauli*](qiskit.quantum_info.Pauli "qiskit.quantum_info.Pauli") *or*[*PauliOp*](qiskit.opflow.primitive_ops.PauliOp "qiskit.opflow.primitive_ops.PauliOp") *or*[*PauliSumOp*](qiskit.opflow.primitive_ops.PauliSumOp "qiskit.opflow.primitive_ops.PauliSumOp") *or*[*SparsePauliOp*](qiskit.quantum_info.SparsePauliOp "qiskit.quantum_info.SparsePauliOp")) – The operator for the observable + +**Returns** + +The expectation value + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input distribution or operator is an invalid type + +## Mitigation + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------- | +| [`BaseReadoutMitigator`](qiskit.result.BaseReadoutMitigator "qiskit.result.BaseReadoutMitigator")() | Base readout error mitigator class. | +| [`CorrelatedReadoutMitigator`](qiskit.result.CorrelatedReadoutMitigator "qiskit.result.CorrelatedReadoutMitigator")(assignment\_matrix) | N-qubit readout error mitigator. | +| [`LocalReadoutMitigator`](qiskit.result.LocalReadoutMitigator "qiskit.result.LocalReadoutMitigator")(\[assignment\_matrices, ...]) | 1-qubit tensor product readout error mitigator. | + diff --git a/docs/api/qiskit/0.46/scheduler.md b/docs/api/qiskit/0.46/scheduler.md new file mode 100644 index 00000000000..eb0d6427858 --- /dev/null +++ b/docs/api/qiskit/0.46/scheduler.md @@ -0,0 +1,122 @@ +--- +title: scheduler +description: API reference for qiskit.scheduler +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.scheduler +--- + + + + + + + +# Circuit Scheduler + + + +`qiskit.scheduler` + +A circuit scheduler compiles a circuit program to a pulse program. + + + +`qiskit.scheduler.ScheduleConfig(inst_map, meas_map, dt)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/scheduler/config.py "view source code") + +Configuration for pulse scheduling. + +Container for information needed to schedule a QuantumCircuit into a pulse Schedule. + +**Parameters** + +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.instruction_schedule_map.InstructionScheduleMap")) – The schedule definition of all gates supported on a backend. +* **meas\_map** ([*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*List*](https://docs.python.org/3/library/typing.html#typing.List "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*]]*) – A list of groups of qubits which have to be measured together. +* **dt** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Sample duration. + +### schedule\_circuit + + + +`qiskit.scheduler.schedule_circuit.schedule_circuit(circuit, schedule_config, method=None, backend=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/scheduler/schedule_circuit.py "view source code") + +Basic scheduling pass from a circuit to a pulse Schedule, using the backend. If no method is specified, then a basic, as late as possible scheduling pass is performed, i.e. pulses are scheduled to occur as late as possible. + +Supported methods: + +> * `'as_soon_as_possible'`: Schedule pulses greedily, as early as possible on a qubit resource. (alias: `'asap'`) +> * `'as_late_as_possible'`: Schedule pulses late– keep qubits in the ground state when possible. (alias: `'alap'`) + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The quantum circuit to translate. +* **schedule\_config** ([*ScheduleConfig*](#qiskit.scheduler.ScheduleConfig "qiskit.scheduler.config.ScheduleConfig")) – Backend specific parameters used for building the Schedule. +* **method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The scheduling pass method to use. +* **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.backend.BackendV1") *|*[*BackendV2*](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") *| None*) – A backend used to build the Schedule, the backend could be BackendV1 or BackendV2. + +**Returns** + +Schedule corresponding to the input circuit. + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If method isn’t recognized. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + + + +Pulse scheduling methods. + +### as\_soon\_as\_possible + + + +`qiskit.scheduler.methods.as_soon_as_possible(circuit, schedule_config, backend=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/scheduler/methods/basic.py "view source code") + +Return the pulse Schedule which implements the input circuit using an “as soon as possible” (asap) scheduling policy. + +Circuit instructions are first each mapped to equivalent pulse Schedules according to the command definition given by the schedule\_config. Then, this circuit instruction-equivalent Schedule is appended at the earliest time at which all qubits involved in the instruction are available. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The quantum circuit to translate. +* **schedule\_config** ([*ScheduleConfig*](#qiskit.scheduler.ScheduleConfig "qiskit.scheduler.config.ScheduleConfig")) – Backend specific parameters used for building the Schedule. +* **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.backend.BackendV1") *|*[*BackendV2*](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") *| None*) – A backend used to build the Schedule, the backend could be BackendV1 or BackendV2. + +**Returns** + +A schedule corresponding to the input `circuit` with pulses occurring as early as possible. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + +### as\_late\_as\_possible + + + +`qiskit.scheduler.methods.as_late_as_possible(circuit, schedule_config, backend=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/scheduler/methods/basic.py "view source code") + +Return the pulse Schedule which implements the input circuit using an “as late as possible” (alap) scheduling policy. + +Circuit instructions are first each mapped to equivalent pulse Schedules according to the command definition given by the schedule\_config. Then, this circuit instruction-equivalent Schedule is appended at the latest time that it can be without allowing unnecessary time between instructions or allowing instructions with common qubits to overlap. + +This method should improves the outcome fidelity over ASAP scheduling, because we may maximize the time that the qubit remains in the ground state. + +**Parameters** + +* **circuit** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.quantumcircuit.QuantumCircuit")) – The quantum circuit to translate. +* **schedule\_config** ([*ScheduleConfig*](#qiskit.scheduler.ScheduleConfig "qiskit.scheduler.config.ScheduleConfig")) – Backend specific parameters used for building the Schedule. +* **backend** ([*BackendV1*](qiskit.providers.BackendV1 "qiskit.providers.backend.BackendV1") *|*[*BackendV2*](qiskit.providers.BackendV2 "qiskit.providers.backend.BackendV2") *| None*) – A backend used to build the Schedule, the backend could be BackendV1 or BackendV2. + +**Returns** + +A schedule corresponding to the input `circuit` with pulses occurring as late as possible. + +**Return type** + +[*Schedule*](qiskit.pulse.Schedule "qiskit.pulse.schedule.Schedule") + diff --git a/docs/api/qiskit/0.46/synthesis.md b/docs/api/qiskit/0.46/synthesis.md new file mode 100644 index 00000000000..bb841c6ed7c --- /dev/null +++ b/docs/api/qiskit/0.46/synthesis.md @@ -0,0 +1,729 @@ +--- +title: synthesis +description: API reference for qiskit.synthesis +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.synthesis +--- + + + + + + + +# Circuit Synthesis + + + +`qiskit.synthesis` + + + +## Evolution Synthesis + +| | | +| ---------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------- | +| [`EvolutionSynthesis`](qiskit.synthesis.EvolutionSynthesis "qiskit.synthesis.EvolutionSynthesis")() | Interface for evolution synthesis algorithms. | +| [`ProductFormula`](qiskit.synthesis.ProductFormula "qiskit.synthesis.ProductFormula")(order\[, reps, ...]) | Product formula base class for the decomposition of non-commuting operator exponentials. | +| [`LieTrotter`](qiskit.synthesis.LieTrotter "qiskit.synthesis.LieTrotter")(\[reps, insert\_barriers, ...]) | The Lie-Trotter product formula. | +| [`SuzukiTrotter`](qiskit.synthesis.SuzukiTrotter "qiskit.synthesis.SuzukiTrotter")(\[order, reps, ...]) | The (higher order) Suzuki-Trotter product formula. | +| [`MatrixExponential`](qiskit.synthesis.MatrixExponential "qiskit.synthesis.MatrixExponential")() | Exact operator evolution via matrix exponentiation and unitary synthesis. | +| [`QDrift`](qiskit.synthesis.QDrift "qiskit.synthesis.QDrift")(\[reps, insert\_barriers, ...]) | The QDrift Trotterization method, which selects each each term in the Trotterization randomly, with a probability proportional to its weight. | + +## Linear Function Synthesis + +### synth\_cnot\_count\_full\_pmh + + + +`qiskit.synthesis.synth_cnot_count_full_pmh(state, section_size=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/linear/cnot_synth.py "view source code") + +Synthesize linear reversible circuits for all-to-all architecture using Patel, Markov and Hayes method. + +This function is an implementation of the Patel, Markov and Hayes algorithm from \[1] for optimal synthesis of linear reversible circuits for all-to-all architecture, as specified by an n x n matrix. + +**Parameters** + +* **state** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*] or ndarray*) – n x n boolean invertible matrix, describing the state of the input circuit +* **section\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the size of each section, used in the Patel–Markov–Hayes algorithm \[1]. section\_size must be a factor of num\_qubits. + +**Returns** + +a CX-only circuit implementing the linear transformation. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – when variable “state” isn’t of type numpy.ndarray + +**References** + +1. Patel, Ketan N., Igor L. Markov, and John P. Hayes, *Optimal synthesis of linear reversible circuits*, Quantum Information & Computation 8.3 (2008): 282-294. [arXiv:quant-ph/0302002 \[quant-ph\]](https://arxiv.org/abs/quant-ph/0302002) + +### synth\_cnot\_depth\_line\_kms + + + +`qiskit.synthesis.synth_cnot_depth_line_kms(mat)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/linear/linear_depth_lnn.py "view source code") + +Synthesize linear reversible circuit for linear nearest-neighbor architectures using Kutin, Moulton, Smithline method. + +Synthesis algorithm for linear reversible circuits from \[1], Chapter 7. Synthesizes any linear reversible circuit of n qubits over linear nearest-neighbor architecture using CX gates with depth at most 5\*n. + +**Parameters** + +**mat** (*np.ndarray]*) – A boolean invertible matrix. + +**Returns** + +the synthesized quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if mat is not invertible. + +**References** + +1. Kutin, S., Moulton, D. P., Smithline, L., *Computation at a distance*, Chicago J. Theor. Comput. Sci., vol. 2007, (2007), [arXiv:quant-ph/0701194](https://arxiv.org/abs/quant-ph/0701194) + +## Linear-Phase Synthesis + +### synth\_cz\_depth\_line\_mr + + + +`qiskit.synthesis.synth_cz_depth_line_mr(mat)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/linear_phase/cz_depth_lnn.py "view source code") + +Synthesis of a CZ circuit for linear nearest neighbour (LNN) connectivity, based on Maslov and Roetteler. + +Note that this method *reverts* the order of qubits in the circuit, and returns a circuit containing CX and phase (S, Sdg or Z) gates. + +**Parameters** + +**mat** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – an upper-diagonal matrix representing the CZ circuit. mat\[i]\[j]=1 for i\ + +`qiskit.synthesis.synth_cx_cz_depth_line_my(mat_x, mat_z)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/linear_phase/cx_cz_depth_lnn.py "view source code") + +Joint synthesis of a -CZ-CX- circuit for linear nearest neighbour (LNN) connectivity, with 2-qubit depth at most 5n, based on Maslov and Yang. This method computes the CZ circuit inside the CX circuit via phase gate insertions. + +**Parameters** + +* **mat\_z** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a boolean symmetric matrix representing a CZ circuit. Mz\[i]\[j]=1 represents a CZ(i,j) gate +* **mat\_x** ([*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)")) – a boolean invertible matrix representing a CX circuit. + +**Returns** + +a circuit implementation of a CX circuit following a CZ circuit, denoted as a -CZ-CX- circuit,in two-qubit depth at most 5n, for LNN connectivity. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Reference:** + +1. Kutin, S., Moulton, D. P., Smithline, L., *Computation at a distance*, Chicago J. Theor. Comput. Sci., vol. 2007, (2007), [arXiv:quant-ph/0701194](https://arxiv.org/abs/quant-ph/0701194) +2. Dmitri Maslov, Willers Yang, *CNOT circuits need little help to implement arbitrary Hadamard-free Clifford transformations they generate*, [arXiv:2210.16195](https://arxiv.org/abs/2210.16195). + +### synth\_cnot\_phase\_aam + + + +`qiskit.synthesis.synth_cnot_phase_aam(cnots, angles, section_size=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/linear_phase/cnot_phase_synth.py "view source code") + +This function is an implementation of the GraySynth algorithm of Amy, Azimadeh and Mosca. + +GraySynth is a heuristic algorithm from \[1] for synthesizing small parity networks. It is inspired by Gray codes. Given a set of binary strings S (called “cnots” bellow), the algorithm synthesizes a parity network for S by repeatedly choosing an index i to expand and then effectively recursing on the co-factors S\_0 and S\_1, consisting of the strings y in S, with y\_i = 0 or 1 respectively. As a subset S is recursively expanded, CNOT gates are applied so that a designated target bit contains the (partial) parity ksi\_y(x) where y\_i = 1 if and only if y’\_i = 1 for all y’ in S. If S is a singleton \{y’}, then y = y’, hence the target bit contains the value ksi\_y’(x) as desired. + +Notably, rather than uncomputing this sequence of CNOT gates when a subset S is finished being synthesized, the algorithm maintains the invariant that the remaining parities to be computed are expressed over the current state of bits. This allows the algorithm to avoid the ‘backtracking’ inherent in uncomputing-based methods. + +The algorithm is described in detail in section 4 of \[1]. + +**Parameters** + +* **cnots** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*]*) – + + a matrix whose columns are the parities to be synthesized e.g.: + + ```python + [[0, 1, 1, 1, 1, 1], + [1, 0, 0, 1, 1, 1], + [1, 0, 0, 1, 0, 0], + [0, 0, 1, 0, 1, 0]] + ``` + + corresponds to: + + ```python + x1^x2 + x0 + x0^x3 + x0^x1^x2 + x0^x1^x3 + x0^x1 + ``` + +* **angles** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – a list containing all the phase-shift gates which are to be applied, in the same order as in “cnots”. A number is interpreted as the angle of p(angle), otherwise the elements have to be ‘t’, ‘tdg’, ‘s’, ‘sdg’ or ‘z’. + +* **section\_size** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – the size of every section, used in \_lwr\_cnot\_synth(), in the Patel–Markov–Hayes algorithm. section\_size must be a factor of num\_qubits. + +**Returns** + +the decomposed quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – when dimensions of cnots and angles don’t align. + +**References** + +1. Matthew Amy, Parsiad Azimzadeh, and Michele Mosca. *On the controlled-NOT complexity of controlled-NOT–phase circuits.*, Quantum Science and Technology 4.1 (2018): 015002. [arXiv:1712.01859](https://arxiv.org/abs/1712.01859) + +## Permutation Synthesis + +### synth\_permutation\_depth\_lnn\_kms + + + +`qiskit.synthesis.synth_permutation_depth_lnn_kms(pattern)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/permutation/permutation_lnn.py "view source code") + +Synthesize a permutation circuit for a linear nearest-neighbor architecture using the Kutin, Moulton, Smithline method. + +This is the permutation synthesis algorithm from [https://arxiv.org/abs/quant-ph/0701194](https://arxiv.org/abs/quant-ph/0701194), Chapter 6. It synthesizes any permutation of n qubits over linear nearest-neighbor architecture using SWAP gates with depth at most n and size at most n(n-1)/2 (where both depth and size are measured with respect to SWAPs). + +**Parameters** + +**pattern** (*Union\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*], np.ndarray]*) – permutation pattern, describing which qubits occupy the positions 0, 1, 2, etc. after applying the permutation. That is, `pattern[k] = m` when the permutation maps qubit `m` to position `k`. As an example, the pattern `[2, 4, 3, 0, 1]` means that qubit `2` goes to position `0`, qubit `4` goes to position `1`, etc. + +**Returns** + +the synthesized quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### synth\_permutation\_basic + + + +`qiskit.synthesis.synth_permutation_basic(pattern)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/permutation/permutation_full.py "view source code") + +Synthesize a permutation circuit for a fully-connected architecture using sorting. + +More precisely, if the input permutation is a cycle of length `m`, then this creates a quantum circuit with `m-1` SWAPs (and of depth `m-1`); if the input permutation consists of several disjoint cycles, then each cycle is essentially treated independently. + +**Parameters** + +**pattern** (*Union\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*], np.ndarray]*) – permutation pattern, describing which qubits occupy the positions 0, 1, 2, etc. after applying the permutation. That is, `pattern[k] = m` when the permutation maps qubit `m` to position `k`. As an example, the pattern `[2, 4, 3, 0, 1]` means that qubit `2` goes to position `0`, qubit `4` goes to position `1`, etc. + +**Returns** + +the synthesized quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +### synth\_permutation\_acg + + + +`qiskit.synthesis.synth_permutation_acg(pattern)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/permutation/permutation_full.py "view source code") + +Synthesize a permutation circuit for a fully-connected architecture using the Alon, Chung, Graham method. + +This produces a quantum circuit of depth 2 (measured in the number of SWAPs). + +This implementation is based on the Theorem 2 in the paper “Routing Permutations on Graphs Via Matchings” (1993), available at [https://www.cs.tau.ac.il/\~nogaa/PDFS/r.pdf](https://www.cs.tau.ac.il/~nogaa/PDFS/r.pdf). + +**Parameters** + +**pattern** (*Union\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")*], np.ndarray]*) – permutation pattern, describing which qubits occupy the positions 0, 1, 2, etc. after applying the permutation. That is, `pattern[k] = m` when the permutation maps qubit `m` to position `k`. As an example, the pattern `[2, 4, 3, 0, 1]` means that qubit `2` goes to position `0`, qubit `4` goes to position `1`, etc. + +**Returns** + +the synthesized quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +## Clifford Synthesis + +### synth\_clifford\_full + + + +`qiskit.synthesis.synth_clifford_full(clifford, method=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/clifford/clifford_decompose_full.py "view source code") + +Decompose a Clifford operator into a QuantumCircuit. + +For N \<= 3 qubits this is based on optimal CX cost decomposition from reference \[1]. For N > 3 qubits this is done using the general non-optimal greedy compilation routine from reference \[3], which typically yields better CX cost compared to the AG method in \[2]. + +**Parameters** + +* **clifford** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a clifford operator. +* **method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Optional, a synthesis method (‘AG’ or ‘greedy’). If set this overrides optimal decomposition for N \<=3 qubits. + +**Returns** + +a circuit implementation of the Clifford. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**References** + +1. S. Bravyi, D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*, [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) +2. S. Aaronson, D. Gottesman, *Improved Simulation of Stabilizer Circuits*, Phys. Rev. A 70, 052328 (2004). [arXiv:quant-ph/0406196](https://arxiv.org/abs/quant-ph/0406196) +3. Sergey Bravyi, Shaohan Hu, Dmitri Maslov, Ruslan Shaydulin, *Clifford Circuit Optimization with Templates and Symbolic Pauli Gates*, [arXiv:2105.02291 \[quant-ph\]](https://arxiv.org/abs/2105.02291) + +### synth\_clifford\_ag + + + +`qiskit.synthesis.synth_clifford_ag(clifford)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/clifford/clifford_decompose_ag.py "view source code") + +Decompose a Clifford operator into a QuantumCircuit based on Aaronson-Gottesman method. + +**Parameters** + +**clifford** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a clifford operator. + +**Returns** + +a circuit implementation of the Clifford. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Reference:** + +1. S. Aaronson, D. Gottesman, *Improved Simulation of Stabilizer Circuits*, Phys. Rev. A 70, 052328 (2004). [arXiv:quant-ph/0406196](https://arxiv.org/abs/quant-ph/0406196) + +### synth\_clifford\_bm + + + +`qiskit.synthesis.synth_clifford_bm(clifford)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/clifford/clifford_decompose_bm.py "view source code") + +Optimal CX-cost decomposition of a Clifford operator on 2-qubits or 3-qubits into a QuantumCircuit based on Bravyi-Maslov method. + +**Parameters** + +**clifford** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a clifford operator. + +**Returns** + +a circuit implementation of the Clifford. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if clifford is on more than 3 qubits. + +**Reference:** + +1. S. Bravyi, D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*, [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) + +### synth\_clifford\_greedy + + + +`qiskit.synthesis.synth_clifford_greedy(clifford)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/clifford/clifford_decompose_greedy.py "view source code") + +Decompose a Clifford operator into a QuantumCircuit based on the greedy Clifford compiler that is described in Appendix A of Bravyi, Hu, Maslov and Shaydulin. + +This method typically yields better CX cost compared to the Aaronson-Gottesman method. + +**Parameters** + +**clifford** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a clifford operator. + +**Returns** + +a circuit implementation of the Clifford. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if symplectic Gaussian elimination fails. + +**Reference:** + +1. Sergey Bravyi, Shaohan Hu, Dmitri Maslov, Ruslan Shaydulin, *Clifford Circuit Optimization with Templates and Symbolic Pauli Gates*, [arXiv:2105.02291 \[quant-ph\]](https://arxiv.org/abs/2105.02291) + +### synth\_clifford\_layers + + + +`qiskit.synthesis.synth_clifford_layers(cliff, cx_synth_func=, cz_synth_func=, cx_cz_synth_func=None, cz_func_reverse_qubits=False, validate=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/clifford/clifford_decompose_layers.py "view source code") + +Synthesis of a Clifford into layers, it provides a similar decomposition to the synthesis described in Lemma 8 of Bravyi and Maslov. + +For example, a 5-qubit Clifford circuit is decomposed into the following layers: + +```python + ┌─────┐┌─────┐┌────────┐┌─────┐┌─────┐┌─────┐┌─────┐┌────────┐ +q_0: ┤0 ├┤0 ├┤0 ├┤0 ├┤0 ├┤0 ├┤0 ├┤0 ├ + │ ││ ││ ││ ││ ││ ││ ││ │ +q_1: ┤1 ├┤1 ├┤1 ├┤1 ├┤1 ├┤1 ├┤1 ├┤1 ├ + │ ││ ││ ││ ││ ││ ││ ││ │ +q_2: ┤2 S2 ├┤2 CZ ├┤2 CX_dg ├┤2 H2 ├┤2 S1 ├┤2 CZ ├┤2 H1 ├┤2 Pauli ├ + │ ││ ││ ││ ││ ││ ││ ││ │ +q_3: ┤3 ├┤3 ├┤3 ├┤3 ├┤3 ├┤3 ├┤3 ├┤3 ├ + │ ││ ││ ││ ││ ││ ││ ││ │ +q_4: ┤4 ├┤4 ├┤4 ├┤4 ├┤4 ├┤4 ├┤4 ├┤4 ├ + └─────┘└─────┘└────────┘└─────┘└─────┘└─────┘└─────┘└────────┘ +``` + +This decomposition is for the default cz\_synth\_func and cx\_synth\_func functions, with other functions one may see slightly different decomposition. + +**Parameters** + +* **cliff** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a clifford operator. +* **cx\_synth\_func** (*Callable*) – a function to decompose the CX sub-circuit. It gets as input a boolean invertible matrix, and outputs a QuantumCircuit. +* **cz\_synth\_func** (*Callable*) – a function to decompose the CZ sub-circuit. It gets as input a boolean symmetric matrix, and outputs a QuantumCircuit. +* **cx\_cz\_synth\_func** (*Callable*) – optional, a function to decompose both sub-circuits CZ and CX. +* **validate** (*Boolean*) – if True, validates the synthesis process. +* **cz\_func\_reverse\_qubits** (*Boolean*) – True only if cz\_synth\_func is synth\_cz\_depth\_line\_mr, since this function returns a circuit that reverts the order of qubits. + +**Returns** + +a circuit implementation of the Clifford. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Reference:** + +1. S. Bravyi, D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*, [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) + +### synth\_clifford\_depth\_lnn + + + +`qiskit.synthesis.synth_clifford_depth_lnn(cliff)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/clifford/clifford_decompose_layers.py "view source code") + +Synthesis of a Clifford into layers for linear-nearest neighbour connectivity. + +The depth of the synthesized n-qubit circuit is bounded by 7\*n+2, which is not optimal. It should be replaced by a better algorithm that provides depth bounded by 7\*n-4 \[3]. + +**Parameters** + +**cliff** ([*Clifford*](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford")) – a clifford operator. + +**Returns** + +a circuit implementation of the Clifford. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Reference:** + +1. S. Bravyi, D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*, [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) +2. Dmitri Maslov, Martin Roetteler, *Shorter stabilizer circuits via Bruhat decomposition and quantum circuit transformations*, [arXiv:1705.09176](https://arxiv.org/abs/1705.09176). +3. Dmitri Maslov, Willers Yang, *CNOT circuits need little help to implement arbitrary Hadamard-free Clifford transformations they generate*, [arXiv:2210.16195](https://arxiv.org/abs/2210.16195). + +## CNOTDihedral Synthesis + +### synth\_cnotdihedral\_full + + + +`qiskit.synthesis.synth_cnotdihedral_full(elem)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_full.py "view source code") + +Decompose a CNOTDihedral element into a QuantumCircuit. For N \<= 2 qubits this is based on optimal CX cost decomposition from reference \[1]. For N > 2 qubits this is done using the general non-optimal compilation routine from reference \[2]. + +**Parameters** + +**elem** ([*CNOTDihedral*](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral")) – a CNOTDihedral element. + +**Returns** + +a circuit implementation of the CNOTDihedral element. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**References** + +1. Shelly Garion and Andrew W. Cross, *Synthesis of CNOT-Dihedral circuits with optimal number of two qubit gates*, [Quantum 4(369), 2020](https://quantum-journal.org/papers/q-2020-12-07-369/) +2. Andrew W. Cross, Easwar Magesan, Lev S. Bishop, John A. Smolin and Jay M. Gambetta, *Scalable randomised benchmarking of non-Clifford gates*, npj Quantum Inf 2, 16012 (2016). + +### synth\_cnotdihedral\_two\_qubits + + + +`qiskit.synthesis.synth_cnotdihedral_two_qubits(elem)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_two_qubits.py "view source code") + +Decompose a CNOTDihedral element on a single qubit and two qubits into a QuantumCircuit. This decomposition has an optimal number of CX gates. + +**Parameters** + +**elem** ([*CNOTDihedral*](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral")) – a CNOTDihedral element. + +**Returns** + +a circuit implementation of the CNOTDihedral element. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the element in not 1-qubit or 2-qubit CNOTDihedral. + +**Reference:** + +1. Shelly Garion and Andrew W. Cross, *On the structure of the CNOT-Dihedral group*, [arXiv:2006.12042 \[quant-ph\]](https://arxiv.org/abs/2006.12042) + +### synth\_cnotdihedral\_general + + + +`qiskit.synthesis.synth_cnotdihedral_general(elem)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/cnotdihedral/cnotdihedral_decompose_general.py "view source code") + +Decompose a CNOTDihedral element into a QuantumCircuit. + +Decompose a general CNOTDihedral elements. The number of CNOT gates is not necessarily optimal. For a decomposition of a 1-qubit or 2-qubit element, call synth\_cnotdihedral\_two\_qubits. + +**Parameters** + +**elem** ([*CNOTDihedral*](qiskit.quantum_info.CNOTDihedral "qiskit.quantum_info.CNOTDihedral")) – a CNOTDihedral element. + +**Returns** + +a circuit implementation of the CNOTDihedral element. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the element could not be decomposed into a circuit. + +**Reference:** + +1. Andrew W. Cross, Easwar Magesan, Lev S. Bishop, John A. Smolin and Jay M. Gambetta, *Scalable randomised benchmarking of non-Clifford gates*, npj Quantum Inf 2, 16012 (2016). + +## Stabilizer State Synthesis + +### synth\_stabilizer\_layers + + + +`qiskit.synthesis.synth_stabilizer_layers(stab, cz_synth_func=, cz_func_reverse_qubits=False, validate=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/stabilizer/stabilizer_decompose.py "view source code") + +Synthesis of a stabilizer state into layers. + +It provides a similar decomposition to the synthesis described in Lemma 8 of Bravyi and Maslov, without the initial Hadamard-free sub-circuit which do not affect the stabilizer state. + +For example, a 5-qubit stabilizer state is decomposed into the following layers: + +```python + ┌─────┐┌─────┐┌─────┐┌─────┐┌────────┐ +q_0: ┤0 ├┤0 ├┤0 ├┤0 ├┤0 ├ + │ ││ ││ ││ ││ │ +q_1: ┤1 ├┤1 ├┤1 ├┤1 ├┤1 ├ + │ ││ ││ ││ ││ │ +q_2: ┤2 H2 ├┤2 S1 ├┤2 CZ ├┤2 H1 ├┤2 Pauli ├ + │ ││ ││ ││ ││ │ +q_3: ┤3 ├┤3 ├┤3 ├┤3 ├┤3 ├ + │ ││ ││ ││ ││ │ +q_4: ┤4 ├┤4 ├┤4 ├┤4 ├┤4 ├ + └─────┘└─────┘└─────┘└─────┘└────────┘ +``` + +**Parameters** + +* **stab** ([*StabilizerState*](qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState")) – a stabilizer state. +* **cz\_synth\_func** (*Callable*) – a function to decompose the CZ sub-circuit. It gets as input a boolean symmetric matrix, and outputs a QuantumCircuit. +* **validate** (*Boolean*) – if True, validates the synthesis process. +* **cz\_func\_reverse\_qubits** (*Boolean*) – True only if cz\_synth\_func is synth\_cz\_depth\_line\_mr, since this function returns a circuit that reverts the order of qubits. + +**Returns** + +a circuit implementation of the stabilizer state. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – if the input is not a StabilizerState. + +**Reference:** + +1. S. Bravyi, D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*, [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) + +### synth\_stabilizer\_depth\_lnn + + + +`qiskit.synthesis.synth_stabilizer_depth_lnn(stab)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/stabilizer/stabilizer_decompose.py "view source code") + +Synthesis of an n-qubit stabilizer state for linear-nearest neighbour connectivity, in 2-qubit depth 2\*n+2 and two distinct CX layers, using CX and phase gates (S, Sdg or Z). + +**Parameters** + +**stab** ([*StabilizerState*](qiskit.quantum_info.StabilizerState "qiskit.quantum_info.StabilizerState")) – a stabilizer state. + +**Returns** + +a circuit implementation of the stabilizer state. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Reference:** + +1. S. Bravyi, D. Maslov, *Hadamard-free circuits expose the structure of the Clifford group*, [arXiv:2003.09412 \[quant-ph\]](https://arxiv.org/abs/2003.09412) +2. Dmitri Maslov, Martin Roetteler, *Shorter stabilizer circuits via Bruhat decomposition and quantum circuit transformations*, [arXiv:1705.09176](https://arxiv.org/abs/1705.09176). + +## Discrete Basis Synthesis + +| | | +| --------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------- | +| [`SolovayKitaevDecomposition`](qiskit.synthesis.SolovayKitaevDecomposition "qiskit.synthesis.SolovayKitaevDecomposition")(\[...]) | The Solovay Kitaev discrete decomposition algorithm. | + +### generate\_basic\_approximations + + + +`qiskit.synthesis.generate_basic_approximations(basis_gates, depth, filename=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/discrete_basis/generate_basis_approximations.py "view source code") + +Generates a list of `GateSequence``s with the gates in ``basic_gates`. + +**Parameters** + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Gate*](qiskit.circuit.Gate "qiskit.circuit.Gate")*]*) – The gates from which to create the sequences of gates. +* **depth** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum depth of the approximations. +* **filename** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – If provided, the basic approximations are stored in this file. + +**Returns** + +List of `GateSequences` using the gates in `basic_gates`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If `basis_gates` contains an invalid gate identifier. + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")\[GateSequence] + +## Unitary Synthesis + +Decomposition of general $2^n \times 2^n$ unitary matrices for any number of qubits. + +### qs\_decomposition + + + +`qiskit.synthesis.qs_decomposition(mat, opt_a1=True, opt_a2=True, decomposer_1q=None, decomposer_2q=None, *, _depth=0)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/qsd.py "view source code") + +Decomposes a unitary matrix into one and two qubit gates using Quantum Shannon Decomposition, + +This decomposition is described in Shende et al. \[1]. + +```python + ┌───┐ ┌───┐ ┌───┐ ┌───┐ + ─┤ ├─ ───────┤ Rz├─────┤ Ry├─────┤ Rz├───── + │ │ ≃ ┌───┐└─┬─┘┌───┐└─┬─┘┌───┐└─┬─┘┌───┐ +/─┤ ├─ /─┤ ├──□──┤ ├──□──┤ ├──□──┤ ├ + └───┘ └───┘ └───┘ └───┘ └───┘ +``` + +The number of CX gates generated with the decomposition without optimizations is, + +$$ +\frac{9}{16} 4^n - \frac{3}{2} 2^n +$$ + +If opt\_a1 = True, the default, the CX count is reduced by, + +$$ +\frac{1}{3} 4^{n - 2} - 1. +$$ + +If opt\_a2 = True, the default, the CX count is reduced by, + +$$ +4^{n-2} - 1. +$$ + +**Parameters** + +* **mat** (*np.ndarray*) – unitary matrix to decompose +* **opt\_a1** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to try optimization A.1 from Shende et al. \[1]. This should eliminate 1 cx per call. If True CZ gates are left in the output. If desired these can be further decomposed to CX. +* **opt\_a2** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – whether to try optimization A.2 from Shende et al. \[1]. This decomposes two qubit unitaries into a diagonal gate and a two cx unitary and reduces overall cx count by $4^{n-2} - 1$. +* **decomposer\_1q** (*Callable\[\[np.ndarray],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – optional 1Q decomposer. If None, uses [`OneQubitEulerDecomposer`](qiskit.synthesis.OneQubitEulerDecomposer "qiskit.synthesis.OneQubitEulerDecomposer"). +* **decomposer\_2q** (*Callable\[\[np.ndarray],* [*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*] | None*) – optional 2Q decomposer. If None, uses [`TwoQubitBasisDecomposer`](qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer"). + +**Returns** + +Decomposed quantum circuit. + +**Return type** + +[QuantumCircuit](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") + +**Reference:** + +1. Shende, Bullock, Markov, *Synthesis of Quantum Logic Circuits*, [arXiv:0406176 \[quant-ph\]](https://arxiv.org/abs/quant-ph/0406176) + +The Approximate Quantum Compiler is available here: [`qiskit.synthesis.unitary.aqc`](synthesis_aqc#module-qiskit.synthesis.unitary.aqc "qiskit.synthesis.unitary.aqc") + +## One-Qubit Synthesis + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------ | --------------------------------------------------------------------- | +| [`OneQubitEulerDecomposer`](qiskit.synthesis.OneQubitEulerDecomposer "qiskit.synthesis.OneQubitEulerDecomposer")(\[basis, use\_dag]) | A class for decomposing 1-qubit unitaries into Euler angle rotations. | + +## Two-Qubit Synthesis + +| | | +| ------------------------------------------------------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`TwoQubitBasisDecomposer`](qiskit.synthesis.TwoQubitBasisDecomposer "qiskit.synthesis.TwoQubitBasisDecomposer")(gate\[, ...]) | A class for decomposing 2-qubit unitaries into minimal number of uses of a 2-qubit basis gate. | +| [`XXDecomposer`](qiskit.synthesis.XXDecomposer "qiskit.synthesis.XXDecomposer")(\[basis\_fidelity, euler\_basis, ...]) | A class for optimal decomposition of 2-qubit unitaries into 2-qubit basis gates of XX type (i.e., each locally equivalent to CAN(alpha, 0, 0) for a possibly varying alpha). | + diff --git a/docs/api/qiskit/0.46/synthesis_aqc.md b/docs/api/qiskit/0.46/synthesis_aqc.md new file mode 100644 index 00000000000..821bc5dc1f9 --- /dev/null +++ b/docs/api/qiskit/0.46/synthesis_aqc.md @@ -0,0 +1,168 @@ +--- +title: aqc +description: API reference for qiskit.synthesis.unitary.aqc +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.synthesis.unitary.aqc +--- + + + + + + + +# Approximate Quantum Compiler + + + +`qiskit.synthesis.unitary.aqc` + +Implementation of Approximate Quantum Compiler as described in the paper \[1]. + +## Interface + +The main public interface of this module is reached by passing `unitary_synthesis_method='aqc'` to [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"). This will swap the synthesis method to use `AQCSynthesisPlugin`. The individual classes are: + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------- | +| [`AQC`](qiskit.synthesis.unitary.aqc.AQC "qiskit.synthesis.unitary.aqc.AQC")(\[optimizer, seed]) | A generic implementation of the Approximate Quantum Compiler. | +| [`ApproximateCircuit`](qiskit.synthesis.unitary.aqc.ApproximateCircuit "qiskit.synthesis.unitary.aqc.ApproximateCircuit")(num\_qubits\[, name]) | A base class that represents an approximate circuit. | +| [`ApproximatingObjective`](qiskit.synthesis.unitary.aqc.ApproximatingObjective "qiskit.synthesis.unitary.aqc.ApproximatingObjective")() | A base class for an optimization problem definition. | +| [`CNOTUnitCircuit`](qiskit.synthesis.unitary.aqc.CNOTUnitCircuit "qiskit.synthesis.unitary.aqc.CNOTUnitCircuit")(num\_qubits, cnots\[, tol, name]) | A class that represents an approximate circuit based on CNOT unit blocks. | +| [`CNOTUnitObjective`](qiskit.synthesis.unitary.aqc.CNOTUnitObjective "qiskit.synthesis.unitary.aqc.CNOTUnitObjective")(num\_qubits, cnots) | A base class for a problem definition based on CNOT unit. | +| [`DefaultCNOTUnitObjective`](qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective "qiskit.synthesis.unitary.aqc.DefaultCNOTUnitObjective")(num\_qubits, cnots) | A naive implementation of the objective function based on CNOT units. | +| [`FastCNOTUnitObjective`](qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective "qiskit.synthesis.unitary.aqc.FastCNOTUnitObjective")(num\_qubits, cnots) | Implementation of objective function and gradient calculator, which is similar to `DefaultCNOTUnitObjective` but several times faster. | + +## Mathematical Detail + +We are interested in compiling a quantum circuit, which we formalize as finding the best circuit representation in terms of an ordered gate sequence of a target unitary matrix $U\in U(d)$, with some additional hardware constraints. In particular, we look at representations that could be constrained in terms of hardware connectivity, as well as gate depth, and we choose a gate basis in terms of CNOT and rotation gates. We recall that the combination of CNOT and rotation gates is universal in $SU(d)$ and therefore it does not limit compilation. + +To properly define what we mean by best circuit representation, we define the metric as the Frobenius norm between the unitary matrix of the compiled circuit $V$ and the target unitary matrix $U$, i.e., $\|V - U\|_{\mathrm{F}}$. This choice is motivated by mathematical programming considerations, and it is related to other formulations that appear in the literature. Let’s take a look at the problem in more details. + +Let $n$ be the number of qubits and $d=2^n$. Given a CNOT structure $ct$ and a vector of rotation angles $\theta$, the parametric circuit forms a matrix $Vct(\theta)\in SU(d)$. If we are given a target circuit forming a matrix $U\in SU(d)$, then we would like to compute + +$$ +\mathrm{argmax}_{\theta}\frac{1}{d}|\langle Vct(\theta),U\rangle| +$$ + +where the inner product is the Frobenius inner product. Note that $|\langle V,U\rangle|\leq d$ for all unitaries $U$ and $V$, so the objective has range in $[0,1]$. + +Our strategy is to maximize + +$$ +\frac{1}{d}\Re \langle Vct(\theta),U\rangle +$$ + +using its gradient. We will now discuss the specifics by going through an example. + +While the range of $Vct$ is a subset of $SU(d)$ by construction, the target circuit may form a general unitary matrix. However, for any $U\in U(d)$, + +$$ +\frac{\exp(2\pi i k/d)}{\det(U)^{1/d}}U\in SU(d)\text{ for all }k\in\{0,\ldots,d-1\}. +$$ + +Thus, we should normalize the target circuit by its global phase and then approximately compile the normalized circuit. We can add the global phase back in afterwards. + +In the algorithm let $U'$ denote the un-normalized target matrix and $U$ the normalized target matrix. Now that we have $U$, we give the gradient function to the Nesterov’s method optimizer and compute $\theta$. + +To add the global phase back in, we can form the control circuit as + +$$ +\frac{\langle Vct(\theta),U'\rangle}{|\langle Vct(\theta),U'\rangle|}Vct(\theta). +$$ + +Note that while we optimized using Nesterov’s method in the paper, this was for its convergence guarantees, not its speed in practice. It is much faster to use L-BFGS which is used as a default optimizer in this implementation. + +A basic usage of the AQC algorithm should consist of the following steps: + +```python +# Define a target circuit as a unitary matrix +unitary = ... + +# Define a number of qubits for the algorithm, at least 3 qubits +num_qubits = int(round(np.log2(unitary.shape[0]))) + +# Choose a layout of the CNOT structure for the approximate circuit, e.g. ``spin`` for +# a linear layout. +layout = options.get("layout") or "spin" + +# Choose a connectivity type, e.g. ``full`` for full connectivity between qubits. +connectivity = options.get("connectivity") or "full" + +# Define a targeted depth of the approximate circuit in the number of CNOT units. +depth = int(options.get("depth") or 0) + +# Generate a network made of CNOT units +cnots = make_cnot_network( + num_qubits=num_qubits, + network_layout=layout, + connectivity_type=connectivity, + depth=depth +) + +# Create an optimizer to be used by AQC +optimizer = partial(scipy.optimize.minimize, method="L-BFGS-B") + +# Create an instance +aqc = AQC(optimizer) + +# Create a template circuit that will approximate our target circuit +approximate_circuit = CNOTUnitCircuit(num_qubits=num_qubits, cnots=cnots) + +# Create an objective that defines our optimization problem +approximating_objective = DefaultCNOTUnitObjective(num_qubits=num_qubits, cnots=cnots) + +# Run optimization process to compile the unitary +aqc.compile_unitary( + target_matrix=unitary, + approximate_circuit=approximate_circuit, + approximating_objective=approximating_objective +) +``` + +Now `approximate_circuit` is a circuit that approximates the target unitary to a certain degree and can be used instead of the original matrix. + +This uses a helper function, [`make_cnot_network`](#qiskit.synthesis.unitary.aqc.make_cnot_network "qiskit.synthesis.unitary.aqc.make_cnot_network"). + +### make\_cnot\_network + + + +`qiskit.synthesis.unitary.aqc.make_cnot_network(num_qubits, network_layout='spin', connectivity_type='full', depth=0)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/synthesis/unitary/aqc/cnot_structures.py "view source code") + +Generates a network consisting of building blocks each containing a CNOT gate and possibly some single-qubit ones. This network models a quantum operator in question. Note, each building block has 2 input and outputs corresponding to a pair of qubits. What we actually return here is a chain of indices of qubit pairs shared by every building block in a row. + +**Parameters** + +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – number of qubits. +* **network\_layout** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – type of network geometry, `{"sequ", "spin", "cart", "cyclic_spin", "cyclic_line"}`. +* **connectivity\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – type of inter-qubit connectivity, `{"full", "line", "star"}`. +* **depth** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – depth of the CNOT-network, i.e. the number of layers, where each layer consists of a single CNOT-block; default value will be selected, if `L <= 0`. + +**Returns** + +**A matrix of size `(2, N)` matrix that defines layers in cnot-network, where `N`** + +is either equal `L`, or defined by a concrete type of the network. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if unsupported type of CNOT-network layout or number of qubits or combination of parameters are passed. + +**Return type** + +[*ndarray*](https://numpy.org/doc/stable/reference/generated/numpy.ndarray.html#numpy.ndarray "(in NumPy v1.26)") + +One can take advantage of accelerated version of objective function. It implements the same mathematical algorithm as the default one `DefaultCNOTUnitObjective` but runs several times faster. Instantiation of accelerated objective function class is similar to the default case: + +> \# Create an objective that defines our optimization problem approximating\_objective = FastCNOTUnitObjective(num\_qubits=num\_qubits, cnots=cnots) + +The rest of the code in the above example does not change. + +**References** + +**\[1]: Liam Madden, Andrea Simonetto, Best Approximate Quantum Compiling Problems.** + +[arXiv:2106.05649](https://arxiv.org/abs/2106.05649) + diff --git a/docs/api/qiskit/0.46/tools.md b/docs/api/qiskit/0.46/tools.md new file mode 100644 index 00000000000..185c0534fc5 --- /dev/null +++ b/docs/api/qiskit/0.46/tools.md @@ -0,0 +1,140 @@ +--- +title: tools +description: API reference for qiskit.tools +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.tools +--- + + + + + +# Qiskit Tools + + + +`qiskit.tools` + +## Monitoring + +A helper module to get IBM backend information and submitted job status. + +### job\_monitor + + + +`qiskit.tools.job_monitor(job, interval=None, quiet=False, output=<_io.TextIOWrapper name='' mode='w' encoding='utf-8'>, line_discipline='\r')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/tools/monitor/job_monitor.py "view source code") + +Monitor the status of a IBMQJob instance. + +**Parameters** + +* **job** (*BaseJob*) – Job to monitor. +* **interval** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Time interval between status queries. +* **quiet** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If True, do not print status messages. +* **output** (*file*) – The file like object to write status messages to. +* **sys.stdout.** (*By default this is*) – +* **line\_discipline** (*string*) – character emitted at start of a line of job monitor output, +* **r.** (*This defaults to*) – + +**Examples** + +```python +from qiskit import BasicAer, transpile +from qiskit.circuit import QuantumCircuit +from qiskit.tools.monitor import job_monitor +sim_backend = BasicAer.get_backend("qasm_simulator") +qc = QuantumCircuit(2, 2) +qc.h(0) +qc.cx(0, 1) +qc.measure_all() +tqc = transpile(qc, sim_backend) +job_sim = sim_backend.run(tqc) +job_monitor(job_sim) +``` + +### backend\_monitor + + + +`qiskit.tools.backend_monitor(backend)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/tools/monitor/overview.py "view source code") + +Monitor a single IBMQ backend. + +**Parameters** + +**backend** (*IBMQBackend*) – Backend to monitor. + +**Raises** + +* [**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – Input is not a IBMQ backend. +* [**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – If qiskit-ibmq-provider is not installed + +Examples: .. code-block:: python + +> from qiskit.providers.ibmq import IBMQ from qiskit.tools.monitor import backend\_monitor provider = IBMQ.get\_provider(hub=’ibm-q’) backend\_monitor(provider.backends.ibmq\_lima) + +### backend\_overview + + + +`qiskit.tools.backend_overview()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/tools/monitor/overview.py "view source code") + +Gives overview information on all the IBMQ backends that are available. + +**Examples** + +```python +from qiskit.providers.ibmq import IBMQ +from qiskit.tools.monitor import backend_overview +provider = IBMQ.get_provider(hub='ibm-q') +backend_overview() +``` + + + + + +### Events ([`qiskit.tools.events`](#module-qiskit.tools.events "qiskit.tools.events")) + +A helper component for publishing and subscribing to events. + + + +`qiskit.tools.events.TextProgressBar(output_handler=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/tools/events/progressbar.py "view source code") + +A simple text-based progress bar. + +**output\_handlerthe handler the progress bar should be written to, default** + +is sys.stdout, another option is sys.stderr + +**Examples** + +The progress bar can be used to track the progress of a parallel\_map. + +```python +import numpy as np +import qiskit.tools.jupyter +from qiskit.tools.parallel import parallel_map +from qiskit.tools.events import TextProgressBar + +TextProgressBar() +%qiskit_progress_bar -t text +parallel_map(np.sin, np.linspace(0,10,100)); +``` + +And it can also be used individually. + +```python +from qiskit.tools.events import TextProgressBar + +iterations = 100 +t = TextProgressBar() +t.start(iterations=iterations) +for i in range(iterations): + # step i of heavy calculation ... + t.update(i + 1) # update progress bar +``` + diff --git a/docs/api/qiskit/0.46/tools_jupyter.md b/docs/api/qiskit/0.46/tools_jupyter.md new file mode 100644 index 00000000000..d3b10441b51 --- /dev/null +++ b/docs/api/qiskit/0.46/tools_jupyter.md @@ -0,0 +1,86 @@ +--- +title: jupyter +description: API reference for qiskit.tools.jupyter +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.tools.jupyter +--- + + + + + + + +# Jupyter Tools + + + +`qiskit.tools.jupyter` + +A Collection of Jupyter magic functions and tools that extend the functionality of Qiskit. + +## Overview of all available backends + +```python +from qiskit.providers.ibmq import IBMQ +import qiskit.tools.jupyter +%matplotlib inline + +IBMQ.load_account() + +%qiskit_backend_overview +``` + +## Detailed information on a single backend + +```python +from qiskit.providers.ibmq import IBMQ +import qiskit.tools.jupyter +%matplotlib inline + +IBMQ.load_account() +provider = IBMQ.get_provider(hub='ibm-q') +backend = provider.get_backend('ibmq_vigo') +backend +``` + +## Load Qiskit Job Watcher + +```python +import qiskit.tools.jupyter +%qiskit_job_watcher +``` + +## HTMLProgressBar + +```python +import numpy as np +from qiskit.tools.parallel import parallel_map +import qiskit.tools.jupyter + +%qiskit_progress_bar +parallel_map(np.sin, np.linspace(0,10,100)); +``` + +## Qiskit version table + +```python +import qiskit.tools.jupyter +%qiskit_version_table +``` + +## Qiskit copyright + +```python +import qiskit.tools.jupyter +%qiskit_copyright +``` + +## Monospaced output + +```python +import qiskit.tools.jupyter +%monospaced_output +``` + diff --git a/docs/api/qiskit/0.46/transpiler.md b/docs/api/qiskit/0.46/transpiler.md new file mode 100644 index 00000000000..508bcf5e9a3 --- /dev/null +++ b/docs/api/qiskit/0.46/transpiler.md @@ -0,0 +1,980 @@ +--- +title: transpiler +description: API reference for qiskit.transpiler +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.transpiler +--- + + + + + + + +# Transpiler + + + +`qiskit.transpiler` + +## Overview + +Transpilation is the process of rewriting a given input circuit to match the topology of a specific quantum device, and/or to optimize the circuit for execution on present day noisy quantum systems. + +Most circuits must undergo a series of transformations that make them compatible with a given target device, and optimize them to reduce the effects of noise on the resulting outcomes. Rewriting quantum circuits to match hardware constraints and optimizing for performance can be far from trivial. The flow of logic in the rewriting tool chain need not be linear, and can often have iterative sub-loops, conditional branches, and other complex behaviors. That being said, the standard compilation flow follows the structure given below: + +![../\_images/transpiling\_core\_steps.png](/images/api/qiskit/0.46/transpiling_core_steps.png) + +Qiskit has four pre-built transpilation pipelines available here: [`qiskit.transpiler.preset_passmanagers`](transpiler_preset#module-qiskit.transpiler.preset_passmanagers "qiskit.transpiler.preset_passmanagers"). Unless the reader is familiar with quantum circuit optimization methods and their usage, it is best to use one of these ready-made routines. By default the preset pass managers are composed of six stages: + +1. `init` - This stage runs any initial passes that are required before we start embedding the circuit to the backend. This typically involves unrolling custom instructions and converting the circuit to all 1 and 2 qubit gates. +2. `layout` - This stage applies a layout, mapping the virtual qubits in the circuit to the physical qubits on a backend. See [Layout Stage](#layout-stage) for more details. +3. `routing` - This stage runs after a layout has been applied and will inject gates (i.e. swaps) into the original circuit to make it compatible with the backend’s connectivity. See [Routing Stage](#routing-stage) for more details. +4. `translation` - This stage translates the gates in the circuit to the target backend’s basis set. See [Translation Stage](#translation-stage) for more details. +5. `optimization` - This stage runs the main optimization loop repeatedly until a condition (such as fixed depth) is reached. See [Optimization Stage](#optimization-stage) for more details. +6. `scheduling` - This stage is for any hardware-aware scheduling passes. See [Scheduling Stage](#scheduling-stage) for more details. + +When using [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"), the implementation of each stage can be modified with the `*_method` arguments (e.g. `layout_method`). These can be set to one of the built-in methods and can also refer to available external plugins. See [`qiskit.transpiler.preset_passmanagers.plugin`](transpiler_plugins#module-qiskit.transpiler.preset_passmanagers.plugin "qiskit.transpiler.preset_passmanagers.plugin") for details on this plugin interface. + + + +## Working with Preset Pass Managers + +Qiskit includes functions to build preset [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") objects. These preset passmanagers are used by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function for each optimization level. There are 4 optimization levels ranging from 0 to 3, where higher optimization levels take more time and computational effort but may yield a more optimal circuit. Optimization level 0 is intended for device characterization experiments and, as such, only maps the input circuit to the constraints of the target backend, without performing any optimizations. Optimization level 3 spends the most effort to optimize the circuit. However, as many of the optimization techniques in the transpiler are heuristic based, spending more computational effort does not always result in an improvement in the quality of the output circuit. + +If you’d like to work directly with a preset pass manager you can use the [`generate_preset_pass_manager()`](transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") function to easily generate one. For example: + +```python +from qiskit.transpiler.preset_passmanagers import generate_preset_pass_manager +from qiskit.providers.fake_provider import FakeLagosV2 + +backend = FakeLagosV2() +pass_manager = generate_preset_pass_manager(3, backend) +``` + +which will generate a [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") object for optimization level 3 targeting the [`FakeLagosV2`](qiskit.providers.fake_provider.FakeLagosV2 "qiskit.providers.fake_provider.FakeLagosV2") backend (equivalent to what is used internally by [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") with `backend=FakeLagosV2()` and `optimization_level=3`). You can use this just like you would any other [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager"). However, because it is a [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") it also makes it easy to compose and/or replace stages of the pipeline. For example, if you wanted to run a custom scheduling stage using dynamical decoupling (via the [`PadDynamicalDecoupling`](qiskit.transpiler.passes.PadDynamicalDecoupling "qiskit.transpiler.passes.PadDynamicalDecoupling") pass) and also add initial logical optimization prior to routing, you would do something like (building off the previous example): + +```python +import numpy as np +from qiskit.circuit.library import HGate, PhaseGate, RXGate, TdgGate, TGate, XGate +from qiskit.transpiler import PassManager +from qiskit.transpiler.passes import ( + ALAPScheduleAnalysis, + CXCancellation, + InverseCancellation, + PadDynamicalDecoupling, +) + +dd_sequence = [XGate(), XGate()] +scheduling_pm = PassManager( + [ + ALAPScheduleAnalysis(target=backend.target), + PadDynamicalDecoupling(target=backend.target, dd_sequence=dd_sequence), + ] +) +inverse_gate_list = [ + HGate(), + (RXGate(np.pi / 4), RXGate(-np.pi / 4)), + (PhaseGate(np.pi / 4), PhaseGate(-np.pi / 4)), + (TGate(), TdgGate()), +] +logical_opt = PassManager( + [ + CXCancellation(), + InverseCancellation(inverse_gate_list), + ] +) + + +# Add pre-layout stage to run extra logical optimization +pass_manager.pre_layout = logical_opt +# Set scheduling stage to custom pass manager +pass_manager.scheduling = scheduling_pm +``` + +Now, when the staged pass manager is run via the [`run()`](qiskit.transpiler.StagedPassManager#run "qiskit.transpiler.StagedPassManager.run") method, the `logical_opt` pass manager will be called before the `layout` stage, and the `scheduling_pm` pass manager will be used for the `scheduling` stage instead of the default. + +## Custom Pass Managers + +In addition to modifying preset pass managers, it is also possible to construct a pass manager to build an entirely custom pipeline for transforming input circuits. You can use the [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") class directly to do this. You can define arbitrary stage names and populate them with a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") instance. For example, the following code creates a new [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") that has 2 stages, `init` and `translation`.: + +```python +from qiskit.transpiler.passes import ( + UnitarySynthesis, + Collect2qBlocks, + ConsolidateBlocks, + UnitarySynthesis, + Unroll3qOrMore, +) +from qiskit.transpiler import PassManager, StagedPassManager + +basis_gates = ["rx", "ry", "rxx"] +init = PassManager([UnitarySynthesis(basis_gates, min_qubits=3), Unroll3qOrMore()]) +translate = PassManager( + [ + Collect2qBlocks(), + ConsolidateBlocks(basis_gates=basis_gates), + UnitarySynthesis(basis_gates), + ] +) + +staged_pm = StagedPassManager( + stages=["init", "translation"], init=init, translation=translate +) +``` + +There is no limit on the number of stages you can put in a [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager"). + +The [Stage Generator Functions](transpiler_preset#stage-generators) may be useful for the construction of custom `generate_embed_passmanager` generates a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") to “embed” a selected initial [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") from a layout pass to the specified target device. + +## Representing Quantum Computers + +To be able to compile a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") for a specific backend, the transpiler needs a specialized representation of that backend, including its constraints, instruction set, qubit properties, and more, to be able to compile and optimize effectively. While the [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") class defines an interface for querying and interacting with backends, its scope is larger than just the transpiler’s needs including managing job submission and potentially interfacing with remote services. The specific information needed by the transpiler is described by the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") class + +For example, to construct a simple [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object, one can iteratively add descriptions of the instructions it supports: + +```python +from qiskit.circuit import Parameter, Measure +from qiskit.transpiler import Target, InstructionProperties +from qiskit.circuit.library import UGate, RZGate, RXGate, RYGate, CXGate, CZGate + +target = Target(num_qubits=3) +target.add_instruction(CXGate(), {(0, 1): InstructionProperties(error=.0001, duration=5e-7)}) +target.add_instruction( + UGate(Parameter('theta'), Parameter('phi'), Parameter('lam')), + { + (0,): InstructionProperties(error=.00001, duration=5e-8), + (1,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RZGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RYGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RXGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + CZGate(), + { + (1, 2): InstructionProperties(error=.0001, duration=5e-7), + (2, 0): InstructionProperties(error=.0001, duration=5e-7) + } +) +target.add_instruction( + Measure(), + { + (0,): InstructionProperties(error=.001, duration=5e-5), + (1,): InstructionProperties(error=.002, duration=6e-5), + (2,): InstructionProperties(error=.2, duration=5e-7) + } +) +print(target) +``` + +```python +Target +Number of qubits: 3 +Instructions: + cx + (0, 1): + Duration: 5e-07 sec. + Error Rate: 0.0001 + u + (0,): + Duration: 5e-08 sec. + Error Rate: 1e-05 + (1,): + Duration: 6e-08 sec. + Error Rate: 2e-05 + rz + (1,): + Duration: 5e-08 sec. + Error Rate: 1e-05 + (2,): + Duration: 6e-08 sec. + Error Rate: 2e-05 + ry + (1,): + Duration: 5e-08 sec. + Error Rate: 1e-05 + (2,): + Duration: 6e-08 sec. + Error Rate: 2e-05 + rx + (1,): + Duration: 5e-08 sec. + Error Rate: 1e-05 + (2,): + Duration: 6e-08 sec. + Error Rate: 2e-05 + cz + (1, 2): + Duration: 5e-07 sec. + Error Rate: 0.0001 + (2, 0): + Duration: 5e-07 sec. + Error Rate: 0.0001 + measure + (0,): + Duration: 5e-05 sec. + Error Rate: 0.001 + (1,): + Duration: 6e-05 sec. + Error Rate: 0.002 + (2,): + Duration: 5e-07 sec. + Error Rate: 0.2 +``` + +This [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") represents a 3 qubit backend that supports [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") between qubits 0 and 1, [`UGate`](qiskit.circuit.library.UGate "qiskit.circuit.library.UGate") on qubits 0 and 1, [`RZGate`](qiskit.circuit.library.RZGate "qiskit.circuit.library.RZGate"), [`RXGate`](qiskit.circuit.library.RXGate "qiskit.circuit.library.RXGate"), and [`RYGate`](qiskit.circuit.library.RYGate "qiskit.circuit.library.RYGate") on qubits 1 and 2, [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate") between qubits 1 and 2, and qubits 2 and 0, and [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure") on all qubits. + +There are also specific data structures to represent a specific subset of information from the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target"). For example, the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") class is used to solely represent the connectivity constraints of a backend as a directed graph. A coupling map can be generated from a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") using the [`Target.build_coupling_map()`](qiskit.transpiler.Target#build_coupling_map "qiskit.transpiler.Target.build_coupling_map") method. These data structures typically pre-date the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") class but are still used by some transpiler passes that do not work natively with a [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") instance yet or when dealing with backends that aren’t using the latest [`BackendV2`](qiskit.providers.BackendV2 "qiskit.providers.BackendV2") interface. + +For example, if we wanted to visualize the [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap") for the example 3 qubit [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") above: + +```python +from qiskit.circuit import Parameter, Measure +from qiskit.transpiler import Target, InstructionProperties +from qiskit.circuit.library import UGate, RZGate, RXGate, RYGate, CXGate, CZGate + +target = Target(num_qubits=3) +target.add_instruction(CXGate(), {(0, 1): InstructionProperties(error=.0001, duration=5e-7)}) +target.add_instruction( + UGate(Parameter('theta'), Parameter('phi'), Parameter('lam')), + { + (0,): InstructionProperties(error=.00001, duration=5e-8), + (1,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RZGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RYGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RXGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + CZGate(), + { + (1, 2): InstructionProperties(error=.0001, duration=5e-7), + (2, 0): InstructionProperties(error=.0001, duration=5e-7) + } +) +target.add_instruction( + Measure(), + { + (0,): InstructionProperties(error=.001, duration=5e-5), + (1,): InstructionProperties(error=.002, duration=6e-5), + (2,): InstructionProperties(error=.2, duration=5e-7) + } +) + +target.build_coupling_map().draw() +``` + +This shows the global connectivity of the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") which is the combination of the supported qubits for [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") and [`CZGate`](qiskit.circuit.library.CZGate "qiskit.circuit.library.CZGate"). To see the individual connectivity, you can pass the operation name to `CouplingMap.build_coupling_map()`: + +```python +from qiskit.circuit import Parameter, Measure +from qiskit.transpiler import Target, InstructionProperties +from qiskit.circuit.library import UGate, RZGate, RXGate, RYGate, CXGate, CZGate + +target = Target(num_qubits=3) +target.add_instruction(CXGate(), {(0, 1): InstructionProperties(error=.0001, duration=5e-7)}) +target.add_instruction( + UGate(Parameter('theta'), Parameter('phi'), Parameter('lam')), + { + (0,): InstructionProperties(error=.00001, duration=5e-8), + (1,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RZGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RYGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RXGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + CZGate(), + { + (1, 2): InstructionProperties(error=.0001, duration=5e-7), + (2, 0): InstructionProperties(error=.0001, duration=5e-7) + } +) +target.add_instruction( + Measure(), + { + (0,): InstructionProperties(error=.001, duration=5e-5), + (1,): InstructionProperties(error=.002, duration=6e-5), + (2,): InstructionProperties(error=.2, duration=5e-7) + } +) + +target.build_coupling_map('cx').draw() +``` + +```python +from qiskit.circuit import Parameter, Measure +from qiskit.transpiler import Target, InstructionProperties +from qiskit.circuit.library import UGate, RZGate, RXGate, RYGate, CXGate, CZGate + +target = Target(num_qubits=3) +target.add_instruction(CXGate(), {(0, 1): InstructionProperties(error=.0001, duration=5e-7)}) +target.add_instruction( + UGate(Parameter('theta'), Parameter('phi'), Parameter('lam')), + { + (0,): InstructionProperties(error=.00001, duration=5e-8), + (1,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RZGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RYGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + RXGate(Parameter('theta')), + { + (1,): InstructionProperties(error=.00001, duration=5e-8), + (2,): InstructionProperties(error=.00002, duration=6e-8) + } +) +target.add_instruction( + CZGate(), + { + (1, 2): InstructionProperties(error=.0001, duration=5e-7), + (2, 0): InstructionProperties(error=.0001, duration=5e-7) + } +) +target.add_instruction( + Measure(), + { + (0,): InstructionProperties(error=.001, duration=5e-5), + (1,): InstructionProperties(error=.002, duration=6e-5), + (2,): InstructionProperties(error=.2, duration=5e-7) + } +) + +target.build_coupling_map('cz').draw() +``` + + + +## Transpiler Stage Details + +Below are a description of the default transpiler stages and the problems they solve. The default passes used for each stage are described, but the specifics are configurable via the `*_method` keyword arguments for the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") and [`generate_preset_pass_manager()`](transpiler_preset#qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager "qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager") functions which can be used to override the methods described in this section. + + + +### Translation Stage + +When writing a quantum circuit you are free to use any quantum gate (unitary operator) that you like, along with a collection of non-gate operations such as qubit measurements and reset operations. However, most quantum devices only natively support a handful of quantum gates and non-gate operations. The allowed instructions for a given backend can be found by querying the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") for the devices: + +```python +from qiskit.providers.fake_provider import FakeVigoV2 +backend = FakeVigoV2() + +print(backend.target) +``` + +Every quantum circuit run on the target device must be expressed using only these instructions. For example, to run a simple phase estimation circuit: + +```python +import numpy as np +from qiskit import QuantumCircuit +from qiskit.providers.fake_provider import FakeVigoV2 + +backend = FakeVigoV2() + +qc = QuantumCircuit(2, 1) + +qc.h(0) +qc.x(1) +qc.cp(np.pi/4, 0, 1) +qc.h(0) +qc.measure([0], [0]) +qc.draw(output='mpl') +``` + +![../\_images/transpiler-4.png](/images/api/qiskit/0.46/transpiler-4.png) + +We have $H$, $X$, and controlled-$P$ gates, none of which are in our device’s basis gate set, and thus must be translated. This translation is taken care of for us in the `qiskit.execute()` function. However, we can transpile the circuit to show what it will look like in the native gate set of the target IBM Quantum device (the [`FakeVigoV2`](qiskit.providers.fake_provider.FakeVigoV2 "qiskit.providers.fake_provider.FakeVigoV2") backend is a fake backend that models the historical IBM Vigo 5 qubit device for test purposes): + +```python +from qiskit import transpile +from qiskit import QuantumCircuit +from qiskit.providers.fake_provider import FakeVigoV2 + +backend = FakeVigoV2() + +qc = QuantumCircuit(2, 1) + +qc.h(0) +qc.x(1) +qc.cp(np.pi/4, 0, 1) +qc.h(0) +qc.measure([0], [0]) + +qc_basis = transpile(qc, backend) +qc_basis.draw(output='mpl') +``` + +![../\_images/transpiler-5.png](/images/api/qiskit/0.46/transpiler-5.png) + +A few things to highlight. First, the circuit has gotten longer with respect to the original. This can be verified by checking the depth of both circuits: + +```python +print('Original depth:', qc.depth(), 'Decomposed Depth:', qc_basis.depth()) +``` + +```python +Original depth: 4 Decomposed Depth: 10 +``` + +Second, although we had a single controlled gate, the fact that it was not in the basis set means that, when expanded, it requires more than a single [`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") to implement. All said, unrolling to the basis set of gates leads to an increase in the depth of a quantum circuit and the number of gates. + +It is important to highlight two special cases: + +1. If A swap gate is not a native gate and must be decomposed this requires three CNOT gates: + + ```python + from qiskit.providers.fake_provider import FakeVigoV2 + backend = FakeVigoV2() + + print(backend.operation_names) + ``` + + ```python + ['id', 'rz', 'sx', 'x', 'cx', 'measure', 'delay'] + ``` + + As a product of three CNOT gates, swap gates are expensive operations to perform on noisy quantum devices. However, such operations are usually necessary for embedding a circuit into the limited gate connectivities of many devices. Thus, minimizing the number of swap gates in a circuit is a primary goal in the transpilation process. + +2. A Toffoli, or controlled-controlled-not gate (`ccx`), is a three-qubit gate. Given that our basis gate set includes only single- and two-qubit gates, it is obvious that this gate must be decomposed. This decomposition is quite costly: + + ```python + from qiskit.circuit import QuantumCircuit + + ccx_circ = QuantumCircuit(3) + ccx_circ.ccx(0, 1, 2) + ccx_circ.decompose().draw(output='mpl') + ``` + + ![../\_images/transpiler-6.png](/images/api/qiskit/0.46/transpiler-6.png) + + For every Toffoli gate in a quantum circuit, the hardware may execute up to six CNOT gates, and a handful of single-qubit gates. From this example, it should be clear that any algorithm that makes use of multiple Toffoli gates will end up as a circuit with large depth and will therefore be appreciably affected by noise and gate errors. + + + +### Layout Stage + +Quantum circuits are abstract entities whose qubits are “virtual” representations of actual qubits used in computations. We need to be able to map these virtual qubits in a one-to-one manner to the “physical” qubits in an actual quantum device. + +![../\_images/mapping.png](/images/api/qiskit/0.46/mapping.png) + +By default, qiskit will do this mapping for you. The choice of mapping depends on the properties of the circuit, the particular device you are targeting, and the optimization level that is chosen. The choice of initial layout is extremely important for minimizing the number of swap operations needed to map the input circuit onto the device topology and for minimizing the loss due to non-uniform noise properties across a device. Due to the importance of this stage, the preset pass managers try a few different methods to find the best layout. Typically this involves 2 steps: first, trying to find a “perfect” layout (a layout which does not require any swap operations), and then, a heuristic pass that tries to find the best layout to use if a perfect layout cannot be found. There are 2 passes typically used for the first stage: + +* [`VF2Layout`](qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout"): Models layout selection as a subgraph isomorphism problem and tries to find a subgraph of the connectivity graph that is isomorphic to the graph of 2 qubit interactions in the circuit. If more than one isomorphic mapping is found a scoring heuristic is run to select the mapping which would result in the lowest average error when executing the circuit. +* [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout"): Maps each virtual qubit to the same numbered physical qubit on the device, i.e. `[0,1,2,3,4]` -> `[0,1,2,3,4]`. This is historical behavior used only in `optimization_level=1` to try to find a perfect layout. If it fails to do so, [`VF2Layout`](qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout") is tried next. + +Next, for the heuristic stage, 2 passes are used by default: + +* [`SabreLayout`](qiskit.transpiler.passes.SabreLayout "qiskit.transpiler.passes.SabreLayout"): Selects a layout by starting from an initial random layout and then repeatedly running a routing algorithm (by default [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap")) both forward and backward over the circuit, using the permutation caused by swap insertions to adjust that initial random layout. For more details you can refer to the paper describing the algorithm: [arXiv:1809.02573](https://arxiv.org/abs/1809.02573) [`SabreLayout`](qiskit.transpiler.passes.SabreLayout "qiskit.transpiler.passes.SabreLayout") is used to select a layout if a perfect layout isn’t found for optimization levels 1, 2, and 3. +* [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout"): Always used for the layout at optimization level 0. +* [`DenseLayout`](qiskit.transpiler.passes.DenseLayout "qiskit.transpiler.passes.DenseLayout"): Finds the sub-graph of the device with greatest connectivity that has the same number of qubits as the circuit. Used for optimization level 1 if there are control flow operations (such as [`IfElseOp`](qiskit.circuit.IfElseOp "qiskit.circuit.IfElseOp")) present in the circuit. + +Let’s see what layouts are automatically picked at various optimization levels. The circuits returned by [`qiskit.compiler.transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") are annotated with this initial layout information, and we can view this layout selection graphically using [`qiskit.visualization.plot_circuit_layout()`](qiskit.visualization.plot_circuit_layout "qiskit.visualization.plot_circuit_layout"): + +```python +from qiskit import QuantumCircuit, transpile +from qiskit.visualization import plot_circuit_layout +from qiskit.providers.fake_provider import FakeVigo +backend = FakeVigo() + +ghz = QuantumCircuit(3, 3) +ghz.h(0) +ghz.cx(0,range(1,3)) +ghz.barrier() +ghz.measure(range(3), range(3)) +ghz.draw(output='mpl') +``` + +![../\_images/transpiler-7.png](/images/api/qiskit/0.46/transpiler-7.png) + +* **Layout Using Optimization Level 0** + + > ```python + > from qiskit import QuantumCircuit, transpile + > from qiskit.visualization import plot_circuit_layout + > from qiskit.providers.fake_provider import FakeVigo + > backend = FakeVigo() + > + > ghz = QuantumCircuit(3, 3) + > ghz.h(0) + > ghz.cx(0,range(1,3)) + > ghz.barrier() + > ghz.measure(range(3), range(3)) + > + > new_circ_lv0 = transpile(ghz, backend=backend, optimization_level=0) + > plot_circuit_layout(new_circ_lv0, backend) + > ``` + > + > ![../\_images/transpiler-8.png](/images/api/qiskit/0.46/transpiler-8.png) + +* **Layout Using Optimization Level 3** + + > ```python + > from qiskit import QuantumCircuit, transpile + > from qiskit.visualization import plot_circuit_layout + > from qiskit.providers.fake_provider import FakeVigo + > backend = FakeVigo() + > + > ghz = QuantumCircuit(3, 3) + > ghz.h(0) + > ghz.cx(0,range(1,3)) + > ghz.barrier() + > ghz.measure(range(3), range(3)) + > + > new_circ_lv3 = transpile(ghz, backend=backend, optimization_level=3) + > plot_circuit_layout(new_circ_lv3, backend) + > ``` + > + > ![../\_images/transpiler-9.png](/images/api/qiskit/0.46/transpiler-9.png) + +It is possible to override automatic layout selection by specifying an initial layout. To do so we can pass a list of integers to [`qiskit.compiler.transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") via the initial\_layout keyword argument, where the index labels the virtual qubit in the circuit and the corresponding value is the label for the physical qubit to map onto: + +```python +from qiskit import QuantumCircuit, transpile +from qiskit.visualization import plot_circuit_layout +from qiskit.providers.fake_provider import FakeVigo +backend = FakeVigo() + +ghz = QuantumCircuit(3, 3) +ghz.h(0) +ghz.cx(0,range(1,3)) +ghz.barrier() +ghz.measure(range(3), range(3)) + +# Virtual -> physical +# 0 -> 3 +# 1 -> 4 +# 2 -> 2 + +my_ghz = transpile(ghz, backend, initial_layout=[3, 4, 2]) +plot_circuit_layout(my_ghz, backend) +``` + +![../\_images/transpiler-10.png](/images/api/qiskit/0.46/transpiler-10.png) + + + +### Routing Stage + +In order to implement a 2-qubit gate between qubits in a quantum circuit that are not directly connected on a quantum device, one or more swap gates must be inserted into the circuit to move the qubit states around until they are adjacent on the device gate map. Each swap gate typically represents an expensive and noisy operation to perform. Thus, finding the minimum number of swap gates needed to map a circuit onto a given device, is an important step (if not the most important) in the whole execution process. + +However, as with many important things in life, finding the optimal swap mapping is hard. In fact it is in a class of problems called NP-hard, and is thus prohibitively expensive to compute for all but the smallest quantum devices and input circuits. To get around this, by default Qiskit uses a stochastic heuristic algorithm called [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap") to compute a good, but not necessarily optimal swap mapping. The use of a stochastic method means the circuits generated by [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") (or [`execute()`](execute#qiskit.execute_function.execute "qiskit.execute_function.execute") that calls [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") internally) are not guaranteed to be the same over repeated runs. Indeed, running the same circuit repeatedly will in general result in a distribution of circuit depths and gate counts at the output. + +In order to highlight this, we run a GHZ circuit 100 times, using a “bad” (disconnected) initial\_layout: + +![../\_images/transpiler-11.png](/images/api/qiskit/0.46/transpiler-11.png) + +```python +import matplotlib.pyplot as plt +from qiskit import QuantumCircuit, transpile +from qiskit.providers.fake_provider import FakeAuckland +backend = FakeAuckland() + +ghz = QuantumCircuit(15) +ghz.h(0) +ghz.cx(0, range(1, 15)) + +depths = [] +for _ in range(100): + depths.append( + transpile( + ghz, + backend, + layout_method='trivial' # Fixed layout mapped in circuit order + ).depth() + ) + +plt.figure(figsize=(8, 6)) +plt.hist(depths, align='left', color='#AC557C') +plt.xlabel('Depth', fontsize=14) +plt.ylabel('Counts', fontsize=14); +``` + +![../\_images/transpiler-12.png](/images/api/qiskit/0.46/transpiler-12.png) + +This distribution is quite wide, signaling the difficulty the swap mapper is having in computing the best mapping. Most circuits will have a distribution of depths, perhaps not as wide as this one, due to the stochastic nature of the default swap mapper. Of course, we want the best circuit we can get, especially in cases where the depth is critical to success or failure. The [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap") pass will by default by run its algorithm in parallel with multiple seed values and select the output which uses the fewest swaps. If you would like to increase the number of trials [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap") runs you can refer to [Working with Preset Pass Managers](#working-with-preset-pass-managers) and modify the `routing` stage with a custom instance of [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap") with a larger value for the `trials` argument. + +Typically, following the swap mapper, the routing stage in the preset pass managers also includes running the [`VF2PostLayout`](qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout") pass. As its name implies, [`VF2PostLayout`](qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout") uses the same basic algorithm as [`VF2Layout`](qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout"), but instead of using it to find a perfect initial layout, it is designed to run after mapping and try to find a layout on qubits with lower error rates which will result in better output fidelity when running the circuit. The details of this algorithm are described in [arXiv:2209.15512](https://arxiv.org/abs/2209.15512). + + + +### Optimization Stage + +Decomposing quantum circuits into the basis gate set of the target device, and the addition of swap gates needed to match hardware topology, conspire to increase the depth and gate count of quantum circuits. Fortunately many routines for optimizing circuits by combining or eliminating gates exist. In some cases these methods are so effective the output circuits have lower depth than the inputs. In other cases, not much can be done, and the computation may be difficult to perform on noisy devices. Different gate optimizations are turned on with different `optimization_level` values. Below we show the benefits gained from setting the optimization level higher: + + + The output from [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") varies due to the stochastic swap mapper. So the numbers below will likely change each time you run the code. + + +![../\_images/transpiler-13.png](/images/api/qiskit/0.46/transpiler-13.png) + +```python +import matplotlib.pyplot as plt +from qiskit import QuantumCircuit, transpile +from qiskit.providers.fake_provider import FakeAuckland +backend = FakeAuckland() + +ghz = QuantumCircuit(15) +ghz.h(0) +ghz.cx(0, range(1, 15)) + +depths = [] +gate_counts = [] +non_local_gate_counts = [] +levels = [str(x) for x in range(4)] +for level in range(4): + circ = transpile(ghz, backend, optimization_level=level) + depths.append(circ.depth()) + gate_counts.append(sum(circ.count_ops().values())) + non_local_gate_counts.append(circ.num_nonlocal_gates()) +fig, (ax1, ax2) = plt.subplots(2, 1) +ax1.bar(levels, depths, label='Depth') +ax1.set_xlabel("Optimization Level") +ax1.set_ylabel("Depth") +ax1.set_title("Output Circuit Depth") +ax2.bar(levels, gate_counts, label='Number of Circuit Operations') +ax2.bar(levels, non_local_gate_counts, label='Number of non-local gates') +ax2.set_xlabel("Optimization Level") +ax2.set_ylabel("Number of gates") +ax2.legend() +ax2.set_title("Number of output circuit gates") +fig.tight_layout() +plt.show() +``` + +![../\_images/transpiler-14.png](/images/api/qiskit/0.46/transpiler-14.png) + + + +### Scheduling Stage + +After the circuit has been translated to the target basis, mapped to the device, and optimized, a scheduling phase can be applied to optionally account for all the idle time in the circuit. At a high level, the scheduling can be thought of as inserting delays into the circuit to account for idle time on the qubits between the execution of instructions. For example, if we start with a circuit such as: + +![../\_images/transpiler-15.png](/images/api/qiskit/0.46/transpiler-15.png) + +we can then call [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") on it with `scheduling_method` set: + +```python +from qiskit import QuantumCircuit, transpile +from qiskit.providers.fake_provider import FakeBoeblingen + +backend = FakeBoeblingen() + +ghz = QuantumCircuit(5) +ghz.h(0) +ghz.cx(0,range(1,5)) + +circ = transpile(ghz, backend, scheduling_method="asap") +circ.draw(output='mpl') +``` + +![../\_images/transpiler-16.png](/images/api/qiskit/0.46/transpiler-16.png) + +You can see here that the transpiler inserted [`Delay`](qiskit.circuit.Delay "qiskit.circuit.Delay") instructions to account for idle time on each qubit. To get a better idea of the timing of the circuit we can also look at it with the `timeline.draw()` function: + +![../\_images/transpiler-17.png](/images/api/qiskit/0.46/transpiler-17.png) + +The scheduling of a circuit involves two parts: analysis and constraint mapping, followed by a padding pass. The first part requires running a scheduling analysis pass such as `ALAPSchedulingAnalysis` or `ASAPSchedulingAnalysis` which analyzes the circuit and records the start time of each instruction in the circuit using a scheduling algorithm (“as late as possible” for `ALAPSchedulingAnalysis` and “as soon as possible” for `ASAPSchedulingAnalysis`) in the property set. Once the circuit has an initial scheduling, additional passes can be run to account for any timing constraints on the target backend, such as alignment constraints. This is typically done with the [`ConstrainedReschedule`](qiskit.transpiler.passes.ConstrainedReschedule "qiskit.transpiler.passes.ConstrainedReschedule") pass which will adjust the scheduling set in the property set to the constraints of the target backend. Once all the scheduling and adjustments/rescheduling are finished, a padding pass, such as [`PadDelay`](qiskit.transpiler.passes.PadDelay "qiskit.transpiler.passes.PadDelay") or [`PadDynamicalDecoupling`](qiskit.transpiler.passes.PadDynamicalDecoupling "qiskit.transpiler.passes.PadDynamicalDecoupling") is run to insert the instructions into the circuit, which completes the scheduling. + +#### Scheduling Analysis with control flow instructions + +When running scheduling analysis passes on a circuit, you must keep in mind that there are additional constraints on classical conditions and control flow instructions. This section covers the details of these additional constraints that any scheduling pass will need to account for. + +##### Topological node ordering in scheduling + +The DAG representation of `QuantumCircuit` respects the node ordering in the classical register wires, though theoretically two conditional instructions conditioned on the same register could commute, i.e. read-access to the classical register doesn’t change its state. + +```python +qc = QuantumCircuit(2, 1) +qc.delay(100, 0) +qc.x(0).c_if(0, True) +qc.x(1).c_if(0, True) +``` + +The scheduler SHOULD comply with the above topological ordering policy of the DAG circuit. Accordingly, the asap-scheduled circuit will become + +```python + ┌────────────────┐ ┌───┐ +q_0: ┤ Delay(100[dt]) ├───┤ X ├────────────── + ├────────────────┤ └─╥─┘ ┌───┐ +q_1: ┤ Delay(100[dt]) ├─────╫────────┤ X ├─── + └────────────────┘ ║ └─╥─┘ + ┌────╨────┐┌────╨────┐ +c: 1/══════════════════╡ c_0=0x1 ╞╡ c_0=0x1 ╞ + └─────────┘└─────────┘ +``` + +Note that this scheduling might be inefficient in some cases, because the second conditional operation could start without waiting for the 100 dt delay. However, any additional optimization should be done in a different pass, not to break the topological ordering of the original circuit. + +##### Realistic control flow scheduling (respecting microarchitecture) + +In the dispersive QND readout scheme, the qubit (Q) is measured by sending a microwave stimulus, followed by a resonator ring-down (depopulation). This microwave signal is recorded in the buffer memory (B) with the hardware kernel, then a discriminated (D) binary value is moved to the classical register (C). A sequence from t0 to t1 of the measure instruction interval could be modeled as follows: + +```python +Q ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ +B ░░▒▒▒▒▒▒▒▒░░░░░░░░░ +D ░░░░░░░░░░▒▒▒▒▒▒░░░ +C ░░░░░░░░░░░░░░░░▒▒░ +``` + +However, the [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") representation is not accurate enough to represent this model. In the circuit representation, the corresponding [`Qubit`](qiskit.circuit.Qubit "qiskit.circuit.Qubit") is occupied by the stimulus microwave signal during the first half of the interval, and the [`Clbit`](qiskit.circuit.Clbit "qiskit.circuit.Clbit") is only occupied at the very end of the interval. + +The lack of precision representing the physical model may induce edge cases in the scheduling: + +```python + ┌───┐ +q_0: ───┤ X ├────── + └─╥─┘ ┌─┐ +q_1: ─────╫─────┤M├ + ┌────╨────┐└╥┘ +c: 1/╡ c_0=0x1 ╞═╩═ + └─────────┘ 0 +``` + +In this example, a user may intend to measure the state of `q_1` after the [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") is applied to `q_0`. This is the correct interpretation from the viewpoint of topological node ordering, i.e. The [`XGate`](qiskit.circuit.library.XGate "qiskit.circuit.library.XGate") node comes in front of the [`Measure`](qiskit.circuit.library.Measure "qiskit.circuit.library.Measure") node. However, according to the measurement model above, the data in the register is unchanged during the application of the stimulus, so two nodes are simultaneously operated. If one tries to alap-schedule this circuit, it may return following circuit: + +```python + ┌────────────────┐ ┌───┐ +q_0: ┤ Delay(500[dt]) ├───┤ X ├────── + └────────────────┘ └─╥─┘ ┌─┐ +q_1: ───────────────────────╫─────┤M├ + ┌────╨────┐└╥┘ +c: 1/══════════════════╡ c_0=0x1 ╞═╩═ + └─────────┘ 0 +``` + +Note that there is no delay on the `q_1` wire, and the measure instruction immediately starts after t=0, while the conditional gate starts after the delay. It looks like the topological ordering between the nodes is flipped in the scheduled view. This behavior can be understood by considering the control flow model described above, + +```python +: Quantum Circuit, first-measure +0 ░░░░░░░░░░░░▒▒▒▒▒▒░ +1 ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ + +: In wire q0 +Q ░░░░░░░░░░░░░░░▒▒▒░ +C ░░░░░░░░░░░░▒▒░░░░░ + +: In wire q1 +Q ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ +B ░░▒▒▒▒▒▒▒▒░░░░░░░░░ +D ░░░░░░░░░░▒▒▒▒▒▒░░░ +C ░░░░░░░░░░░░░░░░▒▒░ +``` + +Since there is no qubit register overlap between Q0 and Q1, the node ordering is determined by the shared classical register C. As you can see, the execution order is still preserved on C, i.e. read C then apply `XGate`, finally store the measured outcome in C. But because `DAGOpNode` cannot define different durations for the associated registers, the time ordering of the two nodes is inverted. + +This behavior can be controlled by `clbit_write_latency` and `conditional_latency`. `clbit_write_latency` determines the delay of the register write-access from the beginning of the measure instruction (t0), while `conditional_latency` determines the delay of conditional gate operations with respect to t0, which is determined by the register read-access. This information is accessible in the backend configuration and should be copied to the pass manager property set before the pass is called. + +Due to default latencies, the alap-scheduled circuit of above example may become + +```python + ┌───┐ +q_0: ───┤ X ├────── + └─╥─┘ ┌─┐ +q_1: ─────╫─────┤M├ + ┌────╨────┐└╥┘ +c: 1/╡ c_0=0x1 ╞═╩═ + └─────────┘ 0 +``` + +If the backend microarchitecture supports smart scheduling of the control flow instructions, such as separately scheduling qubits and classical registers, the insertion of the delay yields an unnecessarily longer total execution time. + +```python +: Quantum Circuit, first-XGate +0 ░▒▒▒░░░░░░░░░░░░░░░ +1 ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ + +: In wire q0 +Q ░▒▒▒░░░░░░░░░░░░░░░ +C ░░░░░░░░░░░░░░░░░░░ (zero latency) + +: In wire q1 +Q ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ +C ░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ (zero latency, scheduled after C0 read-access) +``` + +However, this result is much more intuitive in the topological ordering view. If a finite conditional latency value is provided, for example, 30 dt, the circuit is scheduled as follows: + +```python + ┌───────────────┐ ┌───┐ +q_0: ┤ Delay(30[dt]) ├───┤ X ├────── + ├───────────────┤ └─╥─┘ ┌─┐ +q_1: ┤ Delay(30[dt]) ├─────╫─────┤M├ + └───────────────┘┌────╨────┐└╥┘ +c: 1/═════════════════╡ c_0=0x1 ╞═╩═ + └─────────┘ 0 +``` + +with the timing model: + +```python +: Quantum Circuit, first-xgate +0 ░░▒▒▒░░░░░░░░░░░░░░░ +1 ░░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ + +: In wire q0 +Q ░░▒▒▒░░░░░░░░░░░░░░░ +C ░▒░░░░░░░░░░░░░░░░░░ (30dt latency) + +: In wire q1 +Q ░░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ +C ░░▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒▒░ +``` + +See [https://arxiv.org/abs/2102.01682](https://arxiv.org/abs/2102.01682) for more details. + +## Transpiler API + +### Transpiler Target + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | +| [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target")(\[description, num\_qubits, dt, ...]) | The intent of the `Target` object is to inform Qiskit's compiler about the constraints of a particular backend so the compiler can compile an input circuit to something that works and is optimized for a device. | +| [`InstructionProperties`](qiskit.transpiler.InstructionProperties "qiskit.transpiler.InstructionProperties")(\[duration, error, ...]) | A representation of the properties of a gate implementation. | + +### Pass Manager Construction + +| | | +| ------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------- | +| [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager")(\[stages]) | A pass manager pipeline built from individual stages. | +| [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager")(\[passes, max\_iteration]) | Manager for a set of Passes and their scheduling during transpilation. | +| [`PassManagerConfig`](qiskit.transpiler.PassManagerConfig "qiskit.transpiler.PassManagerConfig")(\[initial\_layout, ...]) | Pass Manager Configuration. | + +### Layout and Topology + +| | | +| ------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------ | +| [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout")(\[input\_dict]) | Two-ways dict to represent a Layout. | +| [`CouplingMap`](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")(\[couplinglist, description]) | Directed graph specifying fixed coupling. | +| [`TranspileLayout`](qiskit.transpiler.TranspileLayout "qiskit.transpiler.TranspileLayout")(initial\_layout, ...\[, ...]) | Layout attributes from output circuit from transpiler. | + +### Scheduling + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------- | +| [`InstructionDurations`](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations")(\[instruction\_durations, dt]) | Helper class to provide durations of instructions for scheduling. | + +### Fenced Objects + +| | | +| ------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------ | +| [`FencedPropertySet`](qiskit.transpiler.FencedPropertySet "qiskit.transpiler.FencedPropertySet")(property\_set\_instance) | A property set that cannot be written (via \_\_setitem\_\_) | +| [`FencedDAGCircuit`](qiskit.transpiler.FencedDAGCircuit "qiskit.transpiler.FencedDAGCircuit")(dag\_circuit\_instance) | A dag circuit that cannot be modified (via remove\_op\_node) | + +### Abstract Passes + +| | | +| ----------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------- | +| [`TransformationPass`](qiskit.transpiler.TransformationPass "qiskit.transpiler.TransformationPass")(\*args, \*\*kwargs) | A transformation pass: change DAG, not property set. | +| [`AnalysisPass`](qiskit.transpiler.AnalysisPass "qiskit.transpiler.AnalysisPass")(\*args, \*\*kwargs) | An analysis pass: change property set, not DAG. | + +### Exceptions + +### TranspilerError + + + +`qiskit.transpiler.TranspilerError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/exceptions.py "view source code") + +Exceptions raised during transpilation. + +Set the error message. + +### TranspilerAccessError + + + +`qiskit.transpiler.TranspilerAccessError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/exceptions.py "view source code") + +DEPRECATED: Exception of access error in the transpiler passes. + +Set the error message. + +### CouplingError + + + +`qiskit.transpiler.CouplingError(*msg)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/exceptions.py "view source code") + +Base class for errors raised by the coupling graph object. + +Set the error message. + +### LayoutError + + + +`qiskit.transpiler.LayoutError(*msg)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/exceptions.py "view source code") + +Errors raised by the layout object. + +Set the error message. + diff --git a/docs/api/qiskit/0.46/transpiler_builtin_plugins.md b/docs/api/qiskit/0.46/transpiler_builtin_plugins.md new file mode 100644 index 00000000000..c5595272581 --- /dev/null +++ b/docs/api/qiskit/0.46/transpiler_builtin_plugins.md @@ -0,0 +1,8 @@ + + +# Built-in Transpiler Synthesis Plugins + +* [Approximate Quantum Compiler (`qiskit.synthesis.unitary.aqc`)](synthesis_aqc) + + * [Interface](synthesis_aqc#interface) + * [Mathematical Detail](synthesis_aqc#mathematical-detail) diff --git a/docs/api/qiskit/0.46/transpiler_passes.md b/docs/api/qiskit/0.46/transpiler_passes.md new file mode 100644 index 00000000000..186692598c3 --- /dev/null +++ b/docs/api/qiskit/0.46/transpiler_passes.md @@ -0,0 +1,162 @@ +--- +title: passes +description: API reference for qiskit.transpiler.passes +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.transpiler.passes +--- + + + + + + + +# Transpiler Passes + + + +`qiskit.transpiler.passes` + +## Layout Selection (Placement) + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------- | +| [`SetLayout`](qiskit.transpiler.passes.SetLayout "qiskit.transpiler.passes.SetLayout")(\*args, \*\*kwargs) | Set the `layout` property to the given layout. | +| [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout")(\*args, \*\*kwargs) | Choose a Layout by assigning `n` circuit qubits to device qubits `0, .., n-1`. | +| [`DenseLayout`](qiskit.transpiler.passes.DenseLayout "qiskit.transpiler.passes.DenseLayout")(\*args, \*\*kwargs) | Choose a Layout by finding the most connected subset of qubits. | +| [`NoiseAdaptiveLayout`](qiskit.transpiler.passes.NoiseAdaptiveLayout "qiskit.transpiler.passes.NoiseAdaptiveLayout")(\*args, \*\*kwargs) | Choose a noise-adaptive Layout based on current calibration data for the backend. | +| [`SabreLayout`](qiskit.transpiler.passes.SabreLayout "qiskit.transpiler.passes.SabreLayout")(\*args, \*\*kwargs) | Choose a Layout via iterative bidirectional routing of the input circuit. | +| [`CSPLayout`](qiskit.transpiler.passes.CSPLayout "qiskit.transpiler.passes.CSPLayout")(\*args, \*\*kwargs) | If possible, chooses a Layout as a CSP, using backtracking. | +| [`VF2Layout`](qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout")(\*args, \*\*kwargs) | A pass for choosing a Layout of a circuit onto a Coupling graph, as a subgraph isomorphism problem, solved by VF2++. | +| [`ApplyLayout`](qiskit.transpiler.passes.ApplyLayout "qiskit.transpiler.passes.ApplyLayout")(\*args, \*\*kwargs) | Transform a circuit with virtual qubits into a circuit with physical qubits. | +| [`Layout2qDistance`](qiskit.transpiler.passes.Layout2qDistance "qiskit.transpiler.passes.Layout2qDistance")(\*args, \*\*kwargs) | Evaluate how good the layout selection was. | +| [`EnlargeWithAncilla`](qiskit.transpiler.passes.EnlargeWithAncilla "qiskit.transpiler.passes.EnlargeWithAncilla")(\*args, \*\*kwargs) | Extend the dag with virtual qubits that are in layout but not in the circuit yet. | +| [`FullAncillaAllocation`](qiskit.transpiler.passes.FullAncillaAllocation "qiskit.transpiler.passes.FullAncillaAllocation")(\*args, \*\*kwargs) | Allocate all idle nodes from the coupling map or target as ancilla on the layout. | +| [`SabrePreLayout`](qiskit.transpiler.passes.SabrePreLayout "qiskit.transpiler.passes.SabrePreLayout")(\*args, \*\*kwargs) | Choose a starting layout to use for additional Sabre layout trials. | + +## Routing + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------- | +| [`BasicSwap`](qiskit.transpiler.passes.BasicSwap "qiskit.transpiler.passes.BasicSwap")(\*args, \*\*kwargs) | Map (with minimum effort) a DAGCircuit onto a `coupling_map` adding swap gates. | +| [`LookaheadSwap`](qiskit.transpiler.passes.LookaheadSwap "qiskit.transpiler.passes.LookaheadSwap")(\*args, \*\*kwargs) | Map input circuit onto a backend topology via insertion of SWAPs. | +| [`StochasticSwap`](qiskit.transpiler.passes.StochasticSwap "qiskit.transpiler.passes.StochasticSwap")(\*args, \*\*kwargs) | Map a DAGCircuit onto a coupling\_map adding swap gates. | +| [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap")(\*args, \*\*kwargs) | Map input circuit onto a backend topology via insertion of SWAPs. | +| [`Commuting2qGateRouter`](qiskit.transpiler.passes.Commuting2qGateRouter "qiskit.transpiler.passes.Commuting2qGateRouter")(\*args, \*\*kwargs) | A class to swap route one or more commuting gates to the coupling map. | + +## Basis Change + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------- | +| [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator")(\*args, \*\*kwargs) | Translates gates to a target basis by searching for a set of translations from a given EquivalenceLibrary. | +| [`Decompose`](qiskit.transpiler.passes.Decompose "qiskit.transpiler.passes.Decompose")(\*args, \*\*kwargs) | Expand a gate in a circuit using its decomposition rules. | +| [`TranslateParameterizedGates`](qiskit.transpiler.passes.TranslateParameterizedGates "qiskit.transpiler.passes.TranslateParameterizedGates")(\*args, \*\*kwargs) | Translate parameterized gates to a supported basis set. | +| [`Unroll3qOrMore`](qiskit.transpiler.passes.Unroll3qOrMore "qiskit.transpiler.passes.Unroll3qOrMore")(\*args, \*\*kwargs) | Recursively expands 3q+ gates until the circuit only contains 2q or 1q gates. | +| [`UnrollCustomDefinitions`](qiskit.transpiler.passes.UnrollCustomDefinitions "qiskit.transpiler.passes.UnrollCustomDefinitions")(\*args, \*\*kwargs) | Unrolls instructions with custom definitions. | +| [`Unroller`](qiskit.transpiler.passes.Unroller "qiskit.transpiler.passes.Unroller")(\*args, \*\*kwargs) | Unroll a circuit to a given basis. | + +## Optimizations + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`Optimize1qGates`](qiskit.transpiler.passes.Optimize1qGates "qiskit.transpiler.passes.Optimize1qGates")(\*args, \*\*kwargs) | Optimize chains of single-qubit u1, u2, u3 gates by combining them into a single gate. | +| [`Optimize1qGatesDecomposition`](qiskit.transpiler.passes.Optimize1qGatesDecomposition "qiskit.transpiler.passes.Optimize1qGatesDecomposition")(\*args, \*\*kwargs) | Optimize chains of single-qubit gates by combining them into a single gate. | +| [`Collect1qRuns`](qiskit.transpiler.passes.Collect1qRuns "qiskit.transpiler.passes.Collect1qRuns")(\*args, \*\*kwargs) | Collect one-qubit subcircuits. | +| [`Collect2qBlocks`](qiskit.transpiler.passes.Collect2qBlocks "qiskit.transpiler.passes.Collect2qBlocks")(\*args, \*\*kwargs) | Collect two-qubit subcircuits. | +| [`CollectMultiQBlocks`](qiskit.transpiler.passes.CollectMultiQBlocks "qiskit.transpiler.passes.CollectMultiQBlocks")(\*args, \*\*kwargs) | Collect sequences of uninterrupted gates acting on groups of qubits. | +| [`CollectLinearFunctions`](qiskit.transpiler.passes.CollectLinearFunctions "qiskit.transpiler.passes.CollectLinearFunctions")(\*args, \*\*kwargs) | Collect blocks of linear gates ([`CXGate`](qiskit.circuit.library.CXGate "qiskit.circuit.library.CXGate") and [`SwapGate`](qiskit.circuit.library.SwapGate "qiskit.circuit.library.SwapGate") gates) and replaces them by linear functions ([`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.LinearFunction")). | +| [`CollectCliffords`](qiskit.transpiler.passes.CollectCliffords "qiskit.transpiler.passes.CollectCliffords")(\*args, \*\*kwargs) | Collects blocks of Clifford gates and replaces them by a [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") object. | +| [`ConsolidateBlocks`](qiskit.transpiler.passes.ConsolidateBlocks "qiskit.transpiler.passes.ConsolidateBlocks")(\*args, \*\*kwargs) | Replace each block of consecutive gates by a single Unitary node. | +| [`CXCancellation`](qiskit.transpiler.passes.CXCancellation "qiskit.transpiler.passes.CXCancellation")(\*args, \*\*kwargs) | Cancel back-to-back `cx` gates in dag. | +| [`InverseCancellation`](qiskit.transpiler.passes.InverseCancellation "qiskit.transpiler.passes.InverseCancellation")(\*args, \*\*kwargs) | Cancel specific Gates which are inverses of each other when they occur back-to- back. | +| [`CommutationAnalysis`](qiskit.transpiler.passes.CommutationAnalysis "qiskit.transpiler.passes.CommutationAnalysis")(\*args, \*\*kwargs) | Analysis pass to find commutation relations between DAG nodes. | +| [`CommutativeCancellation`](qiskit.transpiler.passes.CommutativeCancellation "qiskit.transpiler.passes.CommutativeCancellation")(\*args, \*\*kwargs) | Cancel the redundant (self-adjoint) gates through commutation relations. | +| [`CommutativeInverseCancellation`](qiskit.transpiler.passes.CommutativeInverseCancellation "qiskit.transpiler.passes.CommutativeInverseCancellation")(\*args, \*\*kwargs) | Cancel pairs of inverse gates exploiting commutation relations. | +| [`Optimize1qGatesSimpleCommutation`](qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation "qiskit.transpiler.passes.Optimize1qGatesSimpleCommutation")(\*args, \*\*kwargs) | Optimizes 1Q gate strings interrupted by 2Q gates by commuting the components and resynthesizing the results. | +| [`RemoveDiagonalGatesBeforeMeasure`](qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure "qiskit.transpiler.passes.RemoveDiagonalGatesBeforeMeasure")(\*args, \*\*kwargs) | Remove diagonal gates (including diagonal 2Q gates) before a measurement. | +| [`RemoveResetInZeroState`](qiskit.transpiler.passes.RemoveResetInZeroState "qiskit.transpiler.passes.RemoveResetInZeroState")(\*args, \*\*kwargs) | Remove reset gate when the qubit is in zero state. | +| [`CrosstalkAdaptiveSchedule`](qiskit.transpiler.passes.CrosstalkAdaptiveSchedule "qiskit.transpiler.passes.CrosstalkAdaptiveSchedule")(\*args, \*\*kwargs) | Crosstalk mitigation through adaptive instruction scheduling. | +| [`HoareOptimizer`](qiskit.transpiler.passes.HoareOptimizer "qiskit.transpiler.passes.HoareOptimizer")(\*args, \*\*kwargs) | This is a transpiler pass using Hoare logic circuit optimization. | +| [`TemplateOptimization`](qiskit.transpiler.passes.TemplateOptimization "qiskit.transpiler.passes.TemplateOptimization")(\*args, \*\*kwargs) | Class for the template optimization pass. | +| [`EchoRZXWeylDecomposition`](qiskit.transpiler.passes.EchoRZXWeylDecomposition "qiskit.transpiler.passes.EchoRZXWeylDecomposition")(\*args, \*\*kwargs) | Rewrite two-qubit gates using the Weyl decomposition. | +| [`ResetAfterMeasureSimplification`](qiskit.transpiler.passes.ResetAfterMeasureSimplification "qiskit.transpiler.passes.ResetAfterMeasureSimplification")(\*args, \*\*kwargs) | This pass replaces reset after measure with a conditional X gate. | +| [`OptimizeCliffords`](qiskit.transpiler.passes.OptimizeCliffords "qiskit.transpiler.passes.OptimizeCliffords")(\*args, \*\*kwargs) | Combine consecutive Cliffords over the same qubits. | +| [`NormalizeRXAngle`](qiskit.transpiler.passes.NormalizeRXAngle "qiskit.transpiler.passes.NormalizeRXAngle")(\*args, \*\*kwargs) | Normalize theta parameter of RXGate instruction. | + +## Calibration + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------ | +| [`PulseGates`](qiskit.transpiler.passes.PulseGates "qiskit.transpiler.passes.PulseGates")(\*args, \*\*kwargs) | Pulse gate adding pass. | +| [`RZXCalibrationBuilder`](qiskit.transpiler.passes.RZXCalibrationBuilder "qiskit.transpiler.passes.RZXCalibrationBuilder")(\*args, \*\*kwargs) | Creates calibrations for RZXGate(theta) by stretching and compressing Gaussian square pulses in the CX gate. | +| [`RZXCalibrationBuilderNoEcho`](qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho "qiskit.transpiler.passes.RZXCalibrationBuilderNoEcho")(\*args, \*\*kwargs) | Creates calibrations for RZXGate(theta) by stretching and compressing Gaussian square pulses in the CX gate. | +| [`RXCalibrationBuilder`](qiskit.transpiler.passes.RXCalibrationBuilder "qiskit.transpiler.passes.RXCalibrationBuilder")(\*args, \*\*kwargs) | Add single-pulse RX calibrations that are bootstrapped from the SX calibration. | + +## Scheduling + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- | +| [`TimeUnitConversion`](qiskit.transpiler.passes.TimeUnitConversion "qiskit.transpiler.passes.TimeUnitConversion")(\*args, \*\*kwargs) | Choose a time unit to be used in the following time-aware passes, and make all circuit time units consistent with that. | +| [`ALAPScheduleAnalysis`](qiskit.transpiler.passes.ALAPScheduleAnalysis "qiskit.transpiler.passes.ALAPScheduleAnalysis")(\*args, \*\*kwargs) | ALAP Scheduling pass, which schedules the **stop** time of instructions as late as possible. | +| [`ASAPScheduleAnalysis`](qiskit.transpiler.passes.ASAPScheduleAnalysis "qiskit.transpiler.passes.ASAPScheduleAnalysis")(\*args, \*\*kwargs) | ASAP Scheduling pass, which schedules the start time of instructions as early as possible. | +| [`PadDynamicalDecoupling`](qiskit.transpiler.passes.PadDynamicalDecoupling "qiskit.transpiler.passes.PadDynamicalDecoupling")(\*args, \*\*kwargs) | Dynamical decoupling insertion pass. | +| [`PadDelay`](qiskit.transpiler.passes.PadDelay "qiskit.transpiler.passes.PadDelay")(\*args, \*\*kwargs) | Padding idle time with Delay instructions. | +| [`ConstrainedReschedule`](qiskit.transpiler.passes.ConstrainedReschedule "qiskit.transpiler.passes.ConstrainedReschedule")(\*args, \*\*kwargs) | Rescheduler pass that updates node start times to conform to the hardware alignments. | +| [`ValidatePulseGates`](qiskit.transpiler.passes.ValidatePulseGates "qiskit.transpiler.passes.ValidatePulseGates")(\*args, \*\*kwargs) | Check custom gate length. | +| [`InstructionDurationCheck`](qiskit.transpiler.passes.InstructionDurationCheck "qiskit.transpiler.passes.InstructionDurationCheck")(\*args, \*\*kwargs) | Duration validation pass for reschedule. | +| [`SetIOLatency`](qiskit.transpiler.passes.SetIOLatency "qiskit.transpiler.passes.SetIOLatency")(\*args, \*\*kwargs) | Set IOLatency information to the input circuit. | +| [`ALAPSchedule`](qiskit.transpiler.passes.ALAPSchedule "qiskit.transpiler.passes.ALAPSchedule")(\*args, \*\*kwargs) | ALAP Scheduling pass, which schedules the **stop** time of instructions as late as possible. | +| [`ASAPSchedule`](qiskit.transpiler.passes.ASAPSchedule "qiskit.transpiler.passes.ASAPSchedule")(\*args, \*\*kwargs) | ASAP Scheduling pass, which schedules the start time of instructions as early as possible.. | +| [`DynamicalDecoupling`](qiskit.transpiler.passes.DynamicalDecoupling "qiskit.transpiler.passes.DynamicalDecoupling")(\*args, \*\*kwargs) | Dynamical decoupling insertion pass. | +| [`AlignMeasures`](qiskit.transpiler.passes.AlignMeasures "qiskit.transpiler.passes.AlignMeasures")(\*args, \*\*kwargs) | Measurement alignment. | + +## Circuit Analysis + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`Width`](qiskit.transpiler.passes.Width "qiskit.transpiler.passes.Width")(\*args, \*\*kwargs) | Calculate the width of a DAG circuit. | +| [`Depth`](qiskit.transpiler.passes.Depth "qiskit.transpiler.passes.Depth")(\*args, \*\*kwargs) | Calculate the depth of a DAG circuit. | +| [`Size`](qiskit.transpiler.passes.Size "qiskit.transpiler.passes.Size")(\*args, \*\*kwargs) | Calculate the size of a DAG circuit. | +| [`CountOps`](qiskit.transpiler.passes.CountOps "qiskit.transpiler.passes.CountOps")(\*args, \*\*kwargs) | Count the operations in a DAG circuit. | +| [`CountOpsLongestPath`](qiskit.transpiler.passes.CountOpsLongestPath "qiskit.transpiler.passes.CountOpsLongestPath")(\*args, \*\*kwargs) | Count the operations on the longest path in a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit"). | +| [`NumTensorFactors`](qiskit.transpiler.passes.NumTensorFactors "qiskit.transpiler.passes.NumTensorFactors")(\*args, \*\*kwargs) | Calculate the number of tensor factors of a DAG circuit. | +| [`DAGLongestPath`](qiskit.transpiler.passes.DAGLongestPath "qiskit.transpiler.passes.DAGLongestPath")(\*args, \*\*kwargs) | Return the longest path in a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") as a list of [`DAGOpNode`](qiskit.dagcircuit.DAGOpNode "qiskit.dagcircuit.DAGOpNode")s, [`DAGInNode`](qiskit.dagcircuit.DAGInNode "qiskit.dagcircuit.DAGInNode")s, and [`DAGOutNode`](qiskit.dagcircuit.DAGOutNode "qiskit.dagcircuit.DAGOutNode")s. | + +## Synthesis + +| | | +| ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------- | +| [`UnitarySynthesis`](qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis")(\*args, \*\*kwargs) | Synthesize gates according to their basis gates. | +| [`LinearFunctionsSynthesis`](qiskit.transpiler.passes.LinearFunctionsSynthesis "qiskit.transpiler.passes.LinearFunctionsSynthesis")(\*args, \*\*kwargs) | DEPRECATED: Synthesize linear functions. | +| [`LinearFunctionsToPermutations`](qiskit.transpiler.passes.LinearFunctionsToPermutations "qiskit.transpiler.passes.LinearFunctionsToPermutations")(\*args, \*\*kwargs) | Promotes linear functions to permutations when possible. | +| [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis")(\*args, \*\*kwargs) | Synthesize higher-level objects and unroll custom definitions. | +| [`SolovayKitaev`](qiskit.transpiler.passes.SolovayKitaev "qiskit.transpiler.passes.SolovayKitaev")(\*args, \*\*kwargs) | Approximately decompose 1q gates to a discrete basis using the Solovay-Kitaev algorithm. | +| [`SolovayKitaevSynthesis`](qiskit.transpiler.passes.SolovayKitaevSynthesis "qiskit.transpiler.passes.SolovayKitaevSynthesis")() | A Solovay-Kitaev Qiskit unitary synthesis plugin. | +| [`AQCSynthesisPlugin`](qiskit.transpiler.passes.AQCSynthesisPlugin "qiskit.transpiler.passes.AQCSynthesisPlugin")() | An AQC-based Qiskit unitary synthesis plugin. | + +## Post Layout (Post transpile qubit selection) + +| | | +| ---------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------- | +| [`VF2PostLayout`](qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout")(\*args, \*\*kwargs) | A pass for choosing a Layout after transpilation of a circuit onto a Coupling graph, as a subgraph isomorphism problem, solved by VF2++. | + +## Additional Passes + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------- | +| [`CheckMap`](qiskit.transpiler.passes.CheckMap "qiskit.transpiler.passes.CheckMap")(\*args, \*\*kwargs) | Check if a DAG circuit is already mapped to a coupling map. | +| [`CheckGateDirection`](qiskit.transpiler.passes.CheckGateDirection "qiskit.transpiler.passes.CheckGateDirection")(\*args, \*\*kwargs) | Check if the two-qubit gates follow the right direction with respect to the coupling map. | +| [`GateDirection`](qiskit.transpiler.passes.GateDirection "qiskit.transpiler.passes.GateDirection")(\*args, \*\*kwargs) | Modify asymmetric gates to match the hardware coupling direction. | +| [`MergeAdjacentBarriers`](qiskit.transpiler.passes.MergeAdjacentBarriers "qiskit.transpiler.passes.MergeAdjacentBarriers")(\*args, \*\*kwargs) | Return a circuit with any adjacent barriers merged together. | +| [`RemoveBarriers`](qiskit.transpiler.passes.RemoveBarriers "qiskit.transpiler.passes.RemoveBarriers")(\*args, \*\*kwargs) | Return a circuit with any barrier removed. | +| [`BarrierBeforeFinalMeasurements`](qiskit.transpiler.passes.BarrierBeforeFinalMeasurements "qiskit.transpiler.passes.BarrierBeforeFinalMeasurements")(\*args, \*\*kwargs) | Add a barrier before final measurements. | +| [`RemoveFinalMeasurements`](qiskit.transpiler.passes.RemoveFinalMeasurements "qiskit.transpiler.passes.RemoveFinalMeasurements")(\*args, \*\*kwargs) | Remove final measurements and barriers at the end of a circuit. | +| [`DAGFixedPoint`](qiskit.transpiler.passes.DAGFixedPoint "qiskit.transpiler.passes.DAGFixedPoint")(\*args, \*\*kwargs) | Check if the DAG has reached a fixed point. | +| [`FixedPoint`](qiskit.transpiler.passes.FixedPoint "qiskit.transpiler.passes.FixedPoint")(\*args, \*\*kwargs) | Check if a property reached a fixed point. | +| [`MinimumPoint`](qiskit.transpiler.passes.MinimumPoint "qiskit.transpiler.passes.MinimumPoint")(\*args, \*\*kwargs) | Check if the DAG has reached a relative semi-stable point over previous runs | +| [`ContainsInstruction`](qiskit.transpiler.passes.ContainsInstruction "qiskit.transpiler.passes.ContainsInstruction")(\*args, \*\*kwargs) | An analysis pass to detect if the DAG contains a specific instruction. | +| [`GatesInBasis`](qiskit.transpiler.passes.GatesInBasis "qiskit.transpiler.passes.GatesInBasis")(\*args, \*\*kwargs) | Check if all gates in a DAG are in a given set of gates | +| [`ConvertConditionsToIfOps`](qiskit.transpiler.passes.ConvertConditionsToIfOps "qiskit.transpiler.passes.ConvertConditionsToIfOps")(\*args, \*\*kwargs) | Convert instructions whose `condition` attribute is set to a non-`None` value into the equivalent single-statement `IfElseBlock`. | +| [`UnrollForLoops`](qiskit.transpiler.passes.UnrollForLoops "qiskit.transpiler.passes.UnrollForLoops")(\*args, \*\*kwargs) | `UnrollForLoops` transpilation pass unrolls for-loops when possible. | + diff --git a/docs/api/qiskit/0.46/transpiler_plugins.md b/docs/api/qiskit/0.46/transpiler_plugins.md new file mode 100644 index 00000000000..8a999a278ca --- /dev/null +++ b/docs/api/qiskit/0.46/transpiler_plugins.md @@ -0,0 +1,170 @@ +--- +title: plugin +description: API reference for qiskit.transpiler.preset_passmanagers.plugin +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.transpiler.preset_passmanagers.plugin +--- + + + + + + + +# Transpiler Stage Plugin Interface + + + +`qiskit.transpiler.preset_passmanagers.plugin` + +This module defines the plugin interface for providing custom stage implementations for the preset pass managers and the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function. This enables external Python packages to provide [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") objects that can be used for each named stage. + +The plugin interfaces are built using setuptools [entry points](https://setuptools.readthedocs.io/en/latest/userguide/entry_point.html) which enable packages external to Qiskit to advertise they include a transpiler stage(s). + +For details on how to instead write plugins for transpiler synthesis methods, see [`qiskit.transpiler.passes.synthesis.plugin`](transpiler_synthesis_plugins#module-qiskit.transpiler.passes.synthesis.plugin "qiskit.transpiler.passes.synthesis.plugin"). + + + +## Plugin Stages + +Currently, there are 6 stages in the preset pass managers, all of which actively load external plugins via corresponding entry points. + +| Stage Name | Entry Point | Reserved Names | Description and expectations | +| -------------- | -------------------------------- | -------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| `init` | `qiskit.transpiler.init` | `default` | This stage runs first and is typically used for any initial logical optimization. Because most layout and routing algorithms are only designed to work with 1 and 2 qubit gates, this stage is also used to translate any gates that operate on more than 2 qubits into gates that only operate on 1 or 2 qubits. | +| `layout` | `qiskit.transpiler.layout` | `trivial`, `dense`, `noise_adaptive`, `sabre`, `default` | The output from this stage is expected to have the `layout` property set field set with a [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") object. Additionally, the circuit is typically expected to be embedded so that it is expanded to include all qubits and the [`ApplyLayout`](qiskit.transpiler.passes.ApplyLayout "qiskit.transpiler.passes.ApplyLayout") pass is expected to be run to apply the layout. The embedding of the [`Layout`](qiskit.transpiler.Layout "qiskit.transpiler.Layout") can be generated with [`generate_embed_passmanager()`](transpiler_preset#qiskit.transpiler.preset_passmanagers.common.generate_embed_passmanager "qiskit.transpiler.preset_passmanagers.common.generate_embed_passmanager"). | +| `routing` | `qiskit.transpiler.routing` | `basic`, `stochastic`, `lookahead`, `sabre`, `toqm` | The output from this stage is expected to have the circuit match the connectivity constraints of the target backend. This does not necessarily need to match the directionality of the edges in the target as a later stage typically will adjust directional gates to match that constraint (but there is no penalty for doing that in the `routing` stage). | +| `translation` | `qiskit.transpiler.translation` | `translator`, `synthesis`, `unroller` | **The output of this stage is expected to have every operation be a native**instruction on the target backend. | +| `optimization` | `qiskit.transpiler.optimization` | `default` | This stage is expected to perform optimization and simplification. The constraints from earlier stages still apply to the output of this stage. After the `optimization` stage is run we expect the circuit to still be executable on the target. | +| `scheduling` | `qiskit.transpiler.scheduling` | `alap`, `asap`, `default` | This is the last stage run and it is expected to output a scheduled circuit such that all idle periods in the circuit are marked by explicit [`Delay`](qiskit.circuit.Delay "qiskit.circuit.Delay") instructions. | + +## Writing Plugins + +To write a pass manager stage plugin there are 2 main steps. The first step is to create a subclass of the abstract plugin class [`PassManagerStagePlugin`](qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin "qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin") which is used to define how the [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") for the stage will be constructed. For example, to create a `layout` stage plugin that just runs [`VF2Layout`](qiskit.transpiler.passes.VF2Layout "qiskit.transpiler.passes.VF2Layout") (with increasing amount of trials, depending on the optimization level) and falls back to using [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout") if `VF2Layout` is unable to find a perfect layout: + +```python +from qiskit.transpiler.preset_passmanagers.plugin import PassManagerStagePlugin +from qiskit.transpiler.preset_passmanagers import common +from qiskit.transpiler import PassManager +from qiskit.transpiler.passes import VF2Layout, TrivialLayout +from qiskit.transpiler.passes.layout.vf2_layout import VF2LayoutStopReason + + +def _vf2_match_not_found(property_set): + return property_set["layout"] is None or ( + property_set["VF2Layout_stop_reason"] is not None + and property_set["VF2Layout_stop_reason"] is not VF2LayoutStopReason.SOLUTION_FOUND + + +class VF2LayoutPlugin(PassManagerStagePlugin): + + def pass_manager(self, pass_manager_config, optimization_level): + layout_pm = PassManager( + [ + VF2Layout( + coupling_map=pass_manager_config.coupling_map, + properties=pass_manager_config.backend_properties, + max_trials=optimization_level * 10 + 1 + target=pass_manager_config.target + ) + ] + ) + layout_pm.append( + TrivialLayout(pass_manager_config.coupling_map), + condition=_vf2_match_not_found, + ) + layout_pm += common.generate_embed_passmanager(pass_manager_config.coupling_map) + return layout_pm +``` + +The second step is to expose the [`PassManagerStagePlugin`](qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin "qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin") subclass as a setuptools entry point in the package metadata. This can be done by simply adding an `entry_points` entry to the `setuptools.setup` call in the `setup.py` or the plugin package with the necessary entry points under the appropriate namespace for the stage your plugin is for. You can see the list of stages, entry points, and expectations from the stage in [Plugin Stages](#stage-table). For example, continuing from the example plugin above: + +```python +entry_points = { + 'qiskit.transpiler.layout': [ + 'vf2 = qiskit_plugin_pkg.module.plugin:VF2LayoutPlugin', + ] +}, +``` + +Note that the entry point `name = path` is a single string not a Python expression. There isn’t a limit to the number of plugins a single package can include as long as each plugin has a unique name. So a single package can expose multiple plugins if necessary. Refer to [Plugin Stages](#stage-table) for a list of reserved names for each stage. + +## Plugin API + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| [`PassManagerStagePlugin`](qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin "qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePlugin")() | A `PassManagerStagePlugin` is a plugin interface object for using custom stages in [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"). | +| [`PassManagerStagePluginManager`](qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager "qiskit.transpiler.preset_passmanagers.plugin.PassManagerStagePluginManager")() | Manager class for preset pass manager stage plugins. | + +### list\_stage\_plugins + + + +`qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins(stage_name)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/plugin.py "view source code") + +Get a list of installed plugins for a stage. + +**Parameters** + +**stage\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The stage name to get the plugin names for + +**Returns** + +The list of installed plugin names for the specified stages + +**Return type** + +plugins + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If an invalid stage name is specified. + +### passmanager\_stage\_plugins + + + +`qiskit.transpiler.preset_passmanagers.plugin.passmanager_stage_plugins(stage)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/plugin.py "view source code") + +Return a dict with, for each stage name, the class type of the plugin. + +This function is useful for getting more information about a plugin: + +```python +from qiskit.transpiler.preset_passmanagers.plugin import passmanager_stage_plugins +routing_plugins = passmanager_stage_plugins('routing') +basic_plugin = routing_plugins['basic'] +help(basic_plugin) +``` + +```python +Help on BasicSwapPassManager in module ...preset_passmanagers.builtin_plugins object: + +class BasicSwapPassManager(...preset_passmanagers.plugin.PassManagerStagePlugin) + | Plugin class for routing stage with :class:`~.BasicSwap` + | + | Method resolution order: + | BasicSwapPassManager + | ...preset_passmanagers.plugin.PassManagerStagePlugin + | abc.ABC + | builtins.object + ... +``` + +**Parameters** + +**stage** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The stage name to get + +**Returns** + +the key is the name of the plugin and the value is the class type for each. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If an invalid stage name is specified. + diff --git a/docs/api/qiskit/0.46/transpiler_preset.md b/docs/api/qiskit/0.46/transpiler_preset.md new file mode 100644 index 00000000000..06e2c6b6741 --- /dev/null +++ b/docs/api/qiskit/0.46/transpiler_preset.md @@ -0,0 +1,398 @@ +--- +title: preset_passmanagers +description: API reference for qiskit.transpiler.preset_passmanagers +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.transpiler.preset_passmanagers +--- + + + + + + + +# Preset Passmanagers + + + +`qiskit.transpiler.preset_passmanagers` + +This module contains functions for generating the preset pass managers for the transpiler. The preset pass managers are instances of [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") which are used to execute the circuit transformations as part of Qiskit’s compiler inside the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function at the different optimization levels. The functionality here is divided into two parts, the first includes the functions used generate the entire pass manager which is used by [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") ([Preset Pass Manager Generation](#preset-pass-manager-generators)) and the second includes functions which are used to build (either entirely or in part) the stages which the preset pass managers are composed of ([Stage Generator Functions](#stage-generators)). + + + +## Preset Pass Manager Generation + +### generate\_preset\_pass\_manager + + + +`qiskit.transpiler.preset_passmanagers.generate_preset_pass_manager(optimization_level, backend=None, target=None, basis_gates=None, inst_map=None, coupling_map=None, instruction_durations=None, backend_properties=None, timing_constraints=None, initial_layout=None, layout_method=None, routing_method=None, translation_method=None, scheduling_method=None, approximation_degree=None, seed_transpiler=None, unitary_synthesis_method='default', unitary_synthesis_plugin_config=None, hls_config=None, init_method=None, optimization_method=None, *, _skip_target=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/__init__.py "view source code") + +Generate a preset [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +This function is used to quickly generate a preset pass manager. A preset pass manager are the default pass managers used by the [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") function. This function provides a convenient and simple method to construct a standalone [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") object that mirrors what the transpile + +**Parameters** + +* **optimization\_level** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – + + The optimization level to generate a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") for. This can be 0, 1, 2, or 3. Higher levels generate more optimized circuits, at the expense of longer transpilation time: + + > * 0: no optimization + > * 1: light optimization + > * 2: heavy optimization + > * 3: even heavier optimization + +* **backend** ([*Backend*](qiskit.providers.Backend "qiskit.providers.Backend")) – An optional backend object which can be used as the source of the default values for the `basis_gates`, `inst_map`, `couplig_map`, `backend_properties`, `instruction_durations`, `timing_constraints`, and `target`. If any of those other arguments are specified in addition to `backend` they will take precedence over the value contained in the backend. + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") representing a backend compilation target. The following attributes will be inferred from this argument if they are not set: `coupling_map`, `basis_gates`, `instruction_durations`, `inst_map`, `timing_constraints` and `backend_properties`. + +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – List of basis gate names to unroll to (e.g: `['u1', 'u2', 'u3', 'cx']`). + +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap")) – Mapping object that maps gate to schedules. If any user defined calibration is found in the map and this is used in a circuit, transpiler attaches the custom gate definition to the circuit. This enables one to flexibly override the low-level instruction implementation. + +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – Directed graph represented a coupling map. + +* **instruction\_durations** ([*InstructionDurations*](qiskit.transpiler.InstructionDurations "qiskit.transpiler.InstructionDurations")) – Dictionary of duration (in dt) for each instruction. + +* **timing\_constraints** (*TimingConstraints*) – Hardware time alignment restrictions. + +* **initial\_layout** ([*Layout*](qiskit.transpiler.Layout "qiskit.transpiler.Layout")) – Initial position of virtual qubits on physical qubits. + +* **layout\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The `Pass` to use for choosing initial qubit placement. Valid choices are `'trivial'`, `'dense'`, `'noise_adaptive'`, and, `'sabre'` representing [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout"), `DenseLayout`, [`NoiseAdaptiveLayout`](qiskit.transpiler.passes.NoiseAdaptiveLayout "qiskit.transpiler.passes.NoiseAdaptiveLayout"), [`SabreLayout`](qiskit.transpiler.passes.SabreLayout "qiskit.transpiler.passes.SabreLayout") respectively. This can also be the external plugin name to use for the `layout` stage of the output [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager"). You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"layout"` for the `stage_name` argument. + +* **routing\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The pass to use for routing qubits on the architecture. Valid choices are `'basic'`, `'lookahead'`, `'stochastic'`, `'sabre'`, and `'none'` representing [`BasicSwap`](qiskit.transpiler.passes.BasicSwap "qiskit.transpiler.passes.BasicSwap"), [`LookaheadSwap`](qiskit.transpiler.passes.LookaheadSwap "qiskit.transpiler.passes.LookaheadSwap"), [`StochasticSwap`](qiskit.transpiler.passes.StochasticSwap "qiskit.transpiler.passes.StochasticSwap"), [`SabreSwap`](qiskit.transpiler.passes.SabreSwap "qiskit.transpiler.passes.SabreSwap"), and erroring if routing is required respectively. This can also be the external plugin name to use for the `routing` stage of the output [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager"). You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"routing"` for the `stage_name` argument. + +* **translation\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The method to use for translating gates to basis gates. Valid choices `'unroller'`, `'translator'`, `'synthesis'` representing [`Unroller`](qiskit.transpiler.passes.Unroller "qiskit.transpiler.passes.Unroller"), [`BasisTranslator`](qiskit.transpiler.passes.BasisTranslator "qiskit.transpiler.passes.BasisTranslator"), and [`UnitarySynthesis`](qiskit.transpiler.passes.UnitarySynthesis "qiskit.transpiler.passes.UnitarySynthesis") respectively. This can also be the external plugin name to use for the `translation` stage of the output [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager"). You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"translation"` for the `stage_name` argument. + +* **scheduling\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The pass to use for scheduling instructions. Valid choices are `'alap'` and `'asap'`. This can also be the external plugin name to use for the `scheduling` stage of the output [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager"). You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"scheduling"` for the `stage_name` argument. + +* **backend\_properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – Properties returned by a backend, including information on gate errors, readout errors, qubit coherence times, etc. + +* **approximation\_degree** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – Heuristic dial used for circuit approximation (1.0=no approximation, 0.0=maximal approximation). + +* **seed\_transpiler** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Sets random seed for the stochastic parts of the transpiler. + +* **unitary\_synthesis\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the unitary synthesis method to use. By default `'default'` is used. You can see a list of installed plugins with [`unitary_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names"). + +* **unitary\_synthesis\_plugin\_config** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – An optional configuration dictionary that will be passed directly to the unitary synthesis plugin. By default this setting will have no effect as the default unitary synthesis method does not take custom configuration. This should only be necessary when a unitary synthesis plugin is specified with the `unitary_synthesis` argument. As this is custom for each unitary synthesis plugin refer to the plugin documentation for how to use this option. + +* **hls\_config** (*HLSConfig*) – An optional configuration class `HLSConfig` that will be passed directly to [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") transformation pass. This configuration class allows to specify for various high-level objects the lists of synthesis algorithms and their parameters. + +* **init\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The plugin name to use for the `init` stage of the output [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager"). By default an external plugin is not used. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"init"` for the stage name argument. + +* **optimization\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The plugin name to use for the `optimization` stage of the output [`StagedPassManager`](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager"). By default an external plugin is not used. You can see a list of installed plugins by using [`list_stage_plugins()`](transpiler_plugins#qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins "qiskit.transpiler.preset_passmanagers.plugin.list_stage_plugins") with `"optimization"` for the `stage_name` argument. + +**Returns** + +The preset pass manager for the given options + +**Return type** + +[StagedPassManager](qiskit.transpiler.StagedPassManager "qiskit.transpiler.StagedPassManager") + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if an invalid value for `optimization_level` is passed in. + +### level\_0\_pass\_manager + + + +`qiskit.transpiler.preset_passmanagers.level_0_pass_manager(pass_manager_config)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/level0.py "view source code") + +Level 0 pass manager: no explicit optimization other than mapping to backend. + +This pass manager applies the user-given initial layout. If none is given, a trivial layout consisting of mapping the i-th virtual qubit to the i-th physical qubit is used. Any unused physical qubit is allocated as ancilla space. + +The pass manager then unrolls the circuit to the desired basis, and transforms the circuit to match the coupling map. + +**Parameters** + +**pass\_manager\_config** ([*PassManagerConfig*](qiskit.transpiler.PassManagerConfig "qiskit.transpiler.passmanager_config.PassManagerConfig")) – configuration of the pass manager. + +**Returns** + +a level 0 pass manager. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the passmanager config is invalid. + +**Return type** + +[*StagedPassManager*](qiskit.transpiler.StagedPassManager "qiskit.transpiler.passmanager.StagedPassManager") + +### level\_1\_pass\_manager + + + +`qiskit.transpiler.preset_passmanagers.level_1_pass_manager(pass_manager_config)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/level1.py "view source code") + +Level 1 pass manager: light optimization by simple adjacent gate collapsing. + +This pass manager applies the user-given initial layout. If none is given, and a trivial layout (i-th virtual -> i-th physical) makes the circuit fit the coupling map, that is used. Otherwise, the circuit is mapped to the most densely connected coupling subgraph, and swaps are inserted to map. Any unused physical qubit is allocated as ancilla space. The pass manager then unrolls the circuit to the desired basis, and transforms the circuit to match the coupling map. Finally, optimizations in the form of adjacent gate collapse and redundant reset removal are performed. + +**Parameters** + +**pass\_manager\_config** ([*PassManagerConfig*](qiskit.transpiler.PassManagerConfig "qiskit.transpiler.passmanager_config.PassManagerConfig")) – configuration of the pass manager. + +**Returns** + +a level 1 pass manager. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the passmanager config is invalid. + +**Return type** + +[*StagedPassManager*](qiskit.transpiler.StagedPassManager "qiskit.transpiler.passmanager.StagedPassManager") + +### level\_2\_pass\_manager + + + +`qiskit.transpiler.preset_passmanagers.level_2_pass_manager(pass_manager_config)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/level2.py "view source code") + +Level 2 pass manager: medium optimization by initial layout selection and gate cancellation using commutativity rules. + +This pass manager applies the user-given initial layout. If none is given, a search for a perfect layout (i.e. one that satisfies all 2-qubit interactions) is conducted. If no such layout is found, qubits are laid out on the most densely connected subset which also exhibits the best gate fidelities. + +The pass manager then transforms the circuit to match the coupling constraints. It is then unrolled to the basis, and any flipped cx directions are fixed. Finally, optimizations in the form of commutative gate cancellation and redundant reset removal are performed. + +**Parameters** + +**pass\_manager\_config** ([*PassManagerConfig*](qiskit.transpiler.PassManagerConfig "qiskit.transpiler.passmanager_config.PassManagerConfig")) – configuration of the pass manager. + +**Returns** + +a level 2 pass manager. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the passmanager config is invalid. + +**Return type** + +[*StagedPassManager*](qiskit.transpiler.StagedPassManager "qiskit.transpiler.passmanager.StagedPassManager") + +### level\_3\_pass\_manager + + + +`qiskit.transpiler.preset_passmanagers.level_3_pass_manager(pass_manager_config)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/level3.py "view source code") + +Level 3 pass manager: heavy optimization by noise adaptive qubit mapping and gate cancellation using commutativity rules and unitary synthesis. + +This pass manager applies the user-given initial layout. If none is given, a search for a perfect layout (i.e. one that satisfies all 2-qubit interactions) is conducted. If no such layout is found, and device calibration information is available, the circuit is mapped to the qubits with best readouts and to CX gates with highest fidelity. + +The pass manager then transforms the circuit to match the coupling constraints. It is then unrolled to the basis, and any flipped cx directions are fixed. Finally, optimizations in the form of commutative gate cancellation, resynthesis of two-qubit unitary blocks, and redundant reset removal are performed. + +**Parameters** + +**pass\_manager\_config** ([*PassManagerConfig*](qiskit.transpiler.PassManagerConfig "qiskit.transpiler.passmanager_config.PassManagerConfig")) – configuration of the pass manager. + +**Returns** + +a level 3 pass manager. + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – if the passmanager config is invalid. + +**Return type** + +[*StagedPassManager*](qiskit.transpiler.StagedPassManager "qiskit.transpiler.passmanager.StagedPassManager") + + + +## Stage Generator Functions + +### generate\_control\_flow\_options\_check + + + +`qiskit.transpiler.preset_passmanagers.common.generate_control_flow_options_check(layout_method=None, routing_method=None, translation_method=None, optimization_method=None, scheduling_method=None, basis_gates=(), target=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Generate a pass manager that, when run on a DAG that contains control flow, fails with an error message explaining the invalid options, and what could be used instead. + +**Returns** + +a pass manager that populates the `contains_x` properties for each of the control-flow operations, and raises an error if any of the given options do not support control flow, but a circuit with control flow is given. + +**Return type** + +[PassManager](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +### generate\_error\_on\_control\_flow + + + +`qiskit.transpiler.preset_passmanagers.common.generate_error_on_control_flow(message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Get a pass manager that always raises an error if control flow is present in a given circuit. + +### generate\_unroll\_3q + + + +`qiskit.transpiler.preset_passmanagers.common.generate_unroll_3q(target, basis_gates=None, approximation_degree=None, unitary_synthesis_method='default', unitary_synthesis_plugin_config=None, hls_config=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Generate an unroll >3q [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +**Parameters** + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the backend +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of str gate names that represent the basis gates on the backend target +* **approximation\_degree** (*Optional\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The heuristic approximation degree to use. Can be between 0 and 1. +* **unitary\_synthesis\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unitary synthesis method to use. You can see a list of installed plugins with [`unitary_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names"). +* **unitary\_synthesis\_plugin\_config** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The optional dictionary plugin configuration, this is plugin specific refer to the specified plugin’s documentation for how to use. +* **hls\_config** (*HLSConfig*) – An optional configuration class to use for [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") pass. Specifies how to synthesize various high-level objects. + +**Returns** + +The unroll 3q or more pass manager + +**Return type** + +[PassManager](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +### generate\_embed\_passmanager + + + +`qiskit.transpiler.preset_passmanagers.common.generate_embed_passmanager(coupling_map)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Generate a layout embedding [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +This is used to generate a [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") object that can be used to expand and apply an initial layout to a circuit + +**Parameters** + +**coupling\_map** (*Union\[*[*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")*,* [*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The coupling map for the backend to embed the circuit to. + +**Returns** + +**The embedding passmanager that assumes the layout property** + +set has been set in earlier stages + +**Return type** + +[PassManager](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +### generate\_routing\_passmanager + + + +`qiskit.transpiler.preset_passmanagers.common.generate_routing_passmanager(routing_pass, target, coupling_map=None, vf2_call_limit=None, backend_properties=None, seed_transpiler=None, check_trivial=False, use_barrier_before_measurement=True, vf2_max_trials=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Generate a routing [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +**Parameters** + +* **routing\_pass** ([*TransformationPass*](qiskit.transpiler.TransformationPass "qiskit.transpiler.TransformationPass")) – The pass which will perform the routing +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the backend +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – The coupling map of the backend to route for +* **vf2\_call\_limit** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The internal call limit for the vf2 post layout pass. If this is `None` or `0` the vf2 post layout will not be run. +* **backend\_properties** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – Properties of a backend to synthesize for (e.g. gate fidelities). +* **seed\_transpiler** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Sets random seed for the stochastic parts of the transpiler. +* **check\_trivial** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If set to true this will condition running the [`VF2PostLayout`](qiskit.transpiler.passes.VF2PostLayout "qiskit.transpiler.passes.VF2PostLayout") pass after routing on whether a trivial layout was tried and was found to not be perfect. This is only needed if the constructed pass manager runs [`TrivialLayout`](qiskit.transpiler.passes.TrivialLayout "qiskit.transpiler.passes.TrivialLayout") as a first layout attempt and uses it if it’s a perfect layout (as is the case with preset pass manager level 1). +* **use\_barrier\_before\_measurement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If true (the default) the [`BarrierBeforeFinalMeasurements`](qiskit.transpiler.passes.BarrierBeforeFinalMeasurements "qiskit.transpiler.passes.BarrierBeforeFinalMeasurements") transpiler pass will be run prior to the specified pass in the `routing_pass` argument. +* **vf2\_max\_trials** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The maximum number of trials to run VF2 when evaluating the vf2 post layout pass. If this is `None` or `0` the vf2 post layout will not be run. + +**Returns** + +The routing pass manager + +**Return type** + +[PassManager](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +### generate\_pre\_op\_passmanager + + + +`qiskit.transpiler.preset_passmanagers.common.generate_pre_op_passmanager(target=None, coupling_map=None, remove_reset_in_zero=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Generate a pre-optimization loop [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +This pass manager will check to ensure that directionality from the coupling map is respected + +**Parameters** + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the backend +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – The coupling map to use +* **remove\_reset\_in\_zero** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If `True` include the remove reset in zero pass in the generated PassManager + +**Returns** + +The pass manager + +**Return type** + +[PassManager](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +### generate\_translation\_passmanager + + + +`qiskit.transpiler.preset_passmanagers.common.generate_translation_passmanager(target, basis_gates=None, method='translator', approximation_degree=None, coupling_map=None, backend_props=None, unitary_synthesis_method='default', unitary_synthesis_plugin_config=None, hls_config=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Generate a basis translation [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +**Parameters** + +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – the [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the backend +* **basis\_gates** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – A list of str gate names that represent the basis gates on the backend target +* **method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The basis translation method to use +* **approximation\_degree** (*Optional\[*[*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")*]*) – The heuristic approximation degree to use. Can be between 0 and 1. +* **coupling\_map** ([*CouplingMap*](qiskit.transpiler.CouplingMap "qiskit.transpiler.CouplingMap")) – the coupling map of the backend in case synthesis is done on a physical circuit. The directionality of the coupling\_map will be taken into account if pulse\_optimize is True/None and natural\_direction is True/None. +* **unitary\_synthesis\_plugin\_config** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The optional dictionary plugin configuration, this is plugin specific refer to the specified plugin’s documentation for how to use. +* **backend\_props** ([*BackendProperties*](qiskit.providers.models.BackendProperties "qiskit.providers.models.BackendProperties")) – Properties of a backend to synthesize for (e.g. gate fidelities). +* **unitary\_synthesis\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The unitary synthesis method to use. You can see a list of installed plugins with [`unitary_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names"). +* **hls\_config** (*HLSConfig*) – An optional configuration class to use for [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.HighLevelSynthesis") pass. Specifies how to synthesize various high-level objects. + +**Returns** + +The basis translation pass manager + +**Return type** + +[PassManager](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the `method` kwarg is not a valid value + +### generate\_scheduling + + + +`qiskit.transpiler.preset_passmanagers.common.generate_scheduling(instruction_durations, scheduling_method, timing_constraints, inst_map, target=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/transpiler/preset_passmanagers/common.py "view source code") + +Generate a post optimization scheduling [`PassManager`](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +**Parameters** + +* **instruction\_durations** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – The dictionary of instruction durations +* **scheduling\_method** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The scheduling method to use, can either be `'asap'`/`'as_soon_as_possible'` or `'alap'`/`'as_late_as_possible'` +* **timing\_constraints** (*TimingConstraints*) – Hardware time alignment restrictions. +* **inst\_map** ([*InstructionScheduleMap*](qiskit.pulse.InstructionScheduleMap "qiskit.pulse.InstructionScheduleMap")) – Mapping object that maps gate to schedule. +* **target** ([*Target*](qiskit.transpiler.Target "qiskit.transpiler.Target")) – The [`Target`](qiskit.transpiler.Target "qiskit.transpiler.Target") object representing the backend + +**Returns** + +The scheduling pass manager + +**Return type** + +[PassManager](qiskit.transpiler.PassManager "qiskit.transpiler.PassManager") + +**Raises** + +[**TranspilerError**](transpiler#qiskit.transpiler.TranspilerError "qiskit.transpiler.TranspilerError") – If the `scheduling_method` kwarg is not a valid value + diff --git a/docs/api/qiskit/0.46/transpiler_synthesis_plugins.md b/docs/api/qiskit/0.46/transpiler_synthesis_plugins.md new file mode 100644 index 00000000000..cb32aa6c3a6 --- /dev/null +++ b/docs/api/qiskit/0.46/transpiler_synthesis_plugins.md @@ -0,0 +1,169 @@ +--- +title: plugin +description: API reference for qiskit.transpiler.passes.synthesis.plugin +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.transpiler.passes.synthesis.plugin +--- + + + + + + + +# Synthesis Plugins + + + +`qiskit.transpiler.passes.synthesis.plugin` + +This module defines the plugin interfaces for the synthesis transpiler passes in Qiskit. These provide a hook point for external python packages to implement their own synthesis techniques and have them seamlessly exposed as opt-in options to users when they run [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile"). + +The plugin interfaces are built using setuptools [entry points](https://setuptools.readthedocs.io/en/latest/userguide/entry_point.html) which enable packages external to qiskit to advertise they include a synthesis plugin. + +See [`qiskit.transpiler.preset_passmanagers.plugin`](transpiler_plugins#module-qiskit.transpiler.preset_passmanagers.plugin "qiskit.transpiler.preset_passmanagers.plugin") for details on how to write plugins for transpiler stages. + +## Writing Plugins + +### Unitary Synthesis Plugins + +To write a unitary synthesis plugin there are 2 main steps. The first step is to create a subclass of the abstract plugin class: [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin"). The plugin class defines the interface and contract for unitary synthesis plugins. The primary method is [`run()`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin#run "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.run") which takes in a single positional argument, a unitary matrix as a numpy array, and is expected to return a [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") object representing the synthesized circuit from that unitary matrix. Then to inform the Qiskit transpiler about what information is necessary for the pass there are several required property methods that need to be implemented such as `supports_basis_gates` and `supports_coupling_map` depending on whether the plugin supports and/or requires that input to perform synthesis. For the full details refer to the [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") documentation for all the required fields. An example plugin class would look something like: + +```python +from qiskit.transpiler.passes.synthesis import plugin +from qiskit_plugin_pkg.synthesis import generate_dag_circuit_from_matrix + + +class SpecialUnitarySynthesis(plugin.UnitarySynthesisPlugin): + @property + def supports_basis_gates(self): + return True + + @property + def supports_coupling_map(self): + return False + + @property + def supports_natural_direction(self): + return False + + @property + def supports_pulse_optimize(self): + return False + + @property + def supports_gate_lengths(self): + return False + + @property + def supports_gate_errors(self): + return False + + @property + def supports_gate_lengths_by_qubit(self): + return False + + @property + def supports_gate_errors_by_qubit(self): + return False + + @property + def min_qubits(self): + return None + + @property + def max_qubits(self): + return None + + @property + def supported_bases(self): + return None + + def run(self, unitary, **options): + basis_gates = options['basis_gates'] + dag_circuit = generate_dag_circuit_from_matrix(unitary, basis_gates) + return dag_circuit +``` + +If for some reason the available inputs to the [`run()`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin#run "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin.run") method are insufficient please open an issue and we can discuss expanding the plugin interface with new opt-in inputs that can be added in a backwards compatible manner for future releases. Do note though that this plugin interface is considered stable and guaranteed to not change in a breaking manner. If changes are needed (for example to expand the available optional input options) it will be done in a way that will **not** require changes from existing plugins. + + + All methods prefixed with `supports_` are reserved on a `UnitarySynthesisPlugin` derived class for part of the interface. You should not define any custom `supports_*` methods on a subclass that are not defined in the abstract class. + + +The second step is to expose the [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin") as a setuptools entry point in the package metadata. This is done by simply adding an `entry_points` entry to the `setuptools.setup` call in the `setup.py` for the plugin package with the necessary entry points under the `qiskit.unitary_synthesis` namespace. For example: + +```python +entry_points = { + 'qiskit.unitary_synthesis': [ + 'special = qiskit_plugin_pkg.module.plugin:SpecialUnitarySynthesis', + ] +}, +``` + +(note that the entry point `name = path` is a single string not a Python expression). There isn’t a limit to the number of plugins a single package can include as long as each plugin has a unique name. So a single package can expose multiple plugins if necessary. The name `default` is used by Qiskit itself and can’t be used in a plugin. + +#### Unitary Synthesis Plugin Configuration + +For some unitary synthesis plugins that expose multiple options and tunables the plugin interface has an option for users to provide a free form configuration dictionary. This will be passed through to the `run()` method as the `config` kwarg. If your plugin has these configuration options you should clearly document how a user should specify these configuration options and how they’re used as it’s a free form field. + +### High-Level Synthesis Plugins + +Writing a high-level synthesis plugin is conceptually similar to writing a unitary synthesis plugin. The first step is to create a subclass of the abstract plugin class: [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin"), which defines the interface and contract for high-level synthesis plugins. The primary method is [`run()`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin#run "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.run"). The positional argument `high_level_object` specifies the “higher-level-object” to be synthesized, which is any object of type [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") (including, for example, [`LinearFunction`](qiskit.circuit.library.LinearFunction "qiskit.circuit.library.generalized_gates.linear_function.LinearFunction") or [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.operators.symplectic.clifford.Clifford")). The keyword argument `target` specifies the target backend, allowing the plugin to access all target-specific information, such as the coupling map, the supported gate set, and so on. The keyword argument `coupling_map` only specifies the coupling map, and is only used when `target` is not specified. The keyword argument `qubits` specifies the list of qubits over which the higher-level-object is defined, in case the synthesis is done on the physical circuit. The value of `None` indicates that the layout has not yet been chosen and the physical qubits in the target or coupling map that this operation is operating on has not yet been determined. Additionally, plugin-specific options and tunables can be specified via `options`, which is a free form configuration dictionary. If your plugin has these configuration options you should clearly document how a user should specify these configuration options and how they’re used as it’s a free form field. The method [`run()`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin#run "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin.run") is expected to return a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") object representing the synthesized circuit from that higher-level-object. It is also allowed to return `None` representing that the synthesis method is unable to synthesize the given higher-level-object. The actual synthesis of higher-level objects is performed by [`HighLevelSynthesis`](qiskit.transpiler.passes.HighLevelSynthesis "qiskit.transpiler.passes.synthesis.high_level_synthesis.HighLevelSynthesis") transpiler pass. For the full details refer to the [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") documentation for all the required fields. An example plugin class would look something like: + +```python +from qiskit.transpiler.passes.synthesis.plugin import HighLevelSynthesisPlugin +from qiskit.synthesis.clifford import synth_clifford_bm + + +class SpecialSynthesisClifford(HighLevelSynthesisPlugin): + +def run(self, high_level_object, coupling_map=None, target=None, qubits=None, **options): + if higher_level_object.num_qubits <= 3: + return synth_clifford_bm(high_level_object) + else: + return None +``` + +The above example creates a plugin to synthesize objects of type [`Clifford`](qiskit.quantum_info.Clifford "qiskit.quantum_info.Clifford") that have at most 3 qubits, using the method `synth_clifford_bm`. + +The second step is to expose the [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin") as a setuptools entry point in the package metadata. This is done by adding an `entry_points` entry to the `setuptools.setup` call in the `setup.py` for the plugin package with the necessary entry points under the `qiskit.synthesis` namespace. For example: + +```python +entry_points = { + 'qiskit.synthesis': [ + 'clifford.special = qiskit_plugin_pkg.module.plugin:SpecialSynthesisClifford', + ] +}, +``` + +(note that the entry point `name = path` is a single string not a Python expression). The `name` consists of two parts separated by dot “.”: the name of the type of [`Operation`](qiskit.circuit.Operation "qiskit.circuit.Operation") to which the synthesis plugin applies (`clifford`), and the name of the plugin (`special`). There isn’t a limit to the number of plugins a single package can include as long as each plugin has a unique name. + +## Using Plugins + +To use a plugin all you need to do is install the package that includes a synthesis plugin. Then Qiskit will automatically discover the installed plugins and expose them as valid options for the appropriate [`transpile()`](compiler#qiskit.compiler.transpile "qiskit.compiler.transpile") kwargs and pass constructors. If there are any installed plugins which can’t be loaded/imported this will be logged to Python logging. + +To get the installed list of installed unitary synthesis plugins you can use the [`qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names()`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names") function. + +## Plugin API + + + +### Unitary Synthesis Plugins + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------- | +| [`UnitarySynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPlugin")() | Abstract unitary synthesis plugin class | +| [`UnitarySynthesisPluginManager`](qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager "qiskit.transpiler.passes.synthesis.plugin.UnitarySynthesisPluginManager")() | Unitary Synthesis plugin manager class | +| [`unitary_synthesis_plugin_names`](qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names "qiskit.transpiler.passes.synthesis.plugin.unitary_synthesis_plugin_names")() | Return a list of installed unitary synthesis plugin names | + + + +### High-Level Synthesis Plugins + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------- | +| [`HighLevelSynthesisPlugin`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPlugin")() | Abstract high-level synthesis plugin class. | +| [`HighLevelSynthesisPluginManager`](qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager "qiskit.transpiler.passes.synthesis.plugin.HighLevelSynthesisPluginManager")() | Class tracking the installed high-level-synthesis plugins. | + diff --git a/docs/api/qiskit/0.46/utils.md b/docs/api/qiskit/0.46/utils.md new file mode 100644 index 00000000000..b7b8bc4ec70 --- /dev/null +++ b/docs/api/qiskit/0.46/utils.md @@ -0,0 +1,712 @@ +--- +title: utils +description: API reference for qiskit.utils +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.utils +--- + + + + + + + +# Utilities + + + +`qiskit.utils` + +### add\_deprecation\_to\_docstring + + + +`qiskit.utils.add_deprecation_to_docstring(func, msg, *, since, pending)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/deprecation.py "view source code") + +Dynamically insert the deprecation message into `func`’s docstring. + +**Parameters** + +* **func** (*Callable*) – The function to modify. +* **msg** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The full deprecation message. +* **since** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The version the deprecation started at. +* **pending** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Is the deprecation still pending? + +### deprecate\_arg + + + +`qiskit.utils.deprecate_arg(name, *, since, additional_msg=None, deprecation_description=None, pending=False, package_name='qiskit', new_alias=None, predicate=None, removal_timeline='no earlier than 3 months after the release date')`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/deprecation.py "view source code") + +Decorator to indicate an argument has been deprecated in some way. + +This decorator may be used multiple times on the same function, once per deprecated argument. It should be placed beneath other decorators like `@staticmethod` and property decorators. + +**Parameters** + +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The name of the deprecated argument. +* **since** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The version the deprecation started at. If the deprecation is pending, set the version to when that started; but later, when switching from pending to deprecated, update since to the new version. +* **deprecation\_description** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – What is being deprecated? E.g. “Setting my\_func()’s my\_arg argument to None.” If not set, will default to “\{func\_name}’s argument \{name}”. +* **additional\_msg** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Put here any additional information, such as what to use instead (if new\_alias is not set). For example, “Instead, use the argument new\_arg, which is similar but does not impact the circuit’s setup.” +* **pending** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to True if the deprecation is still pending. +* **package\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The PyPI package name, e.g. “qiskit-nature”. +* **new\_alias** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – If the arg has simply been renamed, set this to the new name. The decorator will dynamically update the kwargs so that when the user sets the old arg, it will be passed in as the new\_alias arg. +* **predicate** (*Callable\[\[Any],* [*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")*] | None*) – Only log the runtime warning if the predicate returns True. This is useful to deprecate certain values or types for an argument, e.g. lambda my\_arg: isinstance(my\_arg, dict). Regardless of if a predicate is set, the runtime warning will only log when the user specifies the argument. +* **removal\_timeline** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – How soon can this deprecation be removed? Expects a value like “no sooner than 6 months after the latest release” or “in release 9.99”. + +**Returns** + +The decorated callable. + +**Return type** + +Callable + +### deprecate\_arguments + + + +`qiskit.utils.deprecate_arguments(kwarg_map, category=, *, since=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/deprecation.py "view source code") + +Deprecated. Instead, use @deprecate\_arg. + +**Parameters** + +* **kwarg\_map** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None]*) – A dictionary of the old argument name to the new name. +* **category** ([*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")*\[*[*Warning*](https://docs.python.org/3/library/exceptions.html#Warning "(in Python v3.12)")*]*) – Usually either DeprecationWarning or PendingDeprecationWarning. +* **since** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The version the deprecation started at. Only Optional for backwards compatibility - this should always be set. If the deprecation is pending, set the version to when that started; but later, when switching from pending to deprecated, update since to the new version. + +**Returns** + +The decorated callable. + +**Return type** + +Callable + +### deprecate\_func + + + +`qiskit.utils.deprecate_func(*, since, additional_msg=None, pending=False, package_name='qiskit', removal_timeline='no earlier than 3 months after the release date', is_property=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/deprecation.py "view source code") + +Decorator to indicate a function has been deprecated. + +It should be placed beneath other decorators like @staticmethod and property decorators. + +When deprecating a class, set this decorator on its \_\_init\_\_ function. + +**Parameters** + +* **since** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The version the deprecation started at. If the deprecation is pending, set the version to when that started; but later, when switching from pending to deprecated, update `since` to the new version. +* **additional\_msg** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – Put here any additional information, such as what to use instead. For example, “Instead, use the function `new_func` from the module `.`, which is similar but uses GPU acceleration.” +* **pending** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – Set to `True` if the deprecation is still pending. +* **package\_name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – The PyPI package name, e.g. “qiskit-nature”. +* **removal\_timeline** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – How soon can this deprecation be removed? Expects a value like “no sooner than 6 months after the latest release” or “in release 9.99”. +* **is\_property** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If the deprecated function is a @property, set this to True so that the generated message correctly describes it as such. (This isn’t necessary for property setters, as their docstring is ignored by Python.) + +**Returns** + +The decorated callable. + +**Return type** + +Callable + +### deprecate\_function + + + +`qiskit.utils.deprecate_function(msg, stacklevel=2, category=, *, since=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/deprecation.py "view source code") + +Deprecated. Instead, use @deprecate\_func. + +**Parameters** + +* **msg** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – Warning message to emit. +* **stacklevel** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – The warning stacklevel to use, defaults to 2. +* **category** ([*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")*\[*[*Warning*](https://docs.python.org/3/library/exceptions.html#Warning "(in Python v3.12)")*]*) – Usually either DeprecationWarning or PendingDeprecationWarning. +* **since** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *| None*) – The version the deprecation started at. Only Optional for backwards compatibility - this should always be set. If the deprecation is pending, set the version to when that started; but later, when switching from pending to deprecated, update since to the new version. + +**Returns** + +The decorated, deprecated callable. + +**Return type** + +Callable + +### local\_hardware\_info + + + +`qiskit.utils.local_hardware_info()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/multiprocessing.py "view source code") + +Basic hardware information about the local machine. + +Gives actual number of CPU’s in the machine, even when hyperthreading is turned on. CPU count defaults to 1 when true count can’t be determined. + +**Returns** + +The hardware information. + +**Return type** + +[dict](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)") + +### is\_main\_process + + + +`qiskit.utils.is_main_process()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/multiprocessing.py "view source code") + +Checks whether the current process is the main one + +### apply\_prefix + + + +`qiskit.utils.apply_prefix(value, unit)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/units.py "view source code") + +Given a SI unit prefix and value, apply the prefix to convert to standard SI unit. + +**Parameters** + +* **value** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") *|*[*ParameterExpression*](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression")) – The number to apply prefix to. +* **unit** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – String prefix. + +**Returns** + +Converted value. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [ParameterExpression](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") + + + This may induce tiny value error due to internal representation of float object. See [https://docs.python.org/3/tutorial/floatingpoint.html](https://docs.python.org/3/tutorial/floatingpoint.html) for details. + + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the `units` aren’t recognized. + +**Return type** + +[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)") | [ParameterExpression](qiskit.circuit.ParameterExpression "qiskit.circuit.ParameterExpression") + +### detach\_prefix + + + +`qiskit.utils.detach_prefix(value, decimal=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/units.py "view source code") + +Given a SI unit value, find the most suitable prefix to scale the value. + +For example, the `value = 1.3e8` will be converted into a tuple of `(130.0, "M")`, which represents a scaled value and auxiliary unit that may be used to display the value. In above example, that value might be displayed as `130 MHz` (unit is arbitrary here). + +**Example** + +```python +>>> value, prefix = detach_prefix(1e4) +>>> print(f"{value} {prefix}Hz") +10 kHz +``` + +**Parameters** + +* **value** ([*float*](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)")) – The number to find prefix. +* **decimal** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)") *| None*) – Optional. An arbitrary integer number to represent a precision of the value. If specified, it tries to round the mantissa and adjust the prefix to rounded value. For example, 999\_999.91 will become 999.9999 k with `decimal=4`, while 1.0 M with `decimal=3` or less. + +**Returns** + +A tuple of scaled value and prefix. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + + + This may induce tiny value error due to internal representation of float object. See [https://docs.python.org/3/tutorial/floatingpoint.html](https://docs.python.org/3/tutorial/floatingpoint.html) for details. + + +**Raises** + +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the `value` is out of range. +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – If the `value` is not real number. + +**Return type** + +[tuple](https://docs.python.org/3/library/stdtypes.html#tuple "(in Python v3.12)")\[[float](https://docs.python.org/3/library/functions.html#float "(in Python v3.12)"), [str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")] + +### wrap\_method + + + +`qiskit.utils.wrap_method(cls, name, *, before=None, after=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/classtools.py "view source code") + +Wrap the functionality the instance- or class method `cls.name` with additional behaviour `before` and `after`. + +This mutates `cls`, replacing the attribute `name` with the new functionality. This is useful when creating class decorators. The method is allowed to be defined on any parent class instead. + +If either `before` or `after` are given, they should be callables with a compatible signature to the method referred to. They will be called immediately before or after the method as appropriate, and any return value will be ignored. + +**Parameters** + +* **cls** ([*Type*](https://docs.python.org/3/library/typing.html#typing.Type "(in Python v3.12)")) – the class to modify. +* **name** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the name of the method on the class to wrap. +* **before** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – a callable that should be called before the method that is being wrapped. +* **after** ([*Callable*](https://docs.python.org/3/library/typing.html#typing.Callable "(in Python v3.12)") *| None*) – a callable that should be called after the method that is being wrapped. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if the named method is not defined on the class or any parent class. + +## Algorithm Utilities + +### summarize\_circuits + + + +`qiskit.utils.summarize_circuits(circuits)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/circuit_utils.py "view source code") + +**Summarize circuits based on QuantumCircuit, and five metrics are summarized.** + +* Number of qubits +* Number of classical bits +* Number of operations +* Depth of circuits +* Counts of different gate operations + +The average statistic of the first four is provided if multiple circuits are provided. + +> +> The function `qiskit.utils.circuit_utils.summarize_circuits()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was only used in the context of qiskit.opflow/qiskit.algorithms, two modules deprecated and planned to be removed in Qiskit 1.0. +> + +**Parameters** + +**circuits** ([*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") *or \[*[*QuantumCircuit*](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit")*]*) – the to-be-summarized circuits + +**Returns** + +a formatted string records the summary + +**Return type** + +[str](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") + +### get\_entangler\_map + + + +`qiskit.utils.get_entangler_map(map_type, num_qubits, offset=0)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/entangler_map.py "view source code") + +Utility method to get an entangler map among qubits. + + + The function `qiskit.utils.entangler_map.get_entangler_map()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was only used in the context of qiskit.opflow/qiskit.algorithms, two modules deprecated and planned to be removed in Qiskit 1.0. + + +**Parameters** + +* **map\_type** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – ‘full’ entangles each qubit with all the subsequent ones ‘linear’ entangles each qubit with the next ‘sca’ (shifted circular alternating entanglement) is a circular entanglement where the ‘long’ entanglement is shifted by one position every block and every block the role or control/target qubits alternate +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of qubits for which the map is needed +* **offset** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Some map\_types (e.g. ‘sca’) can shift the gates in the entangler map by the specified integer offset. + +**Returns** + +A map of qubit index to an array of indexes to which this should be entangled + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if map\_type is not valid. + +### validate\_entangler\_map + + + +`qiskit.utils.validate_entangler_map(entangler_map, num_qubits, allow_double_entanglement=False)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/entangler_map.py "view source code") + +Validate a user supplied entangler map and converts entries to ints. + + + The function `qiskit.utils.entangler_map.validate_entangler_map()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was only used in the context of qiskit.opflow/qiskit.algorithms, two modules deprecated and planned to be removed in Qiskit 1.0. + + +**Parameters** + +* **entangler\_map** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*\[*[*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")*]*) – An entangler map, keys are source qubit index (int), value is array of target qubit index(es) (int) +* **num\_qubits** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of qubits +* **allow\_double\_entanglement** ([*bool*](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)")) – If we allow in two qubits can be entangled each other + +**Returns** + +Validated/converted map + +**Return type** + +[list](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)") + +**Raises** + +* [**TypeError**](https://docs.python.org/3/library/exceptions.html#TypeError "(in Python v3.12)") – entangler map is not list type or list of list +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – the index of entangler map is out of range +* [**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – the qubits are cross-entangled. + +### has\_ibmq + + + +`qiskit.utils.has_ibmq()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/backend_utils.py "view source code") + +Check if IBMQ is installed. + + + The function `qiskit.utils.backend_utils.has_ibmq()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/qi\_migration](https://qisk.it/qi_migration). + + +### has\_aer + + + +`qiskit.utils.has_aer()`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/backend_utils.py "view source code") + +Check if Aer is installed. + + + The function `qiskit.utils.backend_utils.has_aer()` is deprecated as of qiskit-terra 0.24.0. It will be removed in the Qiskit 1.0 release. For code migration guidelines, visit [https://qisk.it/qi\_migration](https://qisk.it/qi_migration). + + +### name\_args + + + +`qiskit.utils.name_args(mapping, skip=0)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/name_unnamed_args.py "view source code") + +Decorator to convert unnamed arguments to named ones. + +Can be used to deprecate old signatures of a function, e.g. + +```python +old_f(a: TypeA, b: TypeB, c: TypeC) +new_f(a: TypeA, d: TypeD, b: TypeB=None, c: TypeC=None) +``` + +Then, to support the old signature this decorator can be used as + +```python +@name_args([ + ('a'), # stays the same + ('d', {TypeB: 'b'}), # if arg is of type TypeB, call if 'b' else 'd' + ('b', {TypeC: 'c'}) +]) +def new_f(a: TypeA, d: TypeD, b: TypeB=None, c: TypeC=None): + if b is not None: + # raise warning, this is deprecated! + if c is not None: + # raise warning, this is deprecated! +``` + + + The function `qiskit.utils.name_unnamed_args.name_args()` is deprecated as of qiskit 0.46.0. It will be removed in the Qiskit 1.0 release. This function was only used in the context of qiskit.opflow/qiskit.algorithms, two modules deprecated and planned to be removed in Qiskit 1.0. + + +**qiskit.utils.algorithm\_globals *= \*** + +Class for global properties. + +| | | +| -------------------------------------------------------------------------------- | -------------------------------------------------------- | +| [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") | Deprecated: Quantum Backend including execution setting. | + +A QuantumInstance holds the Qiskit backend as well as a number of compile and runtime parameters controlling circuit compilation and execution. Quantum [`algorithms`](algorithms#module-qiskit.algorithms "qiskit.algorithms") are run on a device or simulator by passing a QuantumInstance setup with the desired backend etc. + +### Parallel Routines + +A helper function for calling a custom function with python `ProcessPoolExecutor`. Tasks can be executed in parallel using this function. It has a built-in event publisher to show the progress of the parallel tasks. + +### parallel\_map + + + +`qiskit.utils.parallel_map(task, values, task_args=(), task_kwargs={}, num_processes=2)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/parallel.py "view source code") + +Parallel execution of a mapping of values to the function task. This is functionally equivalent to: + +```python +result = [task(value, *task_args, **task_kwargs) for value in values] +``` + +On Windows this function defaults to a serial implementation to avoid the overhead from spawning processes in Windows. + +**Parameters** + +* **task** (*func*) – Function that is to be called for each value in `values`. +* **values** (*array\_like*) – List or array of values for which the `task` function is to be evaluated. +* **task\_args** ([*list*](https://docs.python.org/3/library/stdtypes.html#list "(in Python v3.12)")) – Optional additional arguments to the `task` function. +* **task\_kwargs** ([*dict*](https://docs.python.org/3/library/stdtypes.html#dict "(in Python v3.12)")) – Optional additional keyword argument to the `task` function. +* **num\_processes** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.12)")) – Number of processes to spawn. + +**Returns** + +**The result list contains the value of** + +**`task(value, *task_args, **task_kwargs)` for** + +each value in `values`. + +**Return type** + +result + +**Raises** + +[**QiskitError**](exceptions#qiskit.exceptions.QiskitError "qiskit.exceptions.QiskitError") – If user interrupts via keyboard. + +**Events:** + +terra.parallel.start: The collection of parallel tasks are about to start. terra.parallel.update: One of the parallel task has finished. terra.parallel.finish: All the parallel tasks have finished. + +**Examples** + +```python +import time +from qiskit.tools.parallel import parallel_map +def func(_): + time.sleep(0.1) + return 0 +parallel_map(func, list(range(10))); +``` + + + + + +## Optional Dependency Checkers + + + +`qiskit.utils.optionals` + +Qiskit has several features that are enabled only if certain *optional* dependencies are satisfied. This module is a collection of objects that can be used to test if certain functionality is available, and optionally raise [`MissingOptionalLibraryError`](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") if the functionality is not available. + +### Available Testers + +#### Qiskit Components + +| | | +| ------------------------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| **qiskit.utils.optionals.HAS\_AER** | [Qiskit Aer](https://qiskit.org/ecosystem/aer/) provides high-performance simulators for the quantum circuits constructed within Qiskit. | +| **qiskit.utils.optionals.HAS\_IBMQ** | The Qiskit IBMQ Provider was historically used for accessing IBM Quantum hardware in the IBM cloud, but is now deprecated. | +| **qiskit.utils.optionals.HAS\_IGNIS** | Qiskit Ignis provided tools for quantum hardware verification, noise characterization, and error correction, but is now deprecated. | +| **qiskit.utils.optionals.HAS\_TOQM** | [Qiskit TOQM](https://github.com/qiskit-toqm/qiskit-toqm) provides transpiler passes for the [Time-optimal Qubit mapping algorithm](https://doi.org/10.1145/3445814.3446706). | + +#### External Python Libraries + +| | | +| --------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| **qiskit.utils.optionals.HAS\_CONSTRAINT** | python-constraint \<[https://github.com/python-constraint/python-constraint>\_\_](https://github.com/python-constraint/python-constraint>__) is a constraint satisfaction problem solver, used in the :class:\`\~.CSPLayout transpiler pass. | +| **qiskit.utils.optionals.HAS\_CPLEX** | The [IBM CPLEX Optimizer](https://www.ibm.com/analytics/cplex-optimizer) is a high-performance mathematical programming solver for linear, mixed-integer and quadratic programming. This is no longer by Qiskit, but it weas historically and the optional remains for backwards compatibility. | +| **qiskit.utils.optionals.HAS\_CVXPY** | [CVXPY](https://www.cvxpy.org/) is a Python package for solving convex optimization problems. It is required for calculating diamond norms with [`quantum_info.diamond_norm()`](quantum_info#qiskit.quantum_info.diamond_norm "qiskit.quantum_info.diamond_norm"). | +| **qiskit.utils.optionals.HAS\_DOCPLEX** | [IBM Decision Optimization CPLEX Modelling](http://ibmdecisionoptimization.github.io/docplex-doc/) is a library for prescriptive analysis. Like CPLEX, this is no longer by Qiskit, but it weas historically and the optional remains for backwards compatibility. | +| **qiskit.utils.optionals.HAS\_FIXTURES** | The test suite has additional features that are available if the optional [fixtures](https://launchpad.net/python-fixtures) module is installed. This generally also needs [`HAS_TESTTOOLS`](#qiskit.utils.optionals.HAS_TESTTOOLS "qiskit.utils.optionals.HAS_TESTTOOLS") as well. This is generally only needed for Qiskit developers. | +| **qiskit.utils.optionals.HAS\_IPYTHON** | If [the IPython kernel](https://ipython.org/) is available, certain additional visualisations and line magics are made available. | +| **qiskit.utils.optionals.HAS\_IPYWIDGETS** | Monitoring widgets for jobs running on external backends can be provided if [ipywidgets](https://ipywidgets.readthedocs.io/en/latest/) is available. | +| **qiskit.utils.optionals.HAS\_JAX** | Some methods of gradient calculation within [`opflow.gradients`](qiskit.opflow.gradients#module-qiskit.opflow.gradients "qiskit.opflow.gradients") require [JAX](https://github.com/google/jax) for autodifferentiation. | +| **qiskit.utils.optionals.HAS\_JUPYTER** | Some of the tests require a complete [Jupyter](https://jupyter.org/) installation to test interactivity features. | +| **qiskit.utils.optionals.HAS\_MATPLOTLIB** | Qiskit provides several visualisation tools in the [`visualization`](visualization#module-qiskit.visualization "qiskit.visualization") module. Almost all of these are built using [Matplotlib](https://matplotlib.org/), which must be installed in order to use them. | +| **qiskit.utils.optionals.HAS\_NETWORKX** | No longer used by Qiskit. Internally, Qiskit now uses the high-performance [rustworkx](https://github.com/Qiskit/rustworkx) library as a core dependency, and during the change-over period, it was sometimes convenient to convert things into the Python-only [NetworkX](https://networkx.org/) format. Some tests of application modules, such as [Qiskit Nature](https://qiskit.org/ecosystem/nature/) still use NetworkX. | +| **qiskit.utils.optionals.HAS\_NLOPT** | [NLopt](https://nlopt.readthedocs.io/en/latest/) is a nonlinear optimization library, used by the global optimizers in the [`algorithms.optimizers`](qiskit.algorithms.optimizers#module-qiskit.algorithms.optimizers "qiskit.algorithms.optimizers") module. | +| **qiskit.utils.optionals.HAS\_PIL** | PIL is a Python image-manipulation library. Qiskit actually uses the [pillow](https://pillow.readthedocs.io/en/stable/) fork of PIL if it is available when generating certain visualizations, for example of both [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") and [`DAGCircuit`](qiskit.dagcircuit.DAGCircuit "qiskit.dagcircuit.DAGCircuit") in certain modes. | +| **qiskit.utils.optionals.HAS\_PYDOT** | For some graph visualisations, Qiskit uses [pydot](https://github.com/pydot/pydot) as an interface to GraphViz (see [`HAS_GRAPHVIZ`](#qiskit.utils.optionals.HAS_GRAPHVIZ "qiskit.utils.optionals.HAS_GRAPHVIZ")). | +| **qiskit.utils.optionals.HAS\_PYGMENTS** | Pygments is a code highlighter and formatter used by many environments that involve rich display of code blocks, including Sphinx and Jupyter. Qiskit uses this when producing rich output for these environments. | +| **qiskit.utils.optionals.HAS\_PYLATEX** | Various LaTeX-based visualizations, especially the circuit drawers, need access to the [pylatexenc](https://github.com/phfaist/pylatexenc) project to work correctly. | +| **qiskit.utils.optionals.HAS\_QASM3\_IMPORT** | The functions [`qasm3.load()`](qasm3#qiskit.qasm3.load "qiskit.qasm3.load") and [`qasm3.loads()`](qasm3#qiskit.qasm3.loads "qiskit.qasm3.loads") for importing OpenQASM 3 programs into [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit") instances use [an external importer package](https://qiskit.github.io/qiskit-qasm3-import). | +| **qiskit.utils.optionals.HAS\_SEABORN** | Qiskit provides several visualisation tools in the [`visualization`](visualization#module-qiskit.visualization "qiskit.visualization") module. Some of these are built using [Seaborn](https://seaborn.pydata.org/), which must be installed in order to use them. | +| **qiskit.utils.optionals.HAS\_SKLEARN** | Some of the gradient functions in [`opflow.gradients`](qiskit.opflow.gradients#module-qiskit.opflow.gradients "qiskit.opflow.gradients") use regularisation methods from [Scikit Learn](https://scikit-learn.org/stable/). | +| **qiskit.utils.optionals.HAS\_SKQUANT** | Some of the optimisers in [`algorithms.optimizers`](qiskit.algorithms.optimizers#module-qiskit.algorithms.optimizers "qiskit.algorithms.optimizers") are based on those found in [Scikit Quant](https://github.com/scikit-quant/scikit-quant), which must be installed to use them. | +| **qiskit.utils.optionals.HAS\_SQSNOBFIT** | [SQSnobFit](https://pypi.org/project/SQSnobFit/) is a library for the “stable noisy optimization by branch and fit” algorithm. It is used by the [`SNOBFIT`](qiskit.algorithms.optimizers.SNOBFIT "qiskit.algorithms.optimizers.SNOBFIT") optimizer. | +| **qiskit.utils.optionals.HAS\_SYMENGINE** | [Symengine](https://github.com/symengine/symengine) is a fast C++ backend for the symbolic-manipulation library [Sympy](https://www.sympy.org/en/index.html). Qiskit uses special methods from Symengine to accelerate its handling of [`Parameter`](qiskit.circuit.Parameter "qiskit.circuit.Parameter")s if available. | +| **qiskit.utils.optionals.HAS\_TESTTOOLS** | Qiskit’s test suite has more advanced functionality available if the optional [testtools](https://pypi.org/project/testtools/) library is installed. This is generally only needed for Qiskit developers. | +| **qiskit.utils.optionals.HAS\_TWEEDLEDUM** | [Tweedledum](https://github.com/boschmitt/tweedledum) is an extension library for synthesis and optimization of circuits that may involve classical oracles. Qiskit’s [`PhaseOracle`](qiskit.circuit.library.PhaseOracle "qiskit.circuit.library.PhaseOracle") uses this, which is used in turn by amplification algorithms via the [`AmplificationProblem`](qiskit.algorithms.AmplificationProblem "qiskit.algorithms.AmplificationProblem"). | +| **qiskit.utils.optionals.HAS\_Z3** | [Z3](https://github.com/Z3Prover/z3) is a theorem prover, used in the [`CrosstalkAdaptiveSchedule`](qiskit.transpiler.passes.CrosstalkAdaptiveSchedule "qiskit.transpiler.passes.CrosstalkAdaptiveSchedule") and [`HoareOptimizer`](qiskit.transpiler.passes.HoareOptimizer "qiskit.transpiler.passes.HoareOptimizer") transpiler passes. | + +#### External Command-Line Tools + +| | | +| ------------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | +| **qiskit.utils.optionals.HAS\_GRAPHVIZ** | For some graph visualisations, Qiskit uses the [GraphViz](https://graphviz.org/) visualisation tool via its `pydot` interface (see [`HAS_PYDOT`](#qiskit.utils.optionals.HAS_PYDOT "qiskit.utils.optionals.HAS_PYDOT")). | +| **qiskit.utils.optionals.HAS\_PDFLATEX** | Visualisation tools that use LaTeX in their output, such as the circuit drawers, require `pdflatex` to be available. You will generally need to ensure that you have a working LaTeX installation available, and the `qcircuit.tex` package. | +| **qiskit.utils.optionals.HAS\_PDFTOCAIRO** | Visualisation tools that convert LaTeX-generated files into rasterised images use the `pdftocairo` tool. This is part of the [Poppler suite of PDF tools](https://poppler.freedesktop.org/). | + +### Lazy Checker Classes + +Each of the lazy checkers is an instance of [`LazyDependencyManager`](#qiskit.utils.LazyDependencyManager "qiskit.utils.LazyDependencyManager") in one of its two subclasses: [`LazyImportTester`](#qiskit.utils.LazyImportTester "qiskit.utils.LazyImportTester") and [`LazySubprocessTester`](#qiskit.utils.LazySubprocessTester "qiskit.utils.LazySubprocessTester"). These should be imported from [`utils`](#module-qiskit.utils "qiskit.utils") directly if required, such as: + +```python +from qiskit.utils import LazyImportTester +``` + + + +`qiskit.utils.LazyDependencyManager(*, name=None, callback=None, install=None, msg=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/lazy_tester.py "view source code") + +A mananger for some optional features that are expensive to import, or to verify the existence of. + +These objects can be used as Booleans, such as `if x`, and will evaluate `True` if the dependency they test for is available, and `False` if not. The presence of the dependency will only be tested when the Boolean is evaluated, so it can be used as a runtime test in functions and methods without requiring an import-time test. + +These objects also encapsulate the error handling if their dependency is not present, so you can do things such as: + +```python +from qiskit.utils import LazyImportManager +HAS_MATPLOTLIB = LazyImportManager("matplotlib") + +@HAS_MATPLOTLIB.require_in_call +def my_visualisation(): + ... + +def my_other_visualisation(): + # ... some setup ... + HAS_MATPLOTLIB.require_now("my_other_visualisation") + ... + +def my_third_visualisation(): + if HAS_MATPLOTLIB: + from matplotlib import pyplot + else: + ... +``` + +In all of these cases, `matplotlib` is not imported until the functions are entered. In the case of the decorator, `matplotlib` is tested for import when the function is called for the first time. In the second and third cases, the loader attempts to import `matplotlib` when the [`require_now()`](#qiskit.utils.LazyDependencyManager.require_now "qiskit.utils.LazyDependencyManager.require_now") method is called, or when the Boolean context is evaluated. For the `require` methods, an error is raised if the library is not available. + +This is the base class, which provides the Boolean context checking and error management. The concrete classes [`LazyImportTester`](#qiskit.utils.LazyImportTester "qiskit.utils.LazyImportTester") and [`LazySubprocessTester`](#qiskit.utils.LazySubprocessTester "qiskit.utils.LazySubprocessTester") provide convenient entry points for testing that certain symbols are importable from modules, or certain command-line tools are available, respectively. + +**Parameters** + +* **name** – the name of this optional dependency. +* **callback** – a callback that is called immediately after the availability of the library is tested with the result. This will only be called once. +* **install** – how to install this optional dependency. Passed to [`MissingOptionalLibraryError`](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") as the `pip_install` parameter. +* **msg** – an extra message to include in the error raised if this is required. + +### \_is\_available + + + +`abstract _is_available()` + +Subclasses of [`LazyDependencyManager`](#qiskit.utils.LazyDependencyManager "qiskit.utils.LazyDependencyManager") should override this method to implement the actual test of availability. This method should return a Boolean, where `True` indicates that the dependency was available. This method will only ever be called once. + +**Return type** + +[bool](https://docs.python.org/3/library/functions.html#bool "(in Python v3.12)") + +### disable\_locally + + + +`disable_locally()` + +Create a context, during which the value of the dependency manager will be `False`. This means that within the context, any calls to this object will behave as if the dependency is not available, including raising errors. It is valid to call this method whether or not the dependency has already been evaluated. This is most useful in tests. + +### require\_in\_call + +### require\_in\_call + + + +`require_in_call(feature_or_callable: Callable) → Callable` + + + +`require_in_call(feature_or_callable: str) → Callable[[Callable], Callable]` + +Create a decorator for callables that requires that the dependency is available when the decorated function or method is called. + +**Parameters** + +**feature\_or\_callable** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or Callable*) – the name of the feature that requires these dependencies. If this function is called directly as a decorator (for example `@HAS_X.require_in_call` as opposed to `@HAS_X.require_in_call("my feature")`), then the feature name will be taken to be the function name, or class and method name as appropriate. + +**Returns** + +a decorator that will make its argument require this dependency before it is called. + +**Return type** + +Callable + +### require\_in\_instance + +### require\_in\_instance + + + +`require_in_instance(feature_or_class: Type) → Type` + + + +`require_in_instance(feature_or_class: str) → Callable[[Type], Type]` + +A class decorator that requires the dependency is available when the class is initialised. This decorator can be used even if the class does not define an `__init__` method. + +**Parameters** + +**feature\_or\_class** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *or*[*Type*](circuit_classical#qiskit.circuit.classical.types.Type "qiskit.circuit.classical.types.Type")) – the name of the feature that requires these dependencies. If this function is called directly as a decorator (for example `@HAS_X.require_in_instance` as opposed to `@HAS_X.require_in_instance("my feature")`), then the feature name will be taken as the name of the class. + +**Returns** + +a class decorator that ensures that the wrapped feature is present if the class is initialised. + +**Return type** + +Callable + +### require\_now + + + +`require_now(feature)` + +Eagerly attempt to import the dependencies in this object, and raise an exception if they cannot be imported. + +**Parameters** + +**feature** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")) – the name of the feature that is requiring these dependencies. + +**Raises** + +[**MissingOptionalLibraryError**](exceptions#qiskit.exceptions.MissingOptionalLibraryError "qiskit.exceptions.MissingOptionalLibraryError") – if the dependencies cannot be imported. + + + +`qiskit.utils.LazyImportTester(name_map_or_modules, *, name=None, callback=None, install=None, msg=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/lazy_tester.py "view source code") + +A lazy dependency tester for importable Python modules. Any required objects will only be imported at the point that this object is tested for its Boolean value. + +**Parameters** + +**name\_map\_or\_modules** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Dict*](https://docs.python.org/3/library/typing.html#typing.Dict "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*,* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]] |* [*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – if a name map, then a dictionary where the keys are modules or packages, and the values are iterables of names to try and import from that module. It should be valid to write `from import , , ...`. If simply a string or iterable of strings, then it should be valid to write `import ` for each of them. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if no modules are given. + + + +`qiskit.utils.LazySubprocessTester(command, *, name=None, callback=None, install=None, msg=None)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/utils/lazy_tester.py "view source code") + +A lazy checker that a command-line tool is available. The command will only be run once, at the point that this object is checked for its Boolean value. + +**Parameters** + +**command** ([*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)") *|*[*Iterable*](https://docs.python.org/3/library/typing.html#typing.Iterable "(in Python v3.12)")*\[*[*str*](https://docs.python.org/3/library/stdtypes.html#str "(in Python v3.12)")*]*) – the strings that make up the command to be run. For example, `["pdflatex", "-version"]`. + +**Raises** + +[**ValueError**](https://docs.python.org/3/library/exceptions.html#ValueError "(in Python v3.12)") – if an empty command is given. + diff --git a/docs/api/qiskit/0.46/utils_mitigation.md b/docs/api/qiskit/0.46/utils_mitigation.md new file mode 100644 index 00000000000..d8f435a5207 --- /dev/null +++ b/docs/api/qiskit/0.46/utils_mitigation.md @@ -0,0 +1,37 @@ +--- +title: mitigation +description: API reference for qiskit.utils.mitigation +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.utils.mitigation +--- + + + + + + + +# Measurement Mitigation Utils + + + +`qiskit.utils.mitigation` + + + This module is deprecated and will be removed no sooner than 3 months after the release date. For code migration guidelines, visit [https://qisk.it/qi\_migration](https://qisk.it/qi_migration). + + + + The user-facing API stability of this module is not guaranteed except for its use with the [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") (i.e. using the [`CompleteMeasFitter`](qiskit.utils.mitigation.CompleteMeasFitter "qiskit.utils.mitigation.CompleteMeasFitter") or [`TensoredMeasFitter`](qiskit.utils.mitigation.TensoredMeasFitter "qiskit.utils.mitigation.TensoredMeasFitter") classes as values for the `meas_error_mitigation_cls`). The rest of this module should be treated as an internal private API that can not be relied upon. + + +## Measurement correction + +The measurement calibration is used to mitigate measurement errors. The main idea is to prepare all $2^n$ basis input states and compute the probability of measuring counts in the other basis states. From these calibrations, it is possible to correct the average results of another experiment of interest. These tools are intended for use solely with the [`QuantumInstance`](qiskit.utils.QuantumInstance "qiskit.utils.QuantumInstance") class as part of [`qiskit.algorithms`](algorithms#module-qiskit.algorithms "qiskit.algorithms") and [`qiskit.opflow`](opflow#module-qiskit.opflow "qiskit.opflow"). + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------- | +| [`CompleteMeasFitter`](qiskit.utils.mitigation.CompleteMeasFitter "qiskit.utils.mitigation.CompleteMeasFitter")(results, state\_labels\[, ...]) | Deprecated: Measurement correction fitter for a full calibration | +| [`TensoredMeasFitter`](qiskit.utils.mitigation.TensoredMeasFitter "qiskit.utils.mitigation.TensoredMeasFitter")(results, mit\_pattern\[, ...]) | Deprecated: Measurement correction fitter for a tensored calibration. | + diff --git a/docs/api/qiskit/0.46/visualization.md b/docs/api/qiskit/0.46/visualization.md new file mode 100644 index 00000000000..02e5fd0ca03 --- /dev/null +++ b/docs/api/qiskit/0.46/visualization.md @@ -0,0 +1,245 @@ +--- +title: visualization +description: API reference for qiskit.visualization +in_page_toc_min_heading_level: 1 +python_api_type: module +python_api_name: qiskit.visualization +--- + + + + + + + +# Visualizations + + + +`qiskit.visualization` + +The visualization module contain functions that visualizes measurement outcome counts, quantum states, circuits, pulses, devices and more. + +To use visualization functions, you are required to install visualization optionals to your development environment: + +```python +pip install 'qiskit[visualization]' +``` + +## Common Keyword Arguments + +Many of the figures created by visualization functions in this module are created by [Matplotlib](https://matplotlib.org/) and accept a subset of the following common arguments. Consult the individual documentation for exact details. + +* `title` (`str`): a text string to use for the plot title. +* `legend` (`list`): a list of strings to use for labels of the data. +* `figsize` (`tuple`): figure size in inches . +* `color` (`list`): a list of strings for plotting. +* `ax` ([matplotlib.axes.Axes](https://matplotlib.org/stable/api/axes_api.html)): An optional `Axes` object to be used for the visualization output. If none is specified a new [matplotlib.figure.Figure](https://matplotlib.org/stable/api/figure_api.html) will be created and used. Additionally, if specified there will be no returned `Figure` since it is redundant. +* `filename` (`str`): file path to save image to. + +The following example demonstrates the common usage of these arguments: + +```python +from qiskit.visualization import plot_histogram + +counts1 = {'00': 499, '11': 501} +counts2 = {'00': 511, '11': 489} + +data = [counts1, counts2] +plot_histogram(data) +``` + +![../\_images/visualization-1.png](/images/api/qiskit/0.46/visualization-1.png) + +You can specify `legend`, `title`, `figsize` and `color` by passing to the kwargs. + +```python +from qiskit.visualization import plot_histogram + +counts1 = {'00': 499, '11': 501} +counts2 = {'00': 511, '11': 489} +data = [counts1, counts2] + +legend = ['First execution', 'Second execution'] +title = 'New histogram' +figsize = (10,10) +color=['crimson','midnightblue'] +plot_histogram(data, legend=legend, title=title, figsize=figsize, color=color) +``` + +![../\_images/visualization-2.png](/images/api/qiskit/0.46/visualization-2.png) + +You can save the figure to file either by passing the file name to `filename` kwarg or use [matplotlib.figure.Figure.savefig](https://matplotlib.org/stable/api/figure_api.html#matplotlib.figure.Figure.savefig) method. + +```python +plot_histogram(data, filename='new_hist.png') + +hist = plot_histogram(data) +hist.savefig('new_hist.png') +``` + +## Counts Visualizations + +This section contains functions that visualize measurement outcome counts. + +| | | +| --------------------------------------------------------------------------------------------------------------------------- | -------------------------------------- | +| [`plot_histogram`](qiskit.visualization.plot_histogram "qiskit.visualization.plot_histogram")(data\[, figsize, color, ...]) | Plot a histogram of input counts data. | + +### Example Usage + +Here is an example of using [`plot_histogram()`](qiskit.visualization.plot_histogram "qiskit.visualization.plot_histogram") to visualize measurement outcome counts: + +```python +from qiskit.visualization import plot_histogram + +counts = {"00": 501, "11": 499} +plot_histogram(counts) +``` + +![../\_images/visualization-3.png](/images/api/qiskit/0.46/visualization-3.png) + +The data can be a dictionary with bit string as key and counts as value, or more commonly a [`Counts`](qiskit.result.Counts "qiskit.result.Counts") object obtained from [`get_counts()`](qiskit.result.Result#get_counts "qiskit.result.Result.get_counts"). + +## Distribution Visualizations + +This section contains functions that visualize sampled distributions. + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------ | -------------------------------------------- | +| [`plot_distribution`](qiskit.visualization.plot_distribution "qiskit.visualization.plot_distribution")(data\[, figsize, color, ...]) | Plot a distribution from input sampled data. | + +## State Visualizations + +This section contains functions that visualize quantum states. + +| | | +| ------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------- | +| [`plot_bloch_vector`](qiskit.visualization.plot_bloch_vector "qiskit.visualization.plot_bloch_vector")(bloch\[, title, ax, ...]) | Plot the Bloch sphere. | +| [`plot_bloch_multivector`](qiskit.visualization.plot_bloch_multivector "qiskit.visualization.plot_bloch_multivector")(state\[, title, ...]) | Plot a Bloch sphere for each qubit. | +| [`plot_state_city`](qiskit.visualization.plot_state_city "qiskit.visualization.plot_state_city")(state\[, title, figsize, ...]) | Plot the cityscape of quantum state. | +| [`plot_state_hinton`](qiskit.visualization.plot_state_hinton "qiskit.visualization.plot_state_hinton")(state\[, title, figsize, ...]) | Plot a hinton diagram for the density matrix of a quantum state. | +| [`plot_state_paulivec`](qiskit.visualization.plot_state_paulivec "qiskit.visualization.plot_state_paulivec")(state\[, title, figsize, ...]) | Plot the Pauli-vector representation of a quantum state as bar graph. | +| [`plot_state_qsphere`](qiskit.visualization.plot_state_qsphere "qiskit.visualization.plot_state_qsphere")(state\[, figsize, ax, ...]) | Plot the qsphere representation of a quantum state. | + + + +### Example Usage + +Here is an example of using [`plot_state_city()`](qiskit.visualization.plot_state_city "qiskit.visualization.plot_state_city") to visualize a quantum state: + +```python +from qiskit.visualization import plot_state_city + +state = [[ 0.75 , 0.433j], + [-0.433j, 0.25 ]] +plot_state_city(state) +``` + +![../\_images/visualization-4.png](/images/api/qiskit/0.46/visualization-4.png) + +The state can be array-like list of lists, `numpy.array`, or more commonly [`Statevector`](qiskit.quantum_info.Statevector "qiskit.quantum_info.Statevector") or [`DensityMatrix`](qiskit.quantum_info.DensityMatrix "qiskit.quantum_info.DensityMatrix") objects obtained from a [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"): + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import Statevector +from qiskit.visualization import plot_state_city + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0,1) + +# plot using a Statevector +state = Statevector(qc) +plot_state_city(state) +``` + +![../\_images/visualization-5.png](/images/api/qiskit/0.46/visualization-5.png) + +```python +from qiskit import QuantumCircuit +from qiskit.quantum_info import DensityMatrix +from qiskit.visualization import plot_state_city + +qc = QuantumCircuit(2) +qc.h(0) +qc.cx(0,1) + +# plot using a DensityMatrix +state = DensityMatrix(qc) +plot_state_city(state) +``` + +![../\_images/visualization-6.png](/images/api/qiskit/0.46/visualization-6.png) + +You can find code examples for each visualization functions on the individual function API page. + +## Device Visualizations + +| | | +| -------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------- | +| [`plot_gate_map`](qiskit.visualization.plot_gate_map "qiskit.visualization.plot_gate_map")(backend\[, figsize, ...]) | Plots the gate map of a device. | +| [`plot_error_map`](qiskit.visualization.plot_error_map "qiskit.visualization.plot_error_map")(backend\[, figsize, ...]) | Plots the error map of a given backend. | +| [`plot_circuit_layout`](qiskit.visualization.plot_circuit_layout "qiskit.visualization.plot_circuit_layout")(circuit, backend\[, ...]) | Plot the layout of a circuit transpiled for a given target backend. | +| [`plot_coupling_map`](qiskit.visualization.plot_coupling_map "qiskit.visualization.plot_coupling_map")(num\_qubits, ...\[, ...]) | Plots an arbitrary coupling map of qubits (embedded in a plane). | + +## Circuit Visualizations + +| | | +| ------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------- | +| [`circuit_drawer`](qiskit.visualization.circuit_drawer "qiskit.visualization.circuit_drawer")(circuit\[, scale, filename, ...]) | Draw the quantum circuit. | +| [`DefaultStyle`](qiskit.visualization.circuit.qcstyle.DefaultStyle "qiskit.visualization.circuit.qcstyle.DefaultStyle")() | Creates a Default Style dictionary | + +## DAG Visualizations + +| | | +| ----------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------- | +| [`dag_drawer`](qiskit.visualization.dag_drawer "qiskit.visualization.dag_drawer")(dag\[, scale, filename, style]) | Plot the directed acyclic graph (dag) to represent operation dependencies in a quantum circuit. | + +## Pass Manager Visualizations + +| | | +| ----------------------------------------------------------------------------------------------------------------------------------- | ----------------------- | +| [`pass_manager_drawer`](qiskit.visualization.pass_manager_drawer "qiskit.visualization.pass_manager_drawer")(pass\_manager\[, ...]) | Draws the pass manager. | + +## Pulse Visualizations + +| | | +| ------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------- | +| [`pulse_drawer`](qiskit.visualization.pulse_drawer "qiskit.visualization.pulse_drawer")(program\[, style, backend, ...]) | Generate visualization data for pulse programs. | +| [`IQXStandard`](qiskit.visualization.pulse.IQXStandard "qiskit.visualization.pulse.IQXStandard")(\*\*kwargs) | Standard pulse stylesheet. | +| [`IQXSimple`](qiskit.visualization.pulse.IQXSimple "qiskit.visualization.pulse.IQXSimple")(\*\*kwargs) | Simple pulse stylesheet without channel notation. | +| [`IQXDebugging`](qiskit.visualization.pulse.IQXDebugging "qiskit.visualization.pulse.IQXDebugging")(\*\*kwargs) | Pulse stylesheet for pulse programmers. | + +## Timeline Visualizations + +| | | +| ------------------------------------------------------------------------------------------------------------------------ | ----------------------------------------------------------- | +| [`timeline_drawer`](qiskit.visualization.timeline_drawer "qiskit.visualization.timeline_drawer")(program\[, style, ...]) | Generate visualization data for scheduled circuit programs. | + +## Single Qubit State Transition Visualizations + +| | | +| --------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------- | +| [`visualize_transition`](qiskit.visualization.visualize_transition "qiskit.visualization.visualize_transition")(circuit\[, trace, ...]) | Creates animation showing transitions between states of a single qubit by applying quantum gates. | + + + +## Array/Matrix Visualizations + +| | | +| ------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------- | +| [`array_to_latex`](qiskit.visualization.array_to_latex "qiskit.visualization.array_to_latex")(array\[, precision, prefix, ...]) | Latex representation of a complex numpy array (with dimension 1 or 2) | + +## Exceptions + +### VisualizationError + + + +`qiskit.visualization.VisualizationError(*message)`[GitHub](https://github.com/qiskit/qiskit/tree/stable/0.46/qiskit/visualization/exceptions.py "view source code") + +For visualization specific errors. + +Set the error message. + diff --git a/public/images/api/qiskit/0.46/circuit-1.png b/public/images/api/qiskit/0.46/circuit-1.png new file mode 100644 index 0000000000000000000000000000000000000000..1c2f70894dfb00cdcdd33915fd0f49f87eaa54bb GIT binary patch literal 4978 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 KL8;!u$iD&O7?Ab= literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/0.46/circuit-2.png b/public/images/api/qiskit/0.46/circuit-2.png new file mode 100644 index 0000000000000000000000000000000000000000..2184a3d1db1b8be3cd5fb4e7a207ae02f9c1957c GIT binary patch literal 3885 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 PUsu4?5OKZIz%Ay#$2BS` literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/0.46/circuit-3.png b/public/images/api/qiskit/0.46/circuit-3.png new file mode 100644 index 0000000000000000000000000000000000000000..70abaad117f4769f0332920b846eb7ed88dcc24e GIT binary patch literal 5628 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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/0.46/circuit-4.png b/public/images/api/qiskit/0.46/circuit-4.png new file mode 100644 index 0000000000000000000000000000000000000000..d7c78dda5565f4b92fccd801bd519bedc15471f9 GIT binary patch literal 27444 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℘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 literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/0.46/circuit_library-1.png b/public/images/api/qiskit/0.46/circuit_library-1.png new file mode 100644 index 0000000000000000000000000000000000000000..72bcbd480c5cbca4bea83633730ba766ea3d2463 GIT binary patch literal 5904 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 B_(K2y literal 0 HcmV?d00001 diff --git a/public/images/api/qiskit/0.46/depth.gif b/public/images/api/qiskit/0.46/depth.gif new file mode 100644 index 0000000000000000000000000000000000000000..4437049fc8829bce63ab0cd9d5089b3b7011cc55 GIT binary patch literal 2874095 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�okcZtFf{p1hw=P5GV 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

h}GjPha2KophxFqzbUL}%YxcJqiX-K1P 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

  • lJ#GT;3{^ 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

    oA1i@H~V4G6bLey&;1Z@lE|HEHmHs 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

    r9O0Npb6O@lm(B384k{ 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%0DhK?f=f}!}myzy0SK= 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ПXa~Iz{FPEaxxXTiUkb7O(P8|xt0Azzh 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 z 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 z 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 z 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ⅇ(+; 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⋙1 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%0AJc*-A`R3} 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

    >$OO#;D;5WaM3PI?+N{)JqlTf^x{D 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˰v}$F)s23MZaE<;Sd;e(Dk>|JSYIGWo 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 s2MG5W#TjK$Io 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­3X+{3 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 z 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%0AeNpkPpBl3t(mYA9Ke5ASwnBwfc|Uk#z+q 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